diff --git a/.gitignore b/.gitignore index 7d45c62..2daaaaf 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,3 @@ node_modules -dist +./dist push.bat \ No newline at end of file diff --git a/dist/bundle.css b/dist/bundle.css new file mode 100644 index 0000000..caf5bd0 --- /dev/null +++ b/dist/bundle.css @@ -0,0 +1,3009 @@ +/* + * MDC varibles + * must before import + */ +/* font color */ +/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */ +/* Document + ========================================================================== */ +/** + * 1. Correct the line height in all browsers. + * 2. Prevent adjustments of font size after orientation changes in iOS. + */ +html { + line-height: 1.15; + /* 1 */ + -webkit-text-size-adjust: 100%; + /* 2 */ } + +/* Sections + ========================================================================== */ +/** + * Remove the margin in all browsers. + */ +body { + margin: 0; } + +/** + * Render the `main` element consistently in IE. + */ +main { + display: block; } + +/** + * Correct the font size and margin on `h1` elements within `section` and + * `article` contexts in Chrome, Firefox, and Safari. + */ +h1 { + font-size: 2em; + margin: 0.67em 0; } + +/* Grouping content + ========================================================================== */ +/** + * 1. Add the correct box sizing in Firefox. + * 2. Show the overflow in Edge and IE. + */ +hr { + box-sizing: content-box; + /* 1 */ + height: 0; + /* 1 */ + overflow: visible; + /* 2 */ } + +/** + * 1. Correct the inheritance and scaling of font size in all browsers. + * 2. Correct the odd `em` font sizing in all browsers. + */ +pre { + font-family: monospace, monospace; + /* 1 */ + font-size: 1em; + /* 2 */ } + +/* Text-level semantics + ========================================================================== */ +/** + * Remove the gray background on active links in IE 10. + */ +a { + background-color: transparent; } + +/** + * 1. Remove the bottom border in Chrome 57- + * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. + */ +abbr[title] { + border-bottom: none; + /* 1 */ + text-decoration: underline; + /* 2 */ + -webkit-text-decoration: underline dotted; + text-decoration: underline dotted; + /* 2 */ } + +/** + * Add the correct font weight in Chrome, Edge, and Safari. + */ +b, +strong { + font-weight: bolder; } + +/** + * 1. Correct the inheritance and scaling of font size in all browsers. + * 2. Correct the odd `em` font sizing in all browsers. + */ +code, +kbd, +samp { + font-family: monospace, monospace; + /* 1 */ + font-size: 1em; + /* 2 */ } + +/** + * Add the correct font size in all browsers. + */ +small { + font-size: 80%; } + +/** + * Prevent `sub` and `sup` elements from affecting the line height in + * all browsers. + */ +sub, +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; } + +sub { + bottom: -0.25em; } + +sup { + top: -0.5em; } + +/* Embedded content + ========================================================================== */ +/** + * Remove the border on images inside links in IE 10. + */ +img { + border-style: none; } + +/* Forms + ========================================================================== */ +/** + * 1. Change the font styles in all browsers. + * 2. Remove the margin in Firefox and Safari. + */ +button, +input, +optgroup, +select, +textarea { + font-family: inherit; + /* 1 */ + font-size: 100%; + /* 1 */ + line-height: 1.15; + /* 1 */ + margin: 0; + /* 2 */ } + +/** + * Show the overflow in IE. + * 1. Show the overflow in Edge. + */ +button, +input { + /* 1 */ + overflow: visible; } + +/** + * Remove the inheritance of text transform in Edge, Firefox, and IE. + * 1. Remove the inheritance of text transform in Firefox. + */ +button, +select { + /* 1 */ + text-transform: none; } + +/** + * Correct the inability to style clickable types in iOS and Safari. + */ +button, +[type="button"], +[type="reset"], +[type="submit"] { + -webkit-appearance: button; } + +/** + * Remove the inner border and padding in Firefox. + */ +button::-moz-focus-inner, +[type="button"]::-moz-focus-inner, +[type="reset"]::-moz-focus-inner, +[type="submit"]::-moz-focus-inner { + border-style: none; + padding: 0; } + +/** + * Restore the focus styles unset by the previous rule. + */ +button:-moz-focusring, +[type="button"]:-moz-focusring, +[type="reset"]:-moz-focusring, +[type="submit"]:-moz-focusring { + outline: 1px dotted ButtonText; } + +/** + * Correct the padding in Firefox. + */ +fieldset { + padding: 0.35em 0.75em 0.625em; } + +/** + * 1. Correct the text wrapping in Edge and IE. + * 2. Correct the color inheritance from `fieldset` elements in IE. + * 3. Remove the padding so developers are not caught out when they zero out + * `fieldset` elements in all browsers. + */ +legend { + box-sizing: border-box; + /* 1 */ + color: inherit; + /* 2 */ + display: table; + /* 1 */ + max-width: 100%; + /* 1 */ + padding: 0; + /* 3 */ + white-space: normal; + /* 1 */ } + +/** + * Add the correct vertical alignment in Chrome, Firefox, and Opera. + */ +progress { + vertical-align: baseline; } + +/** + * Remove the default vertical scrollbar in IE 10+. + */ +textarea { + overflow: auto; } + +/** + * 1. Add the correct box sizing in IE 10. + * 2. Remove the padding in IE 10. + */ +[type="checkbox"], +[type="radio"] { + box-sizing: border-box; + /* 1 */ + padding: 0; + /* 2 */ } + +/** + * Correct the cursor style of increment and decrement buttons in Chrome. + */ +[type="number"]::-webkit-inner-spin-button, +[type="number"]::-webkit-outer-spin-button { + height: auto; } + +/** + * 1. Correct the odd appearance in Chrome and Safari. + * 2. Correct the outline style in Safari. + */ +[type="search"] { + -webkit-appearance: textfield; + /* 1 */ + outline-offset: -2px; + /* 2 */ } + +/** + * Remove the inner padding in Chrome and Safari on macOS. + */ +[type="search"]::-webkit-search-decoration { + -webkit-appearance: none; } + +/** + * 1. Correct the inability to style clickable types in iOS and Safari. + * 2. Change font properties to `inherit` in Safari. + */ +::-webkit-file-upload-button { + -webkit-appearance: button; + /* 1 */ + font: inherit; + /* 2 */ } + +/* Interactive + ========================================================================== */ +/* + * Add the correct display in Edge, IE 10+, and Firefox. + */ +details { + display: block; } + +/* + * Add the correct display in all browsers. + */ +summary { + display: list-item; } + +/* Misc + ========================================================================== */ +/** + * Add the correct display in IE 10+. + */ +template { + display: none; } + +/** + * Add the correct display in IE 10. + */ +[hidden] { + display: none; } + +.mdc-floating-label { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.75rem; + font-weight: 400; + letter-spacing: 0.00937em; + text-decoration: inherit; + text-transform: inherit; + position: absolute; + /* @noflip */ + left: 0; + /* @noflip */ + -webkit-transform-origin: left top; + transform-origin: left top; + -webkit-transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 150ms cubic-bezier(0.4, 0, 0.2, 1), color 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 150ms cubic-bezier(0.4, 0, 0.2, 1), color 150ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 150ms cubic-bezier(0.4, 0, 0.2, 1); + /* @alternate */ + line-height: 1.15rem; + text-align: left; + text-overflow: ellipsis; + white-space: nowrap; + cursor: text; + overflow: hidden; + will-change: transform; } + [dir="rtl"] .mdc-floating-label, .mdc-floating-label[dir="rtl"] { + /* @noflip */ + right: 0; + /* @noflip */ + left: auto; + /* @noflip */ + -webkit-transform-origin: right top; + transform-origin: right top; + /* @noflip */ + text-align: right; } + +.mdc-floating-label--float-above { + cursor: auto; } + +.mdc-floating-label--float-above { + -webkit-transform: translateY(-50%) scale(0.75); + transform: translateY(-50%) scale(0.75); } + +.mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-standard 250ms 1; + animation: mdc-floating-label-shake-float-above-standard 250ms 1; } + +@-webkit-keyframes mdc-floating-label-shake-float-above-standard { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-standard { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } } + +.mdc-line-ripple { + position: absolute; + bottom: 0; + left: 0; + width: 100%; + height: 2px; + -webkit-transform: scaleX(0); + transform: scaleX(0); + -webkit-transition: opacity 180ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 180ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 180ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 180ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 180ms cubic-bezier(0.4, 0, 0.2, 1), opacity 180ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 180ms cubic-bezier(0.4, 0, 0.2, 1), opacity 180ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 180ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + z-index: 2; } + +.mdc-line-ripple--active { + -webkit-transform: scaleX(1); + transform: scaleX(1); + opacity: 1; } + +.mdc-line-ripple--deactivating { + opacity: 0; } + +.mdc-notched-outline { + display: -webkit-box; + display: flex; + position: absolute; + right: 0; + left: 0; + box-sizing: border-box; + width: 100%; + max-width: 100%; + height: 100%; + /* @noflip */ + text-align: left; + pointer-events: none; } + [dir="rtl"] .mdc-notched-outline, .mdc-notched-outline[dir="rtl"] { + /* @noflip */ + text-align: right; } + .mdc-notched-outline__leading, .mdc-notched-outline__notch, .mdc-notched-outline__trailing { + box-sizing: border-box; + height: 100%; + -webkit-transition: border 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: border 150ms cubic-bezier(0.4, 0, 0.2, 1); + border-top: 1px solid; + border-bottom: 1px solid; + pointer-events: none; } + .mdc-notched-outline__leading { + /* @noflip */ + border-left: 1px solid; + /* @noflip */ + border-right: none; + width: 12px; } + [dir="rtl"] .mdc-notched-outline__leading, .mdc-notched-outline__leading[dir="rtl"] { + /* @noflip */ + border-left: none; + /* @noflip */ + border-right: 1px solid; } + .mdc-notched-outline__trailing { + /* @noflip */ + border-left: none; + /* @noflip */ + border-right: 1px solid; + -webkit-box-flex: 1; + flex-grow: 1; } + [dir="rtl"] .mdc-notched-outline__trailing, .mdc-notched-outline__trailing[dir="rtl"] { + /* @noflip */ + border-left: 1px solid; + /* @noflip */ + border-right: none; } + .mdc-notched-outline__notch { + -webkit-box-flex: 0; + flex: 0 0 auto; + width: auto; + max-width: calc(100% - 12px * 2); } + .mdc-notched-outline .mdc-floating-label { + display: inline-block; + position: relative; + top: 17px; + bottom: auto; + max-width: 100%; } + .mdc-notched-outline .mdc-floating-label--float-above { + text-overflow: clip; } + .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + max-width: calc(100% / .75); } + +.mdc-notched-outline--notched .mdc-notched-outline__notch { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 8px; + border-top: none; } + [dir="rtl"] .mdc-notched-outline--notched .mdc-notched-outline__notch, .mdc-notched-outline--notched .mdc-notched-outline__notch[dir="rtl"] { + /* @noflip */ + padding-left: 8px; + /* @noflip */ + padding-right: 0; } + +.mdc-notched-outline--no-label .mdc-notched-outline__notch { + padding: 0; } + +@-webkit-keyframes mdc-ripple-fg-radius-in { + from { + -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + -webkit-transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); + transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); } + to { + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } } + +@keyframes mdc-ripple-fg-radius-in { + from { + -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + -webkit-transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); + transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); } + to { + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } } + +@-webkit-keyframes mdc-ripple-fg-opacity-in { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: 0; } + to { + opacity: var(--mdc-ripple-fg-opacity, 0); } } + +@keyframes mdc-ripple-fg-opacity-in { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: 0; } + to { + opacity: var(--mdc-ripple-fg-opacity, 0); } } + +@-webkit-keyframes mdc-ripple-fg-opacity-out { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: var(--mdc-ripple-fg-opacity, 0); } + to { + opacity: 0; } } + +@keyframes mdc-ripple-fg-opacity-out { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: var(--mdc-ripple-fg-opacity, 0); } + to { + opacity: 0; } } + +.mdc-ripple-surface--test-edge-var-bug { + --mdc-ripple-surface-test-edge-var: 1px solid #000; + visibility: hidden; } + .mdc-ripple-surface--test-edge-var-bug::before { + border: var(--mdc-ripple-surface-test-edge-var); } + +.mdc-text-field-helper-text { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.03333em; + text-decoration: inherit; + text-transform: inherit; + display: block; + margin-top: 0; + /* @alternate */ + line-height: normal; + margin: 0; + -webkit-transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + will-change: opacity; } + .mdc-text-field-helper-text::before { + display: inline-block; + width: 0; + height: 16px; + content: ""; + vertical-align: 0; } + +.mdc-text-field-helper-text--persistent { + -webkit-transition: none; + transition: none; + opacity: 1; + will-change: initial; } + +.mdc-text-field-character-counter { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.03333em; + text-decoration: inherit; + text-transform: inherit; + display: block; + margin-top: 0; + /* @alternate */ + line-height: normal; + /* @noflip */ + margin-left: auto; + /* @noflip */ + margin-right: 0; + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 0; + white-space: nowrap; } + .mdc-text-field-character-counter::before { + display: inline-block; + width: 0; + height: 16px; + content: ""; + vertical-align: 0; } + [dir="rtl"] .mdc-text-field-character-counter, .mdc-text-field-character-counter[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: auto; } + [dir="rtl"] .mdc-text-field-character-counter, .mdc-text-field-character-counter[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-leading-icon .mdc-text-field__icon, +.mdc-text-field--with-trailing-icon .mdc-text-field__icon { + position: absolute; + bottom: 16px; + cursor: pointer; } + +.mdc-text-field__icon:not([tabindex]), +.mdc-text-field__icon[tabindex="-1"] { + cursor: default; + pointer-events: none; } + +.mdc-text-field { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); + border-radius: 4px 4px 0 0; + display: -webkit-inline-box; + display: inline-flex; + position: relative; + box-sizing: border-box; + height: 56px; + overflow: hidden; + /* @alternate */ + will-change: opacity, transform, color; } + .mdc-text-field::before, .mdc-text-field::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-text-field::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-text-field.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-text-field.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-text-field.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-text-field.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-text-field.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-text-field::before, .mdc-text-field::after { + background-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field:hover::before { + opacity: 0.04; } + .mdc-text-field:not(.mdc-ripple-upgraded):focus::before, .mdc-text-field.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-text-field::before, .mdc-text-field::after { + top: calc(50% - 100%); + /* @noflip */ + left: calc(50% - 100%); + width: 200%; + height: 200%; } + .mdc-text-field.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-floating-label { + color: rgba(0, 0, 0, 0.6); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-text-field__input { + color: rgba(0, 0, 0, 0.87); } + .mdc-text-field .mdc-text-field__input { + caret-color: #fcb8ab; + /* @alternate */ + caret-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input { + border-bottom-color: rgba(0, 0, 0, 0.42); } + .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input:hover { + border-bottom-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field .mdc-line-ripple { + background-color: #fcb8ab; + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--textarea) { + border-bottom-color: rgba(0, 0, 0, 0.12); } + .mdc-text-field:not(.mdc-text-field--disabled) + .mdc-text-field-helper-line .mdc-text-field-helper-text { + color: rgba(0, 0, 0, 0.6); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-text-field-character-counter, + .mdc-text-field:not(.mdc-text-field--disabled) + .mdc-text-field-helper-line .mdc-text-field-character-counter { + color: rgba(0, 0, 0, 0.6); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-text-field__icon { + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field:not(.mdc-text-field--disabled) { + background-color: whitesmoke; } + .mdc-text-field .mdc-floating-label { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; + top: 18px; + pointer-events: none; } + [dir="rtl"] .mdc-text-field .mdc-floating-label, .mdc-text-field .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + .mdc-text-field--textarea .mdc-floating-label { + /* @noflip */ + left: 4px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--textarea .mdc-floating-label, .mdc-text-field--textarea .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 4px; } + .mdc-text-field--outlined .mdc-floating-label { + /* @noflip */ + left: 4px; + /* @noflip */ + right: initial; + top: 17px; } + [dir="rtl"] .mdc-text-field--outlined .mdc-floating-label, .mdc-text-field--outlined .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 4px; } + .mdc-text-field--outlined--with-leading-icon .mdc-floating-label { + /* @noflip */ + left: 36px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--outlined--with-leading-icon .mdc-floating-label, .mdc-text-field--outlined--with-leading-icon .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 36px; } + .mdc-text-field--outlined--with-leading-icon .mdc-floating-label--float-above { + /* @noflip */ + left: 40px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--outlined--with-leading-icon .mdc-floating-label--float-above, .mdc-text-field--outlined--with-leading-icon .mdc-floating-label--float-above[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 40px; } + +.mdc-text-field__input { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.75rem; + font-weight: 400; + letter-spacing: 0.00937em; + text-decoration: inherit; + text-transform: inherit; + align-self: flex-end; + box-sizing: border-box; + width: 100%; + height: 100%; + padding: 20px 16px 6px; + -webkit-transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + border: none; + border-bottom: 1px solid; + border-radius: 0; + background: none; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; } + .mdc-text-field__input::-webkit-input-placeholder { + -webkit-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input::-moz-placeholder { + -moz-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input:-ms-input-placeholder { + -ms-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input::-ms-input-placeholder { + -ms-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input::placeholder { + -webkit-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input:-ms-input-placeholder { + color: rgba(0, 0, 0, 0.54) !important; } + .mdc-text-field--fullwidth .mdc-text-field__input::-webkit-input-placeholder, .mdc-text-field--no-label .mdc-text-field__input::-webkit-input-placeholder, .mdc-text-field--focused .mdc-text-field__input::-webkit-input-placeholder { + -webkit-transition-delay: 40ms; + transition-delay: 40ms; + -webkit-transition-duration: 110ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input::-moz-placeholder, .mdc-text-field--no-label .mdc-text-field__input::-moz-placeholder, .mdc-text-field--focused .mdc-text-field__input::-moz-placeholder { + transition-delay: 40ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input:-ms-input-placeholder, .mdc-text-field--no-label .mdc-text-field__input:-ms-input-placeholder, .mdc-text-field--focused .mdc-text-field__input:-ms-input-placeholder { + transition-delay: 40ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input::-ms-input-placeholder, .mdc-text-field--no-label .mdc-text-field__input::-ms-input-placeholder, .mdc-text-field--focused .mdc-text-field__input::-ms-input-placeholder { + transition-delay: 40ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input::placeholder, + .mdc-text-field--no-label .mdc-text-field__input::placeholder, + .mdc-text-field--focused .mdc-text-field__input::placeholder { + -webkit-transition-delay: 40ms; + transition-delay: 40ms; + -webkit-transition-duration: 110ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field__input:focus { + outline: none; } + .mdc-text-field__input:invalid { + box-shadow: none; } + .mdc-text-field__input:-webkit-autofill { + z-index: auto !important; } + .mdc-text-field--no-label:not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input { + padding-top: 16px; + padding-bottom: 16px; } + +.mdc-text-field__input:-webkit-autofill + .mdc-floating-label { + -webkit-transform: translateY(-50%) scale(0.75); + transform: translateY(-50%) scale(0.75); + cursor: auto; } + +.mdc-text-field--outlined { + border: none; + overflow: visible; } + .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.38); } + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field--outlined .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; } + .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading { + /* @noflip */ + border-radius: 4px 0 0 4px; } + [dir="rtl"] .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading, .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading[dir="rtl"] { + /* @noflip */ + border-radius: 0 4px 4px 0; } + .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing { + /* @noflip */ + border-radius: 0 4px 4px 0; } + [dir="rtl"] .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing, .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing[dir="rtl"] { + /* @noflip */ + border-radius: 4px 0 0 4px; } + .mdc-text-field--outlined .mdc-floating-label--float-above { + -webkit-transform: translateY(-144%) scale(1); + transform: translateY(-144%) scale(1); } + .mdc-text-field--outlined .mdc-floating-label--float-above { + font-size: 0.75rem; } + .mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-130%) scale(0.75); + transform: translateY(-130%) scale(0.75); } + .mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + .mdc-text-field--outlined::before, .mdc-text-field--outlined::after { + content: none; } + .mdc-text-field--outlined:not(.mdc-text-field--disabled) { + background-color: transparent; } + .mdc-text-field--outlined .mdc-text-field__input { + display: -webkit-box; + display: flex; + padding: 12px 16px 14px; + border: none !important; + background-color: transparent; + z-index: 1; } + .mdc-text-field--outlined .mdc-text-field__icon { + z-index: 2; } + +.mdc-text-field--outlined.mdc-text-field--focused .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--focused .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--focused .mdc-notched-outline__trailing { + border-width: 2px; } + +.mdc-text-field--outlined.mdc-text-field--disabled { + background-color: transparent; } + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-notched-outline__leading, + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-notched-outline__notch, + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.06); } + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input { + border-bottom: none; } + +.mdc-text-field--outlined.mdc-text-field--dense { + height: 48px; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + -webkit-transform: translateY(-134%) scale(1); + transform: translateY(-134%) scale(1); } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + font-size: 0.8rem; } + .mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-120%) scale(0.8); + transform: translateY(-120%) scale(0.8); } + .mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-dense 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-dense 250ms 1; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-text-field__input { + padding: 12px 12px 7px; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label { + top: 14px; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-text-field__icon { + top: 12px; } + +.mdc-text-field--with-leading-icon .mdc-text-field__icon { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon .mdc-text-field__icon, .mdc-text-field--with-leading-icon .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + +.mdc-text-field--with-leading-icon .mdc-text-field__input { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + [dir="rtl"] .mdc-text-field--with-leading-icon .mdc-text-field__input, .mdc-text-field--with-leading-icon .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + +.mdc-text-field--with-leading-icon .mdc-floating-label { + /* @noflip */ + left: 48px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon .mdc-floating-label, .mdc-text-field--with-leading-icon .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 48px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__icon { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__input { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above { + -webkit-transform: translateY(-144%) translateX(-32px) scale(1); + transform: translateY(-144%) translateX(-32px) scale(1); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-144%) translateX(32px) scale(1); + transform: translateY(-144%) translateX(32px) scale(1); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above { + font-size: 0.75rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-130%) translateX(-32px) scale(0.75); + transform: translateY(-130%) translateX(-32px) scale(0.75); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"], [dir="rtl"] + .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-130%) translateX(32px) scale(0.75); + transform: translateY(-130%) translateX(32px) scale(0.75); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon 250ms 1; } + +[dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--shake, .mdc-text-field--with-leading-icon.mdc-text-field--outlined[dir="rtl"] .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl 250ms 1; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label { + /* @noflip */ + left: 36px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 36px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + -webkit-transform: translateY(-134%) translateX(-21px) scale(1); + transform: translateY(-134%) translateX(-21px) scale(1); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-134%) translateX(21px) scale(1); + transform: translateY(-134%) translateX(21px) scale(1); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + font-size: 0.8rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-120%) translateX(-21px) scale(0.8); + transform: translateY(-120%) translateX(-21px) scale(0.8); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"], [dir="rtl"] + .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-120%) translateX(21px) scale(0.8); + transform: translateY(-120%) translateX(21px) scale(0.8); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense 250ms 1; } + +[dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--shake, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense[dir="rtl"] .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl 250ms 1; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label { + /* @noflip */ + left: 32px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 32px; } + +.mdc-text-field--with-trailing-icon .mdc-text-field__icon { + /* @noflip */ + left: initial; + /* @noflip */ + right: 12px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon .mdc-text-field__icon, .mdc-text-field--with-trailing-icon .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: 12px; + /* @noflip */ + right: initial; } + +.mdc-text-field--with-trailing-icon .mdc-text-field__input { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon .mdc-text-field__input, .mdc-text-field--with-trailing-icon .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__icon { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__icon, .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__input { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__input, .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon { + /* @noflip */ + left: 16px; + /* @noflip */ + right: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: auto; + /* @noflip */ + right: 16px; } + .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon ~ .mdc-text-field__icon { + /* @noflip */ + right: 12px; + /* @noflip */ + left: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon ~ .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon ~ .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + right: auto; + /* @noflip */ + left: 12px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__input { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 48px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 48px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon, +.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon { + bottom: 16px; + -webkit-transform: scale(0.8); + transform: scale(0.8); } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon { + /* @noflip */ + left: 12px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 12px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__input { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 16px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 44px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-floating-label { + /* @noflip */ + left: 44px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-floating-label, .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 44px; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon { + /* @noflip */ + left: initial; + /* @noflip */ + right: 12px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon, .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: 12px; + /* @noflip */ + right: initial; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 44px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input, .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon { + /* @noflip */ + left: 12px; + /* @noflip */ + right: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: auto; + /* @noflip */ + right: 12px; } + .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon ~ .mdc-text-field__icon { + /* @noflip */ + right: 12px; + /* @noflip */ + left: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon ~ .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon ~ .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + right: auto; + /* @noflip */ + left: 12px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 44px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 44px; } + +.mdc-text-field--dense .mdc-floating-label--float-above { + -webkit-transform: translateY(-70%) scale(0.8); + transform: translateY(-70%) scale(0.8); } + +.mdc-text-field--dense .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-dense 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-dense 250ms 1; } + +.mdc-text-field--dense .mdc-text-field__input { + padding: 12px 12px 0; } + +.mdc-text-field--dense .mdc-floating-label { + font-size: .813rem; } + .mdc-text-field--dense .mdc-floating-label--float-above { + font-size: .813rem; } + +.mdc-text-field__input:required ~ .mdc-floating-label::after, +.mdc-text-field__input:required ~ .mdc-notched-outline .mdc-floating-label::after { + margin-left: 1px; + content: "*"; } + +.mdc-text-field--textarea { + display: -webkit-inline-box; + display: inline-flex; + width: auto; + height: auto; + -webkit-transition: none; + transition: none; + overflow: visible; } + .mdc-text-field--textarea:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.38); } + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field--textarea:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field--textarea .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; } + .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__leading { + /* @noflip */ + border-radius: 4px 0 0 4px; } + [dir="rtl"] .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__leading, .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__leading[dir="rtl"] { + /* @noflip */ + border-radius: 0 4px 4px 0; } + .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__trailing { + /* @noflip */ + border-radius: 0 4px 4px 0; } + [dir="rtl"] .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__trailing, .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__trailing[dir="rtl"] { + /* @noflip */ + border-radius: 4px 0 0 4px; } + .mdc-text-field--textarea::before, .mdc-text-field--textarea::after { + content: none; } + .mdc-text-field--textarea:not(.mdc-text-field--disabled) { + background-color: transparent; } + .mdc-text-field--textarea .mdc-floating-label--float-above { + -webkit-transform: translateY(-144%) scale(1); + transform: translateY(-144%) scale(1); } + .mdc-text-field--textarea .mdc-floating-label--float-above { + font-size: 0.75rem; } + .mdc-text-field--textarea.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--textarea .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-130%) scale(0.75); + transform: translateY(-130%) scale(0.75); } + .mdc-text-field--textarea.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--textarea .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + .mdc-text-field--textarea .mdc-text-field-character-counter { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; + position: absolute; + bottom: 13px; } + [dir="rtl"] .mdc-text-field--textarea .mdc-text-field-character-counter, .mdc-text-field--textarea .mdc-text-field-character-counter[dir="rtl"] { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + .mdc-text-field--textarea .mdc-text-field__input { + align-self: auto; + box-sizing: border-box; + height: auto; + margin: 8px 1px 1px 0; + padding: 0 16px 16px; + border: none; } + .mdc-text-field--textarea .mdc-text-field-character-counter + .mdc-text-field__input { + margin-bottom: 28px; + padding-bottom: 0; } + .mdc-text-field--textarea .mdc-floating-label { + top: 17px; + bottom: auto; + width: auto; + pointer-events: none; } + .mdc-text-field--textarea.mdc-text-field--focused .mdc-notched-outline__leading, + .mdc-text-field--textarea.mdc-text-field--focused .mdc-notched-outline__notch, + .mdc-text-field--textarea.mdc-text-field--focused .mdc-notched-outline__trailing { + border-width: 2px; } + +.mdc-text-field--fullwidth { + width: 100%; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea) { + display: block; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea)::before, .mdc-text-field--fullwidth:not(.mdc-text-field--textarea)::after { + content: none; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea):not(.mdc-text-field--disabled) { + background-color: transparent; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea) .mdc-text-field__input { + padding: 0; } + .mdc-text-field--fullwidth.mdc-text-field--textarea .mdc-text-field__input { + resize: vertical; } + +.mdc-text-field--fullwidth.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--textarea) { + border-bottom-color: #b00020; + /* @alternate */ + border-bottom-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field-helper-line { + display: -webkit-box; + display: flex; + -webkit-box-pack: justify; + justify-content: space-between; + box-sizing: border-box; } + .mdc-text-field--dense + .mdc-text-field-helper-line { + margin-bottom: 4px; } + .mdc-text-field + .mdc-text-field-helper-line { + padding-right: 16px; + padding-left: 16px; } + +.mdc-form-field > .mdc-text-field + label { + align-self: flex-start; } + +.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-floating-label { + color: rgba(252, 184, 171, 0.87); } + +.mdc-text-field--focused .mdc-text-field__input:required ~ .mdc-floating-label::after, +.mdc-text-field--focused .mdc-text-field__input:required ~ .mdc-notched-outline .mdc-floating-label::after { + color: rgba(252, 184, 171, 0.87); } + +.mdc-text-field--focused + .mdc-text-field-helper-line .mdc-text-field-helper-text:not(.mdc-text-field-helper-text--validation-msg) { + opacity: 1; } + +.mdc-text-field--textarea.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input { + border-bottom-color: #b00020; + /* @alternate */ + border-bottom-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input:hover { + border-bottom-color: #b00020; + /* @alternate */ + border-bottom-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-line-ripple { + background-color: #b00020; + /* @alternate */ + background-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-floating-label { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--invalid + .mdc-text-field-helper-line .mdc-text-field-helper-text--validation-msg { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid .mdc-text-field__input { + caret-color: #b00020; + /* @alternate */ + caret-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-text-field__input:required ~ .mdc-floating-label::after, +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-text-field__input:required ~ .mdc-notched-outline .mdc-floating-label::after { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid.mdc-text-field--with-trailing-icon:not(.mdc-text-field--with-leading-icon):not(.mdc-text-field--disabled) .mdc-text-field__icon { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid.mdc-text-field--with-trailing-icon.mdc-text-field--with-leading-icon:not(.mdc-text-field--disabled) .mdc-text-field__icon ~ .mdc-text-field__icon { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid + .mdc-text-field-helper-line .mdc-text-field-helper-text--validation-msg { + opacity: 1; } + +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--disabled { + background-color: #fafafa; + border-bottom: none; + pointer-events: none; } + .mdc-text-field--disabled .mdc-text-field__input { + border-bottom-color: rgba(0, 0, 0, 0.06); } + .mdc-text-field--disabled .mdc-text-field__input { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled .mdc-floating-label { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled + .mdc-text-field-helper-line .mdc-text-field-helper-text { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled .mdc-text-field-character-counter, + .mdc-text-field--disabled + .mdc-text-field-helper-line .mdc-text-field-character-counter { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled .mdc-text-field__icon { + color: rgba(0, 0, 0, 0.3); } + .mdc-text-field--disabled:not(.mdc-text-field--textarea) { + border-bottom-color: rgba(0, 0, 0, 0.12); } + .mdc-text-field--disabled .mdc-floating-label { + cursor: default; } + +.mdc-text-field--textarea.mdc-text-field--disabled { + background-color: transparent; + /* @alternate */ + background-color: #f9f9f9; } + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-notched-outline__leading, + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-notched-outline__notch, + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.06); } + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-text-field__input { + border-bottom: none; } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense { + 0% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense { + 0% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl { + 0% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl { + 0% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-textarea { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-textarea { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +/** + * Copyright 2019 Mashiro + * @description header + * @author Mashiro + * @license MIT + */ +.mdc-top-app-bar { + background-color: #fcb8ab; + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); + color: rgba(0, 0, 0, 0.87); + display: -webkit-box; + display: flex; + position: fixed; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-direction: column; + -webkit-box-pack: justify; + justify-content: space-between; + box-sizing: border-box; + width: 100%; + z-index: 4; } + .mdc-top-app-bar .mdc-top-app-bar__action-item, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon { + color: #442b2d; + /* @alternate */ + color: var(--mdc-theme-on-primary, #442b2d); } + .mdc-top-app-bar .mdc-top-app-bar__action-item::before, .mdc-top-app-bar .mdc-top-app-bar__action-item::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::after { + background-color: #442b2d; } + @supports not (-ms-ime-align: auto) { + .mdc-top-app-bar .mdc-top-app-bar__action-item::before, .mdc-top-app-bar .mdc-top-app-bar__action-item::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::after { + /* @alternate */ + background-color: var(--mdc-theme-on-primary, #442b2d); } } + .mdc-top-app-bar .mdc-top-app-bar__action-item:hover::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:hover::before { + opacity: 0.04; } + .mdc-top-app-bar .mdc-top-app-bar__action-item:not(.mdc-ripple-upgraded):focus::before, .mdc-top-app-bar .mdc-top-app-bar__action-item.mdc-ripple-upgraded--background-focused::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:not(.mdc-ripple-upgraded):focus::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-top-app-bar .mdc-top-app-bar__action-item:not(.mdc-ripple-upgraded)::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-top-app-bar .mdc-top-app-bar__action-item:not(.mdc-ripple-upgraded):active::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-top-app-bar .mdc-top-app-bar__action-item.mdc-ripple-upgraded, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + .mdc-top-app-bar__row { + display: -webkit-box; + display: flex; + position: relative; + box-sizing: border-box; + width: 100%; + height: 64px; } + .mdc-top-app-bar__section { + display: -webkit-inline-box; + display: inline-flex; + -webkit-box-flex: 1; + flex: 1 1 auto; + -webkit-box-align: center; + align-items: center; + min-width: 0; + padding: 8px 12px; + z-index: 1; } + .mdc-top-app-bar__section--align-start { + -webkit-box-pack: start; + justify-content: flex-start; + -webkit-box-ordinal-group: 0; + order: -1; } + .mdc-top-app-bar__section--align-end { + -webkit-box-pack: end; + justify-content: flex-end; + -webkit-box-ordinal-group: 2; + order: 1; } + .mdc-top-app-bar__title { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1.25rem; + line-height: 2rem; + font-weight: 500; + letter-spacing: 0.0125em; + text-decoration: inherit; + text-transform: inherit; + /* @noflip */ + padding-left: 20px; + /* @noflip */ + padding-right: 0; + text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; + z-index: 1; } + [dir="rtl"] .mdc-top-app-bar__title, .mdc-top-app-bar__title[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 20px; } + +.mdc-top-app-bar--short-collapsed { + /* @noflip */ + border-radius: 0 0 24px 0; } + [dir="rtl"] .mdc-top-app-bar--short-collapsed, .mdc-top-app-bar--short-collapsed[dir="rtl"] { + /* @noflip */ + border-radius: 0 0 0 24px; } + +.mdc-top-app-bar--short { + top: 0; + /* @noflip */ + right: auto; + /* @noflip */ + left: 0; + width: 100%; + -webkit-transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); } + [dir="rtl"] .mdc-top-app-bar--short, .mdc-top-app-bar--short[dir="rtl"] { + /* @noflip */ + right: 0; + /* @noflip */ + left: auto; } + .mdc-top-app-bar--short .mdc-top-app-bar__row { + height: 56px; } + .mdc-top-app-bar--short .mdc-top-app-bar__section { + padding: 4px; } + .mdc-top-app-bar--short .mdc-top-app-bar__title { + -webkit-transition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 1; } + +.mdc-top-app-bar--short-collapsed { + box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12); + width: 56px; + -webkit-transition: width 300ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 300ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__title { + display: none; } + .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__action-item { + -webkit-transition: padding 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: padding 150ms cubic-bezier(0.4, 0, 0.2, 1); } + +.mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item { + width: 112px; } + .mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item .mdc-top-app-bar__section--align-end { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 12px; } + [dir="rtl"] .mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item .mdc-top-app-bar__section--align-end, .mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item .mdc-top-app-bar__section--align-end[dir="rtl"] { + /* @noflip */ + padding-left: 12px; + /* @noflip */ + padding-right: 0; } + +.mdc-top-app-bar--dense .mdc-top-app-bar__row { + height: 48px; } + +.mdc-top-app-bar--dense .mdc-top-app-bar__section { + padding: 0 4px; } + +.mdc-top-app-bar--dense .mdc-top-app-bar__title { + /* @noflip */ + padding-left: 12px; + /* @noflip */ + padding-right: 0; } + [dir="rtl"] .mdc-top-app-bar--dense .mdc-top-app-bar__title, .mdc-top-app-bar--dense .mdc-top-app-bar__title[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 12px; } + +.mdc-top-app-bar--prominent .mdc-top-app-bar__row { + height: 128px; } + +.mdc-top-app-bar--prominent .mdc-top-app-bar__title { + align-self: flex-end; + padding-bottom: 2px; } + +.mdc-top-app-bar--prominent .mdc-top-app-bar__action-item, +.mdc-top-app-bar--prominent .mdc-top-app-bar__navigation-icon { + align-self: flex-start; } + +.mdc-top-app-bar--fixed { + -webkit-transition: box-shadow 200ms linear; + transition: box-shadow 200ms linear; } + +.mdc-top-app-bar--fixed-scrolled { + box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12); + -webkit-transition: box-shadow 200ms linear; + transition: box-shadow 200ms linear; } + +.mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__row { + height: 96px; } + +.mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__section { + padding: 0 12px; } + +.mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__title { + /* @noflip */ + padding-left: 20px; + /* @noflip */ + padding-right: 0; + padding-bottom: 9px; } + [dir="rtl"] .mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__title, .mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__title[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 20px; } + +.mdc-top-app-bar--fixed-adjust { + padding-top: 64px; } + +.mdc-top-app-bar--dense-fixed-adjust { + padding-top: 48px; } + +.mdc-top-app-bar--short-fixed-adjust { + padding-top: 56px; } + +.mdc-top-app-bar--prominent-fixed-adjust { + padding-top: 128px; } + +.mdc-top-app-bar--dense-prominent-fixed-adjust { + padding-top: 96px; } + +@media (max-width: 599px) { + .mdc-top-app-bar__row { + height: 56px; } + .mdc-top-app-bar__section { + padding: 4px; } + .mdc-top-app-bar--short { + -webkit-transition: width 200ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 200ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-top-app-bar--short-collapsed { + -webkit-transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__section--align-end { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 12px; } + [dir="rtl"] .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__section--align-end, .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__section--align-end[dir="rtl"] { + /* @noflip */ + padding-left: 12px; + /* @noflip */ + padding-right: 0; } + .mdc-top-app-bar--prominent .mdc-top-app-bar__title { + padding-bottom: 6px; } + .mdc-top-app-bar--fixed-adjust { + padding-top: 56px; } } + +.mdc-icon-button { + width: 48px; + height: 48px; + padding: 12px; + font-size: 24px; + display: inline-block; + position: relative; + box-sizing: border-box; + border: none; + outline: none; + background-color: transparent; + fill: currentColor; + color: inherit; + text-decoration: none; + cursor: pointer; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; } + .mdc-icon-button svg, + .mdc-icon-button img { + width: 24px; + height: 24px; } + .mdc-icon-button:disabled { + color: rgba(0, 0, 0, 0.38); + /* @alternate */ + color: var(--mdc-theme-text-disabled-on-light, rgba(0, 0, 0, 0.38)); + cursor: default; + pointer-events: none; } + +.mdc-icon-button__icon { + display: inline-block; } + .mdc-icon-button__icon.mdc-icon-button__icon--on { + display: none; } + +.mdc-icon-button--on .mdc-icon-button__icon { + display: none; } + .mdc-icon-button--on .mdc-icon-button__icon.mdc-icon-button__icon--on { + display: inline-block; } + +.mdc-icon-button { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); } + .mdc-icon-button::before, .mdc-icon-button::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-icon-button::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-icon-button.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-icon-button.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-icon-button.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-icon-button.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-icon-button.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-icon-button::before, .mdc-icon-button::after { + top: calc(50% - 50%); + /* @noflip */ + left: calc(50% - 50%); + width: 100%; + height: 100%; } + .mdc-icon-button.mdc-ripple-upgraded::before, .mdc-icon-button.mdc-ripple-upgraded::after { + top: var(--mdc-ripple-top, calc(50% - 50%)); + /* @noflip */ + left: var(--mdc-ripple-left, calc(50% - 50%)); + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-icon-button.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-icon-button::before, .mdc-icon-button::after { + background-color: #000; } + .mdc-icon-button:hover::before { + opacity: 0.04; } + .mdc-icon-button:not(.mdc-ripple-upgraded):focus::before, .mdc-icon-button.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-icon-button:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-icon-button:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-icon-button.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + +/** + * @description homepage cover image + * @author Mashiro + * @since 19/11/1 + */ +.header-top { + position: fixed; + width: 100%; + height: 100%; } + .header-top figure { + width: 100%; + margin: 0; + overflow: hidden; } + +#header-top-after { + width: 100%; } + +/** + * Copyright 2019 Mashiro + * @description site content + * @author Mashiro + * @license MIT + */ +.page-content { + position: relative; + background: white; + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-flow: row nowrap; + -webkit-box-pack: justify; + justify-content: space-between; } + .page-content .main-center { + height: 100%; + width: 800px; + background: #9acd3220; } + .page-content .side-bar-left { + width: 100px; } + .page-content .side-bar-right { + width: 100px; } + +.mdc-card { + border-radius: 4px; + background-color: #fff; + /* @alternate */ + background-color: var(--mdc-theme-surface, #fff); + box-shadow: 0px 2px 1px -1px rgba(0, 0, 0, 0.2), 0px 1px 1px 0px rgba(0, 0, 0, 0.14), 0px 1px 3px 0px rgba(0, 0, 0, 0.12); + display: -webkit-box; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-direction: column; + box-sizing: border-box; } + +.mdc-card--outlined { + box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.2), 0px 0px 0px 0px rgba(0, 0, 0, 0.14), 0px 0px 0px 0px rgba(0, 0, 0, 0.12); + border-width: 1px; + border-style: solid; + border-color: #e0e0e0; } + +.mdc-card__media { + position: relative; + box-sizing: border-box; + background-repeat: no-repeat; + background-position: center; + background-size: cover; } + .mdc-card__media::before { + display: block; + content: ""; } + +.mdc-card__media:first-child { + border-top-left-radius: inherit; + border-top-right-radius: inherit; } + +.mdc-card__media:last-child { + border-bottom-left-radius: inherit; + border-bottom-right-radius: inherit; } + +.mdc-card__media--square::before { + margin-top: 100%; } + +.mdc-card__media--16-9::before { + margin-top: 56.25%; } + +.mdc-card__media-content { + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + box-sizing: border-box; } + +.mdc-card__primary-action { + display: -webkit-box; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-direction: column; + box-sizing: border-box; + position: relative; + outline: none; + color: inherit; + text-decoration: none; + cursor: pointer; + overflow: hidden; } + +.mdc-card__primary-action:first-child { + border-top-left-radius: inherit; + border-top-right-radius: inherit; } + +.mdc-card__primary-action:last-child { + border-bottom-left-radius: inherit; + border-bottom-right-radius: inherit; } + +.mdc-card__actions { + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-direction: row; + -webkit-box-align: center; + align-items: center; + box-sizing: border-box; + min-height: 52px; + padding: 8px; } + +.mdc-card__actions--full-bleed { + padding: 0; } + +.mdc-card__action-buttons, +.mdc-card__action-icons { + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-direction: row; + -webkit-box-align: center; + align-items: center; + box-sizing: border-box; } + +.mdc-card__action-icons { + color: rgba(0, 0, 0, 0.6); + -webkit-box-flex: 1; + flex-grow: 1; + -webkit-box-pack: end; + justify-content: flex-end; } + +.mdc-card__action-buttons + .mdc-card__action-icons { + /* @noflip */ + margin-left: 16px; + /* @noflip */ + margin-right: 0; } + [dir="rtl"] .mdc-card__action-buttons + .mdc-card__action-icons, .mdc-card__action-buttons + .mdc-card__action-icons[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 16px; } + +.mdc-card__action { + display: -webkit-inline-box; + display: inline-flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-direction: row; + -webkit-box-align: center; + align-items: center; + box-sizing: border-box; + -webkit-box-pack: center; + justify-content: center; + cursor: pointer; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; } + .mdc-card__action:focus { + outline: none; } + +.mdc-card__action--button { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 8px; + padding: 0 8px; } + [dir="rtl"] .mdc-card__action--button, .mdc-card__action--button[dir="rtl"] { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: 0; } + .mdc-card__action--button:last-child { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 0; } + [dir="rtl"] .mdc-card__action--button:last-child, .mdc-card__action--button:last-child[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 0; } + +.mdc-card__actions--full-bleed .mdc-card__action--button { + -webkit-box-pack: justify; + justify-content: space-between; + width: 100%; + height: auto; + max-height: none; + margin: 0; + padding: 8px 16px; + /* @noflip */ + text-align: left; } + [dir="rtl"] .mdc-card__actions--full-bleed .mdc-card__action--button, .mdc-card__actions--full-bleed .mdc-card__action--button[dir="rtl"] { + /* @noflip */ + text-align: right; } + +.mdc-card__action--icon { + margin: -6px 0; + padding: 12px; } + +.mdc-card__action--icon:not(:disabled) { + color: rgba(0, 0, 0, 0.6); } + +.mdc-card__primary-action { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); } + .mdc-card__primary-action::before, .mdc-card__primary-action::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-card__primary-action::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-card__primary-action.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-card__primary-action.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-card__primary-action.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-card__primary-action.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-card__primary-action.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-card__primary-action::before, .mdc-card__primary-action::after { + top: calc(50% - 100%); + /* @noflip */ + left: calc(50% - 100%); + width: 200%; + height: 200%; } + .mdc-card__primary-action.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-card__primary-action::before, .mdc-card__primary-action::after { + background-color: #000; } + .mdc-card__primary-action:hover::before { + opacity: 0.04; } + .mdc-card__primary-action:not(.mdc-ripple-upgraded):focus::before, .mdc-card__primary-action.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-card__primary-action:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-card__primary-action:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-card__primary-action.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + +.mdc-button { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 2.25rem; + font-weight: 500; + letter-spacing: 0.08929em; + text-decoration: none; + text-transform: uppercase; + padding: 0 8px 0 8px; + display: -webkit-inline-box; + display: inline-flex; + position: relative; + -webkit-box-align: center; + align-items: center; + -webkit-box-pack: center; + justify-content: center; + box-sizing: border-box; + min-width: 64px; + height: 36px; + border: none; + outline: none; + /* @alternate */ + line-height: inherit; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + -webkit-appearance: none; + overflow: hidden; + vertical-align: middle; + border-radius: 4px; } + .mdc-button::-moz-focus-inner { + padding: 0; + border: 0; } + .mdc-button:active { + outline: none; } + .mdc-button:hover { + cursor: pointer; } + .mdc-button:disabled { + background-color: transparent; + color: rgba(0, 0, 0, 0.37); + cursor: default; + pointer-events: none; } + .mdc-button.mdc-button--dense { + border-radius: 4px; } + .mdc-button:not(:disabled) { + background-color: transparent; } + .mdc-button .mdc-button__icon { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 8px; + display: inline-block; + width: 18px; + height: 18px; + font-size: 18px; + vertical-align: top; } + [dir="rtl"] .mdc-button .mdc-button__icon, .mdc-button .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: 0; } + .mdc-button:not(:disabled) { + color: #fcb8ab; + /* @alternate */ + color: var(--mdc-theme-primary, #fcb8ab); } + +.mdc-button__label + .mdc-button__icon { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: 0; } + [dir="rtl"] .mdc-button__label + .mdc-button__icon, .mdc-button__label + .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 8px; } + +svg.mdc-button__icon { + fill: currentColor; } + +.mdc-button--raised .mdc-button__icon, +.mdc-button--unelevated .mdc-button__icon, +.mdc-button--outlined .mdc-button__icon { + /* @noflip */ + margin-left: -4px; + /* @noflip */ + margin-right: 8px; } + [dir="rtl"] .mdc-button--raised .mdc-button__icon, .mdc-button--raised .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--unelevated .mdc-button__icon, + .mdc-button--unelevated .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--outlined .mdc-button__icon, + .mdc-button--outlined .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: -4px; } + +.mdc-button--raised .mdc-button__label + .mdc-button__icon, +.mdc-button--unelevated .mdc-button__label + .mdc-button__icon, +.mdc-button--outlined .mdc-button__label + .mdc-button__icon { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: -4px; } + [dir="rtl"] .mdc-button--raised .mdc-button__label + .mdc-button__icon, .mdc-button--raised .mdc-button__label + .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--unelevated .mdc-button__label + .mdc-button__icon, + .mdc-button--unelevated .mdc-button__label + .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--outlined .mdc-button__label + .mdc-button__icon, + .mdc-button--outlined .mdc-button__label + .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: -4px; + /* @noflip */ + margin-right: 8px; } + +.mdc-button--raised, +.mdc-button--unelevated { + padding: 0 16px 0 16px; } + .mdc-button--raised:disabled, + .mdc-button--unelevated:disabled { + background-color: rgba(0, 0, 0, 0.12); + color: rgba(0, 0, 0, 0.37); } + .mdc-button--raised:not(:disabled), + .mdc-button--unelevated:not(:disabled) { + background-color: #fcb8ab; } + @supports not (-ms-ime-align: auto) { + .mdc-button--raised:not(:disabled), + .mdc-button--unelevated:not(:disabled) { + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); } } + .mdc-button--raised:not(:disabled), + .mdc-button--unelevated:not(:disabled) { + color: #442b2d; + /* @alternate */ + color: var(--mdc-theme-on-primary, #442b2d); } + +.mdc-button--raised { + box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12); + -webkit-transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1); + transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-button--raised:hover, .mdc-button--raised:focus { + box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12); } + .mdc-button--raised:active { + box-shadow: 0px 5px 5px -3px rgba(0, 0, 0, 0.2), 0px 8px 10px 1px rgba(0, 0, 0, 0.14), 0px 3px 14px 2px rgba(0, 0, 0, 0.12); } + .mdc-button--raised:disabled { + box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.2), 0px 0px 0px 0px rgba(0, 0, 0, 0.14), 0px 0px 0px 0px rgba(0, 0, 0, 0.12); } + +.mdc-button--outlined { + border-style: solid; + padding: 0 15px 0 15px; + border-width: 1px; } + .mdc-button--outlined:disabled { + border-color: rgba(0, 0, 0, 0.37); } + .mdc-button--outlined:not(:disabled) { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + +.mdc-button--dense { + height: 32px; + font-size: .8125rem; } + +.mdc-button { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); } + .mdc-button::before, .mdc-button::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-button::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-button.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-button.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-button.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-button.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-button.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-button::before, .mdc-button::after { + top: calc(50% - 100%); + /* @noflip */ + left: calc(50% - 100%); + width: 200%; + height: 200%; } + .mdc-button.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-button::before, .mdc-button::after { + background-color: #fcb8ab; } + @supports not (-ms-ime-align: auto) { + .mdc-button::before, .mdc-button::after { + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); } } + .mdc-button:hover::before { + opacity: 0.08; } + .mdc-button:not(.mdc-ripple-upgraded):focus::before, .mdc-button.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.24; } + .mdc-button:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-button:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.24; } + .mdc-button.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.24; } + +.mdc-button--raised::before, .mdc-button--raised::after, +.mdc-button--unelevated::before, +.mdc-button--unelevated::after { + background-color: #442b2d; } + @supports not (-ms-ime-align: auto) { + .mdc-button--raised::before, .mdc-button--raised::after, + .mdc-button--unelevated::before, + .mdc-button--unelevated::after { + /* @alternate */ + background-color: var(--mdc-theme-on-primary, #442b2d); } } + +.mdc-button--raised:hover::before, +.mdc-button--unelevated:hover::before { + opacity: 0.04; } + +.mdc-button--raised:not(.mdc-ripple-upgraded):focus::before, .mdc-button--raised.mdc-ripple-upgraded--background-focused::before, +.mdc-button--unelevated:not(.mdc-ripple-upgraded):focus::before, +.mdc-button--unelevated.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + +.mdc-button--raised:not(.mdc-ripple-upgraded)::after, +.mdc-button--unelevated:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + +.mdc-button--raised:not(.mdc-ripple-upgraded):active::after, +.mdc-button--unelevated:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + +.mdc-button--raised.mdc-ripple-upgraded, +.mdc-button--unelevated.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + +.mdc-typography { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; } + +.mdc-typography--headline1 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 6rem; + line-height: 6rem; + font-weight: 300; + letter-spacing: -0.01563em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline2 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 3.75rem; + line-height: 3.75rem; + font-weight: 300; + letter-spacing: -0.00833em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline3 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 3rem; + line-height: 3.125rem; + font-weight: 400; + letter-spacing: normal; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline4 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 2.125rem; + line-height: 2.5rem; + font-weight: 400; + letter-spacing: 0.00735em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline5 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1.5rem; + line-height: 2rem; + font-weight: 400; + letter-spacing: normal; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline6 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1.25rem; + line-height: 2rem; + font-weight: 500; + letter-spacing: 0.0125em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--subtitle1 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.75rem; + font-weight: 400; + letter-spacing: 0.00937em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--subtitle2 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 1.375rem; + font-weight: 500; + letter-spacing: 0.00714em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--body1 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.5rem; + font-weight: 400; + letter-spacing: 0.03125em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--body2 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.01786em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--caption { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.03333em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--button { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 2.25rem; + font-weight: 500; + letter-spacing: 0.08929em; + text-decoration: none; + text-transform: uppercase; } + +.mdc-typography--overline { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 2rem; + font-weight: 500; + letter-spacing: 0.16667em; + text-decoration: none; + text-transform: uppercase; } + +.post-thumb-item { + height: 300px; + margin: 10px; } + .post-thumb-item .primary-action { + height: 100%; } + .post-thumb-item .primary-action .content { + height: 100%; + width: 100%; + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-flow: row nowrap; + -webkit-box-pack: justify; + justify-content: space-between; } + .post-thumb-item .primary-action .content .post-info { + width: 45%; + height: 100%; + display: -webkit-box; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-flow: column nowrap; + -webkit-box-pack: justify; + justify-content: space-between; } + .post-thumb-item .primary-action .content .post-info .text { + margin: 30px; } + .post-thumb-item .primary-action .content .post-info .text .post-title { + margin: 0; + color: #504e4e; } + .post-thumb-item .primary-action .content .post-info .text .post-date, + .post-thumb-item .primary-action .content .post-info .text .post-meta { + margin: 0; + color: #888; + font-size: 12px; } + .post-thumb-item .primary-action .content .post-info .text .post-date i, + .post-thumb-item .primary-action .content .post-info .text .post-meta i { + font-size: 12px; } + .post-thumb-item .primary-action .content .post-info .text .post-abstract { + margin: 20px 0; + color: #888; } + .post-thumb-item .primary-action .content .post-info .btn--align-left { + margin: auto auto 30px 30px; } + .post-thumb-item .primary-action .content .post-info .btn--align-right { + margin: auto 30px 30px auto; } + .post-thumb-item .primary-action .content .post-thumb { + width: 55%; + overflow: hidden; } + .post-thumb-item .primary-action .content .post-thumb .thumb-img-box { + height: 100%; + width: 100%; } + .post-thumb-item .primary-action .content .post-thumb .thumb-img-box img { + width: 100%; + height: 100%; + -o-object-fit: cover; + object-fit: cover; + -webkit-transition: all .6s; + transition: all .6s; } + .post-thumb-item .primary-action .content .post-thumb .thumb-img-box img:hover { + -webkit-transform: scale(1.1); + transform: scale(1.1); } diff --git a/dist/bundle.js b/dist/bundle.js new file mode 100644 index 0000000..4df994e --- /dev/null +++ b/dist/bundle.js @@ -0,0 +1,6320 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 0); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./node_modules/@material/base/component.js": +/*!**************************************************!*\ + !*** ./node_modules/@material/base/component.js ***! + \**************************************************/ +/*! exports provided: MDCComponent, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCComponent", function() { return MDCComponent; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/base/foundation.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + +var MDCComponent = /** @class */ (function () { + function MDCComponent(root, foundation) { + var args = []; + for (var _i = 2; _i < arguments.length; _i++) { + args[_i - 2] = arguments[_i]; + } + this.root_ = root; + this.initialize.apply(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__spread"](args)); + // Note that we initialize foundation here and not within the constructor's default param so that + // this.root_ is defined and can be used within the foundation class. + this.foundation_ = foundation === undefined ? this.getDefaultFoundation() : foundation; + this.foundation_.init(); + this.initialSyncWithDOM(); + } + MDCComponent.attachTo = function (root) { + // Subclasses which extend MDCBase should provide an attachTo() method that takes a root element and + // returns an instantiated component with its root set to that element. Also note that in the cases of + // subclasses, an explicit foundation class will not have to be passed in; it will simply be initialized + // from getDefaultFoundation(). + return new MDCComponent(root, new _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"]({})); + }; + /* istanbul ignore next: method param only exists for typing purposes; it does not need to be unit tested */ + MDCComponent.prototype.initialize = function () { + var _args = []; + for (var _i = 0; _i < arguments.length; _i++) { + _args[_i] = arguments[_i]; + } + // Subclasses can override this to do any additional setup work that would be considered part of a + // "constructor". Essentially, it is a hook into the parent constructor before the foundation is + // initialized. Any additional arguments besides root and foundation will be passed in here. + }; + MDCComponent.prototype.getDefaultFoundation = function () { + // Subclasses must override this method to return a properly configured foundation class for the + // component. + throw new Error('Subclasses must override getDefaultFoundation to return a properly configured ' + + 'foundation class'); + }; + MDCComponent.prototype.initialSyncWithDOM = function () { + // Subclasses should override this method if they need to perform work to synchronize with a host DOM + // object. An example of this would be a form control wrapper that needs to synchronize its internal state + // to some property or attribute of the host DOM. Please note: this is *not* the place to perform DOM + // reads/writes that would cause layout / paint, as this is called synchronously from within the constructor. + }; + MDCComponent.prototype.destroy = function () { + // Subclasses may implement this method to release any resources / deregister any listeners they have + // attached. An example of this might be deregistering a resize event from the window object. + this.foundation_.destroy(); + }; + MDCComponent.prototype.listen = function (evtType, handler, options) { + this.root_.addEventListener(evtType, handler, options); + }; + MDCComponent.prototype.unlisten = function (evtType, handler, options) { + this.root_.removeEventListener(evtType, handler, options); + }; + /** + * Fires a cross-browser-compatible custom event from the component root of the given type, with the given data. + */ + MDCComponent.prototype.emit = function (evtType, evtData, shouldBubble) { + if (shouldBubble === void 0) { shouldBubble = false; } + var evt; + if (typeof CustomEvent === 'function') { + evt = new CustomEvent(evtType, { + bubbles: shouldBubble, + detail: evtData, + }); + } + else { + evt = document.createEvent('CustomEvent'); + evt.initCustomEvent(evtType, shouldBubble, false, evtData); + } + this.root_.dispatchEvent(evt); + }; + return MDCComponent; +}()); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCComponent); +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/base/foundation.js": +/*!***************************************************!*\ + !*** ./node_modules/@material/base/foundation.js ***! + \***************************************************/ +/*! exports provided: MDCFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFoundation", function() { return MDCFoundation; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var MDCFoundation = /** @class */ (function () { + function MDCFoundation(adapter) { + if (adapter === void 0) { adapter = {}; } + this.adapter_ = adapter; + } + Object.defineProperty(MDCFoundation, "cssClasses", { + get: function () { + // Classes extending MDCFoundation should implement this method to return an object which exports every + // CSS class the foundation class needs as a property. e.g. {ACTIVE: 'mdc-component--active'} + return {}; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFoundation, "strings", { + get: function () { + // Classes extending MDCFoundation should implement this method to return an object which exports all + // semantic strings as constants. e.g. {ARIA_ROLE: 'tablist'} + return {}; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFoundation, "numbers", { + get: function () { + // Classes extending MDCFoundation should implement this method to return an object which exports all + // of its semantic numbers as constants. e.g. {ANIMATION_DELAY_MS: 350} + return {}; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFoundation, "defaultAdapter", { + get: function () { + // Classes extending MDCFoundation may choose to implement this getter in order to provide a convenient + // way of viewing the necessary methods of an adapter. In the future, this could also be used for adapter + // validation. + return {}; + }, + enumerable: true, + configurable: true + }); + MDCFoundation.prototype.init = function () { + // Subclasses should override this method to perform initialization routines (registering events, etc.) + }; + MDCFoundation.prototype.destroy = function () { + // Subclasses should override this method to perform de-initialization routines (de-registering events, etc.) + }; + return MDCFoundation; +}()); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/dom/events.js": +/*!**********************************************!*\ + !*** ./node_modules/@material/dom/events.js ***! + \**********************************************/ +/*! exports provided: applyPassive */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "applyPassive", function() { return applyPassive; }); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +/** + * Stores result from applyPassive to avoid redundant processing to detect + * passive event listener support. + */ +var supportsPassive_; +/** + * Determine whether the current browser supports passive event listeners, and + * if so, use them. + */ +function applyPassive(globalObj, forceRefresh) { + if (globalObj === void 0) { globalObj = window; } + if (forceRefresh === void 0) { forceRefresh = false; } + if (supportsPassive_ === undefined || forceRefresh) { + var isSupported_1 = false; + try { + globalObj.document.addEventListener('test', function () { return undefined; }, { + get passive() { + isSupported_1 = true; + return isSupported_1; + }, + }); + } + catch (e) { + } // tslint:disable-line:no-empty cannot throw error due to tests. tslint also disables console.log. + supportsPassive_ = isSupported_1; + } + return supportsPassive_ ? { passive: true } : false; +} +//# sourceMappingURL=events.js.map + +/***/ }), + +/***/ "./node_modules/@material/dom/ponyfill.js": +/*!************************************************!*\ + !*** ./node_modules/@material/dom/ponyfill.js ***! + \************************************************/ +/*! exports provided: closest, matches */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "closest", function() { return closest; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "matches", function() { return matches; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +/** + * @fileoverview A "ponyfill" is a polyfill that doesn't modify the global prototype chain. + * This makes ponyfills safer than traditional polyfills, especially for libraries like MDC. + */ +function closest(element, selector) { + if (element.closest) { + return element.closest(selector); + } + var el = element; + while (el) { + if (matches(el, selector)) { + return el; + } + el = el.parentElement; + } + return null; +} +function matches(element, selector) { + var nativeMatches = element.matches + || element.webkitMatchesSelector + || element.msMatchesSelector; + return nativeMatches.call(element, selector); +} +//# sourceMappingURL=ponyfill.js.map + +/***/ }), + +/***/ "./node_modules/@material/floating-label/component.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/floating-label/component.js ***! + \************************************************************/ +/*! exports provided: MDCFloatingLabel */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFloatingLabel", function() { return MDCFloatingLabel; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/floating-label/foundation.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCFloatingLabel = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCFloatingLabel, _super); + function MDCFloatingLabel() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCFloatingLabel.attachTo = function (root) { + return new MDCFloatingLabel(root); + }; + /** + * Styles the label to produce the label shake for errors. + * @param shouldShake If true, shakes the label by adding a CSS class; otherwise, stops shaking by removing the class. + */ + MDCFloatingLabel.prototype.shake = function (shouldShake) { + this.foundation_.shake(shouldShake); + }; + /** + * Styles the label to float/dock. + * @param shouldFloat If true, floats the label by adding a CSS class; otherwise, docks it by removing the class. + */ + MDCFloatingLabel.prototype.float = function (shouldFloat) { + this.foundation_.float(shouldFloat); + }; + MDCFloatingLabel.prototype.getWidth = function () { + return this.foundation_.getWidth(); + }; + MDCFloatingLabel.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + getWidth: function () { return _this.root_.scrollWidth; }, + registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCFloatingLabelFoundation"](adapter); + }; + return MDCFloatingLabel; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/floating-label/constants.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/floating-label/constants.js ***! + \************************************************************/ +/*! exports provided: cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + LABEL_FLOAT_ABOVE: 'mdc-floating-label--float-above', + LABEL_SHAKE: 'mdc-floating-label--shake', + ROOT: 'mdc-floating-label', +}; +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/floating-label/foundation.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/floating-label/foundation.js ***! + \*************************************************************/ +/*! exports provided: MDCFloatingLabelFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFloatingLabelFoundation", function() { return MDCFloatingLabelFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/floating-label/constants.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCFloatingLabelFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCFloatingLabelFoundation, _super); + function MDCFloatingLabelFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCFloatingLabelFoundation.defaultAdapter, adapter)) || this; + _this.shakeAnimationEndHandler_ = function () { return _this.handleShakeAnimationEnd_(); }; + return _this; + } + Object.defineProperty(MDCFloatingLabelFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFloatingLabelFoundation, "defaultAdapter", { + /** + * See {@link MDCFloatingLabelAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + getWidth: function () { return 0; }, + registerInteractionHandler: function () { return undefined; }, + deregisterInteractionHandler: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCFloatingLabelFoundation.prototype.init = function () { + this.adapter_.registerInteractionHandler('animationend', this.shakeAnimationEndHandler_); + }; + MDCFloatingLabelFoundation.prototype.destroy = function () { + this.adapter_.deregisterInteractionHandler('animationend', this.shakeAnimationEndHandler_); + }; + /** + * Returns the width of the label element. + */ + MDCFloatingLabelFoundation.prototype.getWidth = function () { + return this.adapter_.getWidth(); + }; + /** + * Styles the label to produce a shake animation to indicate an error. + * @param shouldShake If true, adds the shake CSS class; otherwise, removes shake class. + */ + MDCFloatingLabelFoundation.prototype.shake = function (shouldShake) { + var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE; + if (shouldShake) { + this.adapter_.addClass(LABEL_SHAKE); + } + else { + this.adapter_.removeClass(LABEL_SHAKE); + } + }; + /** + * Styles the label to float or dock. + * @param shouldFloat If true, adds the float CSS class; otherwise, removes float and shake classes to dock the label. + */ + MDCFloatingLabelFoundation.prototype.float = function (shouldFloat) { + var _a = MDCFloatingLabelFoundation.cssClasses, LABEL_FLOAT_ABOVE = _a.LABEL_FLOAT_ABOVE, LABEL_SHAKE = _a.LABEL_SHAKE; + if (shouldFloat) { + this.adapter_.addClass(LABEL_FLOAT_ABOVE); + } + else { + this.adapter_.removeClass(LABEL_FLOAT_ABOVE); + this.adapter_.removeClass(LABEL_SHAKE); + } + }; + MDCFloatingLabelFoundation.prototype.handleShakeAnimationEnd_ = function () { + var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE; + this.adapter_.removeClass(LABEL_SHAKE); + }; + return MDCFloatingLabelFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCFloatingLabelFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/line-ripple/component.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/line-ripple/component.js ***! + \*********************************************************/ +/*! exports provided: MDCLineRipple */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCLineRipple", function() { return MDCLineRipple; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/line-ripple/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCLineRipple = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCLineRipple, _super); + function MDCLineRipple() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCLineRipple.attachTo = function (root) { + return new MDCLineRipple(root); + }; + /** + * Activates the line ripple + */ + MDCLineRipple.prototype.activate = function () { + this.foundation_.activate(); + }; + /** + * Deactivates the line ripple + */ + MDCLineRipple.prototype.deactivate = function () { + this.foundation_.deactivate(); + }; + /** + * Sets the transform origin given a user's click location. + * The `rippleCenter` is the x-coordinate of the middle of the ripple. + */ + MDCLineRipple.prototype.setRippleCenter = function (xCoordinate) { + this.foundation_.setRippleCenter(xCoordinate); + }; + MDCLineRipple.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + hasClass: function (className) { return _this.root_.classList.contains(className); }, + setStyle: function (propertyName, value) { return _this.root_.style.setProperty(propertyName, value); }, + registerEventHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterEventHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCLineRippleFoundation"](adapter); + }; + return MDCLineRipple; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/line-ripple/constants.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/line-ripple/constants.js ***! + \*********************************************************/ +/*! exports provided: cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + LINE_RIPPLE_ACTIVE: 'mdc-line-ripple--active', + LINE_RIPPLE_DEACTIVATING: 'mdc-line-ripple--deactivating', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/line-ripple/foundation.js": +/*!**********************************************************!*\ + !*** ./node_modules/@material/line-ripple/foundation.js ***! + \**********************************************************/ +/*! exports provided: MDCLineRippleFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCLineRippleFoundation", function() { return MDCLineRippleFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/line-ripple/constants.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCLineRippleFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCLineRippleFoundation, _super); + function MDCLineRippleFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCLineRippleFoundation.defaultAdapter, adapter)) || this; + _this.transitionEndHandler_ = function (evt) { return _this.handleTransitionEnd(evt); }; + return _this; + } + Object.defineProperty(MDCLineRippleFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCLineRippleFoundation, "defaultAdapter", { + /** + * See {@link MDCLineRippleAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return false; }, + setStyle: function () { return undefined; }, + registerEventHandler: function () { return undefined; }, + deregisterEventHandler: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCLineRippleFoundation.prototype.init = function () { + this.adapter_.registerEventHandler('transitionend', this.transitionEndHandler_); + }; + MDCLineRippleFoundation.prototype.destroy = function () { + this.adapter_.deregisterEventHandler('transitionend', this.transitionEndHandler_); + }; + MDCLineRippleFoundation.prototype.activate = function () { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_ACTIVE); + }; + MDCLineRippleFoundation.prototype.setRippleCenter = function (xCoordinate) { + this.adapter_.setStyle('transform-origin', xCoordinate + "px center"); + }; + MDCLineRippleFoundation.prototype.deactivate = function () { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + }; + MDCLineRippleFoundation.prototype.handleTransitionEnd = function (evt) { + // Wait for the line ripple to be either transparent or opaque + // before emitting the animation end event + var isDeactivating = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + if (evt.propertyName === 'opacity') { + if (isDeactivating) { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_ACTIVE); + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + } + } + }; + return MDCLineRippleFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCLineRippleFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/notched-outline/component.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/notched-outline/component.js ***! + \*************************************************************/ +/*! exports provided: MDCNotchedOutline */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCNotchedOutline", function() { return MDCNotchedOutline; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_floating_label_foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/floating-label/foundation */ "./node_modules/@material/floating-label/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/notched-outline/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/notched-outline/foundation.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + +var MDCNotchedOutline = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCNotchedOutline, _super); + function MDCNotchedOutline() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCNotchedOutline.attachTo = function (root) { + return new MDCNotchedOutline(root); + }; + MDCNotchedOutline.prototype.initialSyncWithDOM = function () { + this.notchElement_ = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].NOTCH_ELEMENT_SELECTOR); + var label = this.root_.querySelector('.' + _material_floating_label_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCFloatingLabelFoundation"].cssClasses.ROOT); + if (label) { + label.style.transitionDuration = '0s'; + this.root_.classList.add(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].OUTLINE_UPGRADED); + requestAnimationFrame(function () { + label.style.transitionDuration = ''; + }); + } + else { + this.root_.classList.add(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].NO_LABEL); + } + }; + /** + * Updates classes and styles to open the notch to the specified width. + * @param notchWidth The notch width in the outline. + */ + MDCNotchedOutline.prototype.notch = function (notchWidth) { + this.foundation_.notch(notchWidth); + }; + /** + * Updates classes and styles to close the notch. + */ + MDCNotchedOutline.prototype.closeNotch = function () { + this.foundation_.closeNotch(); + }; + MDCNotchedOutline.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + setNotchWidthProperty: function (width) { return _this.notchElement_.style.setProperty('width', width + 'px'); }, + removeNotchWidthProperty: function () { return _this.notchElement_.style.removeProperty('width'); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_4__["MDCNotchedOutlineFoundation"](adapter); + }; + return MDCNotchedOutline; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/notched-outline/constants.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/notched-outline/constants.js ***! + \*************************************************************/ +/*! exports provided: cssClasses, numbers, strings */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var strings = { + NOTCH_ELEMENT_SELECTOR: '.mdc-notched-outline__notch', +}; +var numbers = { + // This should stay in sync with $mdc-notched-outline-padding * 2. + NOTCH_ELEMENT_PADDING: 8, +}; +var cssClasses = { + NO_LABEL: 'mdc-notched-outline--no-label', + OUTLINE_NOTCHED: 'mdc-notched-outline--notched', + OUTLINE_UPGRADED: 'mdc-notched-outline--upgraded', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/notched-outline/foundation.js": +/*!**************************************************************!*\ + !*** ./node_modules/@material/notched-outline/foundation.js ***! + \**************************************************************/ +/*! exports provided: MDCNotchedOutlineFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCNotchedOutlineFoundation", function() { return MDCNotchedOutlineFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/notched-outline/constants.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCNotchedOutlineFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCNotchedOutlineFoundation, _super); + function MDCNotchedOutlineFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCNotchedOutlineFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCNotchedOutlineFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCNotchedOutlineFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCNotchedOutlineFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCNotchedOutlineFoundation, "defaultAdapter", { + /** + * See {@link MDCNotchedOutlineAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + setNotchWidthProperty: function () { return undefined; }, + removeNotchWidthProperty: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + /** + * Adds the outline notched selector and updates the notch width calculated based off of notchWidth. + */ + MDCNotchedOutlineFoundation.prototype.notch = function (notchWidth) { + var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED; + if (notchWidth > 0) { + notchWidth += _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].NOTCH_ELEMENT_PADDING; // Add padding from left/right. + } + this.adapter_.setNotchWidthProperty(notchWidth); + this.adapter_.addClass(OUTLINE_NOTCHED); + }; + /** + * Removes notched outline selector to close the notch in the outline. + */ + MDCNotchedOutlineFoundation.prototype.closeNotch = function () { + var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED; + this.adapter_.removeClass(OUTLINE_NOTCHED); + this.adapter_.removeNotchWidthProperty(); + }; + return MDCNotchedOutlineFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCNotchedOutlineFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/component.js": +/*!****************************************************!*\ + !*** ./node_modules/@material/ripple/component.js ***! + \****************************************************/ +/*! exports provided: MDCRipple */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCRipple", function() { return MDCRipple; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_dom_events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/dom/events */ "./node_modules/@material/dom/events.js"); +/* harmony import */ var _material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @material/dom/ponyfill */ "./node_modules/@material/dom/ponyfill.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/ripple/foundation.js"); +/* harmony import */ var _util__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./util */ "./node_modules/@material/ripple/util.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + +var MDCRipple = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCRipple, _super); + function MDCRipple() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.disabled = false; + return _this; + } + MDCRipple.attachTo = function (root, opts) { + if (opts === void 0) { opts = { isUnbounded: undefined }; } + var ripple = new MDCRipple(root); + // Only override unbounded behavior if option is explicitly specified + if (opts.isUnbounded !== undefined) { + ripple.unbounded = opts.isUnbounded; + } + return ripple; + }; + MDCRipple.createAdapter = function (instance) { + return { + addClass: function (className) { return instance.root_.classList.add(className); }, + browserSupportsCssVars: function () { return _util__WEBPACK_IMPORTED_MODULE_5__["supportsCssVariables"](window); }, + computeBoundingRect: function () { return instance.root_.getBoundingClientRect(); }, + containsEventTarget: function (target) { return instance.root_.contains(target); }, + deregisterDocumentInteractionHandler: function (evtType, handler) { + return document.documentElement.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + deregisterInteractionHandler: function (evtType, handler) { + return instance.root_.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + deregisterResizeHandler: function (handler) { return window.removeEventListener('resize', handler); }, + getWindowPageOffset: function () { return ({ x: window.pageXOffset, y: window.pageYOffset }); }, + isSurfaceActive: function () { return Object(_material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__["matches"])(instance.root_, ':active'); }, + isSurfaceDisabled: function () { return Boolean(instance.disabled); }, + isUnbounded: function () { return Boolean(instance.unbounded); }, + registerDocumentInteractionHandler: function (evtType, handler) { + return document.documentElement.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + registerInteractionHandler: function (evtType, handler) { + return instance.root_.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + registerResizeHandler: function (handler) { return window.addEventListener('resize', handler); }, + removeClass: function (className) { return instance.root_.classList.remove(className); }, + updateCssVariable: function (varName, value) { return instance.root_.style.setProperty(varName, value); }, + }; + }; + Object.defineProperty(MDCRipple.prototype, "unbounded", { + get: function () { + return Boolean(this.unbounded_); + }, + set: function (unbounded) { + this.unbounded_ = Boolean(unbounded); + this.setUnbounded_(); + }, + enumerable: true, + configurable: true + }); + MDCRipple.prototype.activate = function () { + this.foundation_.activate(); + }; + MDCRipple.prototype.deactivate = function () { + this.foundation_.deactivate(); + }; + MDCRipple.prototype.layout = function () { + this.foundation_.layout(); + }; + MDCRipple.prototype.getDefaultFoundation = function () { + return new _foundation__WEBPACK_IMPORTED_MODULE_4__["MDCRippleFoundation"](MDCRipple.createAdapter(this)); + }; + MDCRipple.prototype.initialSyncWithDOM = function () { + var root = this.root_; + this.unbounded = 'mdcRippleIsUnbounded' in root.dataset; + }; + /** + * Closure Compiler throws an access control error when directly accessing a + * protected or private property inside a getter/setter, like unbounded above. + * By accessing the protected property inside a method, we solve that problem. + * That's why this function exists. + */ + MDCRipple.prototype.setUnbounded_ = function () { + this.foundation_.setUnbounded(Boolean(this.unbounded_)); + }; + return MDCRipple; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/constants.js": +/*!****************************************************!*\ + !*** ./node_modules/@material/ripple/constants.js ***! + \****************************************************/ +/*! exports provided: cssClasses, strings, numbers */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + // Ripple is a special case where the "root" component is really a "mixin" of sorts, + // given that it's an 'upgrade' to an existing component. That being said it is the root + // CSS class that all other CSS classes derive from. + BG_FOCUSED: 'mdc-ripple-upgraded--background-focused', + FG_ACTIVATION: 'mdc-ripple-upgraded--foreground-activation', + FG_DEACTIVATION: 'mdc-ripple-upgraded--foreground-deactivation', + ROOT: 'mdc-ripple-upgraded', + UNBOUNDED: 'mdc-ripple-upgraded--unbounded', +}; +var strings = { + VAR_FG_SCALE: '--mdc-ripple-fg-scale', + VAR_FG_SIZE: '--mdc-ripple-fg-size', + VAR_FG_TRANSLATE_END: '--mdc-ripple-fg-translate-end', + VAR_FG_TRANSLATE_START: '--mdc-ripple-fg-translate-start', + VAR_LEFT: '--mdc-ripple-left', + VAR_TOP: '--mdc-ripple-top', +}; +var numbers = { + DEACTIVATION_TIMEOUT_MS: 225, + FG_DEACTIVATION_MS: 150, + INITIAL_ORIGIN_SCALE: 0.6, + PADDING: 10, + TAP_DELAY_MS: 300, +}; +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/foundation.js": +/*!*****************************************************!*\ + !*** ./node_modules/@material/ripple/foundation.js ***! + \*****************************************************/ +/*! exports provided: MDCRippleFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCRippleFoundation", function() { return MDCRippleFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/ripple/constants.js"); +/* harmony import */ var _util__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./util */ "./node_modules/@material/ripple/util.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + +// Activation events registered on the root element of each instance for activation +var ACTIVATION_EVENT_TYPES = [ + 'touchstart', 'pointerdown', 'mousedown', 'keydown', +]; +// Deactivation events registered on documentElement when a pointer-related down event occurs +var POINTER_DEACTIVATION_EVENT_TYPES = [ + 'touchend', 'pointerup', 'mouseup', 'contextmenu', +]; +// simultaneous nested activations +var activatedTargets = []; +var MDCRippleFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCRippleFoundation, _super); + function MDCRippleFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCRippleFoundation.defaultAdapter, adapter)) || this; + _this.activationAnimationHasEnded_ = false; + _this.activationTimer_ = 0; + _this.fgDeactivationRemovalTimer_ = 0; + _this.fgScale_ = '0'; + _this.frame_ = { width: 0, height: 0 }; + _this.initialSize_ = 0; + _this.layoutFrame_ = 0; + _this.maxRadius_ = 0; + _this.unboundedCoords_ = { left: 0, top: 0 }; + _this.activationState_ = _this.defaultActivationState_(); + _this.activationTimerCallback_ = function () { + _this.activationAnimationHasEnded_ = true; + _this.runDeactivationUXLogicIfReady_(); + }; + _this.activateHandler_ = function (e) { return _this.activate_(e); }; + _this.deactivateHandler_ = function () { return _this.deactivate_(); }; + _this.focusHandler_ = function () { return _this.handleFocus(); }; + _this.blurHandler_ = function () { return _this.handleBlur(); }; + _this.resizeHandler_ = function () { return _this.layout(); }; + return _this; + } + Object.defineProperty(MDCRippleFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCRippleFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCRippleFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCRippleFoundation, "defaultAdapter", { + get: function () { + return { + addClass: function () { return undefined; }, + browserSupportsCssVars: function () { return true; }, + computeBoundingRect: function () { return ({ top: 0, right: 0, bottom: 0, left: 0, width: 0, height: 0 }); }, + containsEventTarget: function () { return true; }, + deregisterDocumentInteractionHandler: function () { return undefined; }, + deregisterInteractionHandler: function () { return undefined; }, + deregisterResizeHandler: function () { return undefined; }, + getWindowPageOffset: function () { return ({ x: 0, y: 0 }); }, + isSurfaceActive: function () { return true; }, + isSurfaceDisabled: function () { return true; }, + isUnbounded: function () { return true; }, + registerDocumentInteractionHandler: function () { return undefined; }, + registerInteractionHandler: function () { return undefined; }, + registerResizeHandler: function () { return undefined; }, + removeClass: function () { return undefined; }, + updateCssVariable: function () { return undefined; }, + }; + }, + enumerable: true, + configurable: true + }); + MDCRippleFoundation.prototype.init = function () { + var _this = this; + var supportsPressRipple = this.supportsPressRipple_(); + this.registerRootHandlers_(supportsPressRipple); + if (supportsPressRipple) { + var _a = MDCRippleFoundation.cssClasses, ROOT_1 = _a.ROOT, UNBOUNDED_1 = _a.UNBOUNDED; + requestAnimationFrame(function () { + _this.adapter_.addClass(ROOT_1); + if (_this.adapter_.isUnbounded()) { + _this.adapter_.addClass(UNBOUNDED_1); + // Unbounded ripples need layout logic applied immediately to set coordinates for both shade and ripple + _this.layoutInternal_(); + } + }); + } + }; + MDCRippleFoundation.prototype.destroy = function () { + var _this = this; + if (this.supportsPressRipple_()) { + if (this.activationTimer_) { + clearTimeout(this.activationTimer_); + this.activationTimer_ = 0; + this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_ACTIVATION); + } + if (this.fgDeactivationRemovalTimer_) { + clearTimeout(this.fgDeactivationRemovalTimer_); + this.fgDeactivationRemovalTimer_ = 0; + this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_DEACTIVATION); + } + var _a = MDCRippleFoundation.cssClasses, ROOT_2 = _a.ROOT, UNBOUNDED_2 = _a.UNBOUNDED; + requestAnimationFrame(function () { + _this.adapter_.removeClass(ROOT_2); + _this.adapter_.removeClass(UNBOUNDED_2); + _this.removeCssVars_(); + }); + } + this.deregisterRootHandlers_(); + this.deregisterDeactivationHandlers_(); + }; + /** + * @param evt Optional event containing position information. + */ + MDCRippleFoundation.prototype.activate = function (evt) { + this.activate_(evt); + }; + MDCRippleFoundation.prototype.deactivate = function () { + this.deactivate_(); + }; + MDCRippleFoundation.prototype.layout = function () { + var _this = this; + if (this.layoutFrame_) { + cancelAnimationFrame(this.layoutFrame_); + } + this.layoutFrame_ = requestAnimationFrame(function () { + _this.layoutInternal_(); + _this.layoutFrame_ = 0; + }); + }; + MDCRippleFoundation.prototype.setUnbounded = function (unbounded) { + var UNBOUNDED = MDCRippleFoundation.cssClasses.UNBOUNDED; + if (unbounded) { + this.adapter_.addClass(UNBOUNDED); + } + else { + this.adapter_.removeClass(UNBOUNDED); + } + }; + MDCRippleFoundation.prototype.handleFocus = function () { + var _this = this; + requestAnimationFrame(function () { + return _this.adapter_.addClass(MDCRippleFoundation.cssClasses.BG_FOCUSED); + }); + }; + MDCRippleFoundation.prototype.handleBlur = function () { + var _this = this; + requestAnimationFrame(function () { + return _this.adapter_.removeClass(MDCRippleFoundation.cssClasses.BG_FOCUSED); + }); + }; + /** + * We compute this property so that we are not querying information about the client + * until the point in time where the foundation requests it. This prevents scenarios where + * client-side feature-detection may happen too early, such as when components are rendered on the server + * and then initialized at mount time on the client. + */ + MDCRippleFoundation.prototype.supportsPressRipple_ = function () { + return this.adapter_.browserSupportsCssVars(); + }; + MDCRippleFoundation.prototype.defaultActivationState_ = function () { + return { + activationEvent: undefined, + hasDeactivationUXRun: false, + isActivated: false, + isProgrammatic: false, + wasActivatedByPointer: false, + wasElementMadeActive: false, + }; + }; + /** + * supportsPressRipple Passed from init to save a redundant function call + */ + MDCRippleFoundation.prototype.registerRootHandlers_ = function (supportsPressRipple) { + var _this = this; + if (supportsPressRipple) { + ACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.registerInteractionHandler(evtType, _this.activateHandler_); + }); + if (this.adapter_.isUnbounded()) { + this.adapter_.registerResizeHandler(this.resizeHandler_); + } + } + this.adapter_.registerInteractionHandler('focus', this.focusHandler_); + this.adapter_.registerInteractionHandler('blur', this.blurHandler_); + }; + MDCRippleFoundation.prototype.registerDeactivationHandlers_ = function (evt) { + var _this = this; + if (evt.type === 'keydown') { + this.adapter_.registerInteractionHandler('keyup', this.deactivateHandler_); + } + else { + POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.registerDocumentInteractionHandler(evtType, _this.deactivateHandler_); + }); + } + }; + MDCRippleFoundation.prototype.deregisterRootHandlers_ = function () { + var _this = this; + ACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.deregisterInteractionHandler(evtType, _this.activateHandler_); + }); + this.adapter_.deregisterInteractionHandler('focus', this.focusHandler_); + this.adapter_.deregisterInteractionHandler('blur', this.blurHandler_); + if (this.adapter_.isUnbounded()) { + this.adapter_.deregisterResizeHandler(this.resizeHandler_); + } + }; + MDCRippleFoundation.prototype.deregisterDeactivationHandlers_ = function () { + var _this = this; + this.adapter_.deregisterInteractionHandler('keyup', this.deactivateHandler_); + POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.deregisterDocumentInteractionHandler(evtType, _this.deactivateHandler_); + }); + }; + MDCRippleFoundation.prototype.removeCssVars_ = function () { + var _this = this; + var rippleStrings = MDCRippleFoundation.strings; + var keys = Object.keys(rippleStrings); + keys.forEach(function (key) { + if (key.indexOf('VAR_') === 0) { + _this.adapter_.updateCssVariable(rippleStrings[key], null); + } + }); + }; + MDCRippleFoundation.prototype.activate_ = function (evt) { + var _this = this; + if (this.adapter_.isSurfaceDisabled()) { + return; + } + var activationState = this.activationState_; + if (activationState.isActivated) { + return; + } + // Avoid reacting to follow-on events fired by touch device after an already-processed user interaction + var previousActivationEvent = this.previousActivationEvent_; + var isSameInteraction = previousActivationEvent && evt !== undefined && previousActivationEvent.type !== evt.type; + if (isSameInteraction) { + return; + } + activationState.isActivated = true; + activationState.isProgrammatic = evt === undefined; + activationState.activationEvent = evt; + activationState.wasActivatedByPointer = activationState.isProgrammatic ? false : evt !== undefined && (evt.type === 'mousedown' || evt.type === 'touchstart' || evt.type === 'pointerdown'); + var hasActivatedChild = evt !== undefined && activatedTargets.length > 0 && activatedTargets.some(function (target) { return _this.adapter_.containsEventTarget(target); }); + if (hasActivatedChild) { + // Immediately reset activation state, while preserving logic that prevents touch follow-on events + this.resetActivationState_(); + return; + } + if (evt !== undefined) { + activatedTargets.push(evt.target); + this.registerDeactivationHandlers_(evt); + } + activationState.wasElementMadeActive = this.checkElementMadeActive_(evt); + if (activationState.wasElementMadeActive) { + this.animateActivation_(); + } + requestAnimationFrame(function () { + // Reset array on next frame after the current event has had a chance to bubble to prevent ancestor ripples + activatedTargets = []; + if (!activationState.wasElementMadeActive + && evt !== undefined + && (evt.key === ' ' || evt.keyCode === 32)) { + // If space was pressed, try again within an rAF call to detect :active, because different UAs report + // active states inconsistently when they're called within event handling code: + // - https://bugs.chromium.org/p/chromium/issues/detail?id=635971 + // - https://bugzilla.mozilla.org/show_bug.cgi?id=1293741 + // We try first outside rAF to support Edge, which does not exhibit this problem, but will crash if a CSS + // variable is set within a rAF callback for a submit button interaction (#2241). + activationState.wasElementMadeActive = _this.checkElementMadeActive_(evt); + if (activationState.wasElementMadeActive) { + _this.animateActivation_(); + } + } + if (!activationState.wasElementMadeActive) { + // Reset activation state immediately if element was not made active. + _this.activationState_ = _this.defaultActivationState_(); + } + }); + }; + MDCRippleFoundation.prototype.checkElementMadeActive_ = function (evt) { + return (evt !== undefined && evt.type === 'keydown') ? this.adapter_.isSurfaceActive() : true; + }; + MDCRippleFoundation.prototype.animateActivation_ = function () { + var _this = this; + var _a = MDCRippleFoundation.strings, VAR_FG_TRANSLATE_START = _a.VAR_FG_TRANSLATE_START, VAR_FG_TRANSLATE_END = _a.VAR_FG_TRANSLATE_END; + var _b = MDCRippleFoundation.cssClasses, FG_DEACTIVATION = _b.FG_DEACTIVATION, FG_ACTIVATION = _b.FG_ACTIVATION; + var DEACTIVATION_TIMEOUT_MS = MDCRippleFoundation.numbers.DEACTIVATION_TIMEOUT_MS; + this.layoutInternal_(); + var translateStart = ''; + var translateEnd = ''; + if (!this.adapter_.isUnbounded()) { + var _c = this.getFgTranslationCoordinates_(), startPoint = _c.startPoint, endPoint = _c.endPoint; + translateStart = startPoint.x + "px, " + startPoint.y + "px"; + translateEnd = endPoint.x + "px, " + endPoint.y + "px"; + } + this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_START, translateStart); + this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_END, translateEnd); + // Cancel any ongoing activation/deactivation animations + clearTimeout(this.activationTimer_); + clearTimeout(this.fgDeactivationRemovalTimer_); + this.rmBoundedActivationClasses_(); + this.adapter_.removeClass(FG_DEACTIVATION); + // Force layout in order to re-trigger the animation. + this.adapter_.computeBoundingRect(); + this.adapter_.addClass(FG_ACTIVATION); + this.activationTimer_ = setTimeout(function () { return _this.activationTimerCallback_(); }, DEACTIVATION_TIMEOUT_MS); + }; + MDCRippleFoundation.prototype.getFgTranslationCoordinates_ = function () { + var _a = this.activationState_, activationEvent = _a.activationEvent, wasActivatedByPointer = _a.wasActivatedByPointer; + var startPoint; + if (wasActivatedByPointer) { + startPoint = Object(_util__WEBPACK_IMPORTED_MODULE_3__["getNormalizedEventCoords"])(activationEvent, this.adapter_.getWindowPageOffset(), this.adapter_.computeBoundingRect()); + } + else { + startPoint = { + x: this.frame_.width / 2, + y: this.frame_.height / 2, + }; + } + // Center the element around the start point. + startPoint = { + x: startPoint.x - (this.initialSize_ / 2), + y: startPoint.y - (this.initialSize_ / 2), + }; + var endPoint = { + x: (this.frame_.width / 2) - (this.initialSize_ / 2), + y: (this.frame_.height / 2) - (this.initialSize_ / 2), + }; + return { startPoint: startPoint, endPoint: endPoint }; + }; + MDCRippleFoundation.prototype.runDeactivationUXLogicIfReady_ = function () { + var _this = this; + // This method is called both when a pointing device is released, and when the activation animation ends. + // The deactivation animation should only run after both of those occur. + var FG_DEACTIVATION = MDCRippleFoundation.cssClasses.FG_DEACTIVATION; + var _a = this.activationState_, hasDeactivationUXRun = _a.hasDeactivationUXRun, isActivated = _a.isActivated; + var activationHasEnded = hasDeactivationUXRun || !isActivated; + if (activationHasEnded && this.activationAnimationHasEnded_) { + this.rmBoundedActivationClasses_(); + this.adapter_.addClass(FG_DEACTIVATION); + this.fgDeactivationRemovalTimer_ = setTimeout(function () { + _this.adapter_.removeClass(FG_DEACTIVATION); + }, _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].FG_DEACTIVATION_MS); + } + }; + MDCRippleFoundation.prototype.rmBoundedActivationClasses_ = function () { + var FG_ACTIVATION = MDCRippleFoundation.cssClasses.FG_ACTIVATION; + this.adapter_.removeClass(FG_ACTIVATION); + this.activationAnimationHasEnded_ = false; + this.adapter_.computeBoundingRect(); + }; + MDCRippleFoundation.prototype.resetActivationState_ = function () { + var _this = this; + this.previousActivationEvent_ = this.activationState_.activationEvent; + this.activationState_ = this.defaultActivationState_(); + // Touch devices may fire additional events for the same interaction within a short time. + // Store the previous event until it's safe to assume that subsequent events are for new interactions. + setTimeout(function () { return _this.previousActivationEvent_ = undefined; }, MDCRippleFoundation.numbers.TAP_DELAY_MS); + }; + MDCRippleFoundation.prototype.deactivate_ = function () { + var _this = this; + var activationState = this.activationState_; + // This can happen in scenarios such as when you have a keyup event that blurs the element. + if (!activationState.isActivated) { + return; + } + var state = tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, activationState); + if (activationState.isProgrammatic) { + requestAnimationFrame(function () { return _this.animateDeactivation_(state); }); + this.resetActivationState_(); + } + else { + this.deregisterDeactivationHandlers_(); + requestAnimationFrame(function () { + _this.activationState_.hasDeactivationUXRun = true; + _this.animateDeactivation_(state); + _this.resetActivationState_(); + }); + } + }; + MDCRippleFoundation.prototype.animateDeactivation_ = function (_a) { + var wasActivatedByPointer = _a.wasActivatedByPointer, wasElementMadeActive = _a.wasElementMadeActive; + if (wasActivatedByPointer || wasElementMadeActive) { + this.runDeactivationUXLogicIfReady_(); + } + }; + MDCRippleFoundation.prototype.layoutInternal_ = function () { + var _this = this; + this.frame_ = this.adapter_.computeBoundingRect(); + var maxDim = Math.max(this.frame_.height, this.frame_.width); + // Surface diameter is treated differently for unbounded vs. bounded ripples. + // Unbounded ripple diameter is calculated smaller since the surface is expected to already be padded appropriately + // to extend the hitbox, and the ripple is expected to meet the edges of the padded hitbox (which is typically + // square). Bounded ripples, on the other hand, are fully expected to expand beyond the surface's longest diameter + // (calculated based on the diagonal plus a constant padding), and are clipped at the surface's border via + // `overflow: hidden`. + var getBoundedRadius = function () { + var hypotenuse = Math.sqrt(Math.pow(_this.frame_.width, 2) + Math.pow(_this.frame_.height, 2)); + return hypotenuse + MDCRippleFoundation.numbers.PADDING; + }; + this.maxRadius_ = this.adapter_.isUnbounded() ? maxDim : getBoundedRadius(); + // Ripple is sized as a fraction of the largest dimension of the surface, then scales up using a CSS scale transform + this.initialSize_ = Math.floor(maxDim * MDCRippleFoundation.numbers.INITIAL_ORIGIN_SCALE); + this.fgScale_ = "" + this.maxRadius_ / this.initialSize_; + this.updateLayoutCssVars_(); + }; + MDCRippleFoundation.prototype.updateLayoutCssVars_ = function () { + var _a = MDCRippleFoundation.strings, VAR_FG_SIZE = _a.VAR_FG_SIZE, VAR_LEFT = _a.VAR_LEFT, VAR_TOP = _a.VAR_TOP, VAR_FG_SCALE = _a.VAR_FG_SCALE; + this.adapter_.updateCssVariable(VAR_FG_SIZE, this.initialSize_ + "px"); + this.adapter_.updateCssVariable(VAR_FG_SCALE, this.fgScale_); + if (this.adapter_.isUnbounded()) { + this.unboundedCoords_ = { + left: Math.round((this.frame_.width / 2) - (this.initialSize_ / 2)), + top: Math.round((this.frame_.height / 2) - (this.initialSize_ / 2)), + }; + this.adapter_.updateCssVariable(VAR_LEFT, this.unboundedCoords_.left + "px"); + this.adapter_.updateCssVariable(VAR_TOP, this.unboundedCoords_.top + "px"); + } + }; + return MDCRippleFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCRippleFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/index.js": +/*!************************************************!*\ + !*** ./node_modules/@material/ripple/index.js ***! + \************************************************/ +/*! exports provided: util, MDCRipple, cssClasses, strings, numbers, MDCRippleFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _util__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./util */ "./node_modules/@material/ripple/util.js"); +/* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "util", function() { return _util__WEBPACK_IMPORTED_MODULE_0__; }); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./component */ "./node_modules/@material/ripple/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCRipple", function() { return _component__WEBPACK_IMPORTED_MODULE_1__["MDCRipple"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/ripple/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/ripple/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCRippleFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_3__["MDCRippleFoundation"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/util.js": +/*!***********************************************!*\ + !*** ./node_modules/@material/ripple/util.js ***! + \***********************************************/ +/*! exports provided: supportsCssVariables, getNormalizedEventCoords */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "supportsCssVariables", function() { return supportsCssVariables; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getNormalizedEventCoords", function() { return getNormalizedEventCoords; }); +/** + * Stores result from supportsCssVariables to avoid redundant processing to + * detect CSS custom variable support. + */ +var supportsCssVariables_; +function detectEdgePseudoVarBug(windowObj) { + // Detect versions of Edge with buggy var() support + // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/11495448/ + var document = windowObj.document; + var node = document.createElement('div'); + node.className = 'mdc-ripple-surface--test-edge-var-bug'; + // Append to head instead of body because this script might be invoked in the + // head, in which case the body doesn't exist yet. The probe works either way. + document.head.appendChild(node); + // The bug exists if ::before style ends up propagating to the parent element. + // Additionally, getComputedStyle returns null in iframes with display: "none" in Firefox, + // but Firefox is known to support CSS custom properties correctly. + // See: https://bugzilla.mozilla.org/show_bug.cgi?id=548397 + var computedStyle = windowObj.getComputedStyle(node); + var hasPseudoVarBug = computedStyle !== null && computedStyle.borderTopStyle === 'solid'; + if (node.parentNode) { + node.parentNode.removeChild(node); + } + return hasPseudoVarBug; +} +function supportsCssVariables(windowObj, forceRefresh) { + if (forceRefresh === void 0) { forceRefresh = false; } + var CSS = windowObj.CSS; + var supportsCssVars = supportsCssVariables_; + if (typeof supportsCssVariables_ === 'boolean' && !forceRefresh) { + return supportsCssVariables_; + } + var supportsFunctionPresent = CSS && typeof CSS.supports === 'function'; + if (!supportsFunctionPresent) { + return false; + } + var explicitlySupportsCssVars = CSS.supports('--css-vars', 'yes'); + // See: https://bugs.webkit.org/show_bug.cgi?id=154669 + // See: README section on Safari + var weAreFeatureDetectingSafari10plus = (CSS.supports('(--css-vars: yes)') && + CSS.supports('color', '#00000000')); + if (explicitlySupportsCssVars || weAreFeatureDetectingSafari10plus) { + supportsCssVars = !detectEdgePseudoVarBug(windowObj); + } + else { + supportsCssVars = false; + } + if (!forceRefresh) { + supportsCssVariables_ = supportsCssVars; + } + return supportsCssVars; +} +function getNormalizedEventCoords(evt, pageOffset, clientRect) { + if (!evt) { + return { x: 0, y: 0 }; + } + var x = pageOffset.x, y = pageOffset.y; + var documentX = x + clientRect.left; + var documentY = y + clientRect.top; + var normalizedX; + var normalizedY; + // Determine touch point relative to the ripple container. + if (evt.type === 'touchstart') { + var touchEvent = evt; + normalizedX = touchEvent.changedTouches[0].pageX - documentX; + normalizedY = touchEvent.changedTouches[0].pageY - documentY; + } + else { + var mouseEvent = evt; + normalizedX = mouseEvent.pageX - documentX; + normalizedY = mouseEvent.pageY - documentY; + } + return { x: normalizedX, y: normalizedY }; +} +//# sourceMappingURL=util.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/component.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/component.js ***! + \*************************************************************************/ +/*! exports provided: MDCTextFieldCharacterCounter */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounter", function() { return MDCTextFieldCharacterCounter; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/character-counter/foundation.js"); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldCharacterCounter = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldCharacterCounter, _super); + function MDCTextFieldCharacterCounter() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextFieldCharacterCounter.attachTo = function (root) { + return new MDCTextFieldCharacterCounter(root); + }; + Object.defineProperty(MDCTextFieldCharacterCounter.prototype, "foundation", { + get: function () { + return this.foundation_; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldCharacterCounter.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + var adapter = { + setContent: function (content) { + _this.root_.textContent = content; + }, + }; + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldCharacterCounterFoundation"](adapter); + }; + return MDCTextFieldCharacterCounter; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/constants.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/constants.js ***! + \*************************************************************************/ +/*! exports provided: strings, cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + ROOT: 'mdc-text-field-character-counter', +}; +var strings = { + ROOT_SELECTOR: "." + cssClasses.ROOT, +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/foundation.js": +/*!**************************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/foundation.js ***! + \**************************************************************************/ +/*! exports provided: MDCTextFieldCharacterCounterFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounterFoundation", function() { return MDCTextFieldCharacterCounterFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/character-counter/constants.js"); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldCharacterCounterFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldCharacterCounterFoundation, _super); + function MDCTextFieldCharacterCounterFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldCharacterCounterFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCTextFieldCharacterCounterFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldCharacterCounterFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldCharacterCounterFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldCharacterCounterAdapter} for typing information on parameters and return types. + */ + get: function () { + return { + setContent: function () { return undefined; }, + }; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldCharacterCounterFoundation.prototype.setCounterValue = function (currentLength, maxLength) { + currentLength = Math.min(currentLength, maxLength); + this.adapter_.setContent(currentLength + " / " + maxLength); + }; + return MDCTextFieldCharacterCounterFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldCharacterCounterFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/index.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/index.js ***! + \*********************************************************************/ +/*! exports provided: characterCountCssClasses, characterCountStrings, MDCTextFieldCharacterCounter, MDCTextFieldCharacterCounterFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/character-counter/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounter", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextFieldCharacterCounter"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/character-counter/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounterFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCTextFieldCharacterCounterFoundation"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/character-counter/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountCssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountStrings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/component.js": +/*!*******************************************************!*\ + !*** ./node_modules/@material/textfield/component.js ***! + \*******************************************************/ +/*! exports provided: MDCTextField */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextField", function() { return MDCTextField; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_dom_events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/dom/events */ "./node_modules/@material/dom/events.js"); +/* harmony import */ var _material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @material/dom/ponyfill */ "./node_modules/@material/dom/ponyfill.js"); +/* harmony import */ var _material_floating_label_component__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @material/floating-label/component */ "./node_modules/@material/floating-label/component.js"); +/* harmony import */ var _material_line_ripple_component__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @material/line-ripple/component */ "./node_modules/@material/line-ripple/component.js"); +/* harmony import */ var _material_notched_outline_component__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @material/notched-outline/component */ "./node_modules/@material/notched-outline/component.js"); +/* harmony import */ var _material_ripple_component__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @material/ripple/component */ "./node_modules/@material/ripple/component.js"); +/* harmony import */ var _material_ripple_foundation__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @material/ripple/foundation */ "./node_modules/@material/ripple/foundation.js"); +/* harmony import */ var _character_counter_component__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./character-counter/component */ "./node_modules/@material/textfield/character-counter/component.js"); +/* harmony import */ var _character_counter_foundation__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./character-counter/foundation */ "./node_modules/@material/textfield/character-counter/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/foundation.js"); +/* harmony import */ var _helper_text_component__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./helper-text/component */ "./node_modules/@material/textfield/helper-text/component.js"); +/* harmony import */ var _helper_text_foundation__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./helper-text/foundation */ "./node_modules/@material/textfield/helper-text/foundation.js"); +/* harmony import */ var _icon_component__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./icon/component */ "./node_modules/@material/textfield/icon/component.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + + + + + + + + + + + +var MDCTextField = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextField, _super); + function MDCTextField() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextField.attachTo = function (root) { + return new MDCTextField(root); + }; + MDCTextField.prototype.initialize = function (rippleFactory, lineRippleFactory, helperTextFactory, characterCounterFactory, iconFactory, labelFactory, outlineFactory) { + if (rippleFactory === void 0) { rippleFactory = function (el, foundation) { return new _material_ripple_component__WEBPACK_IMPORTED_MODULE_7__["MDCRipple"](el, foundation); }; } + if (lineRippleFactory === void 0) { lineRippleFactory = function (el) { return new _material_line_ripple_component__WEBPACK_IMPORTED_MODULE_5__["MDCLineRipple"](el); }; } + if (helperTextFactory === void 0) { helperTextFactory = function (el) { return new _helper_text_component__WEBPACK_IMPORTED_MODULE_13__["MDCTextFieldHelperText"](el); }; } + if (characterCounterFactory === void 0) { characterCounterFactory = function (el) { return new _character_counter_component__WEBPACK_IMPORTED_MODULE_9__["MDCTextFieldCharacterCounter"](el); }; } + if (iconFactory === void 0) { iconFactory = function (el) { return new _icon_component__WEBPACK_IMPORTED_MODULE_15__["MDCTextFieldIcon"](el); }; } + if (labelFactory === void 0) { labelFactory = function (el) { return new _material_floating_label_component__WEBPACK_IMPORTED_MODULE_4__["MDCFloatingLabel"](el); }; } + if (outlineFactory === void 0) { outlineFactory = function (el) { return new _material_notched_outline_component__WEBPACK_IMPORTED_MODULE_6__["MDCNotchedOutline"](el); }; } + this.input_ = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].INPUT_SELECTOR); + var labelElement = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].LABEL_SELECTOR); + this.label_ = labelElement ? labelFactory(labelElement) : null; + var lineRippleElement = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].LINE_RIPPLE_SELECTOR); + this.lineRipple_ = lineRippleElement ? lineRippleFactory(lineRippleElement) : null; + var outlineElement = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].OUTLINE_SELECTOR); + this.outline_ = outlineElement ? outlineFactory(outlineElement) : null; + // Helper text + var helperTextStrings = _helper_text_foundation__WEBPACK_IMPORTED_MODULE_14__["MDCTextFieldHelperTextFoundation"].strings; + var nextElementSibling = this.root_.nextElementSibling; + var hasHelperLine = (nextElementSibling && nextElementSibling.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].HELPER_LINE)); + var helperTextEl = hasHelperLine && nextElementSibling && nextElementSibling.querySelector(helperTextStrings.ROOT_SELECTOR); + this.helperText_ = helperTextEl ? helperTextFactory(helperTextEl) : null; + // Character counter + var characterCounterStrings = _character_counter_foundation__WEBPACK_IMPORTED_MODULE_10__["MDCTextFieldCharacterCounterFoundation"].strings; + var characterCounterEl = this.root_.querySelector(characterCounterStrings.ROOT_SELECTOR); + // If character counter is not found in root element search in sibling element. + if (!characterCounterEl && hasHelperLine && nextElementSibling) { + characterCounterEl = nextElementSibling.querySelector(characterCounterStrings.ROOT_SELECTOR); + } + this.characterCounter_ = characterCounterEl ? characterCounterFactory(characterCounterEl) : null; + this.leadingIcon_ = null; + this.trailingIcon_ = null; + var iconElements = this.root_.querySelectorAll(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].ICON_SELECTOR); + if (iconElements.length > 0) { + if (iconElements.length > 1) { // Has both icons. + this.leadingIcon_ = iconFactory(iconElements[0]); + this.trailingIcon_ = iconFactory(iconElements[1]); + } + else { + if (this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].WITH_LEADING_ICON)) { + this.leadingIcon_ = iconFactory(iconElements[0]); + } + else { + this.trailingIcon_ = iconFactory(iconElements[0]); + } + } + } + this.ripple = this.createRipple_(rippleFactory); + }; + MDCTextField.prototype.destroy = function () { + if (this.ripple) { + this.ripple.destroy(); + } + if (this.lineRipple_) { + this.lineRipple_.destroy(); + } + if (this.helperText_) { + this.helperText_.destroy(); + } + if (this.characterCounter_) { + this.characterCounter_.destroy(); + } + if (this.leadingIcon_) { + this.leadingIcon_.destroy(); + } + if (this.trailingIcon_) { + this.trailingIcon_.destroy(); + } + if (this.label_) { + this.label_.destroy(); + } + if (this.outline_) { + this.outline_.destroy(); + } + _super.prototype.destroy.call(this); + }; + /** + * Initializes the Text Field's internal state based on the environment's + * state. + */ + MDCTextField.prototype.initialSyncWithDOM = function () { + this.disabled = this.input_.disabled; + }; + Object.defineProperty(MDCTextField.prototype, "value", { + get: function () { + return this.foundation_.getValue(); + }, + /** + * @param value The value to set on the input. + */ + set: function (value) { + this.foundation_.setValue(value); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "disabled", { + get: function () { + return this.foundation_.isDisabled(); + }, + /** + * @param disabled Sets the Text Field disabled or enabled. + */ + set: function (disabled) { + this.foundation_.setDisabled(disabled); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "valid", { + get: function () { + return this.foundation_.isValid(); + }, + /** + * @param valid Sets the Text Field valid or invalid. + */ + set: function (valid) { + this.foundation_.setValid(valid); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "required", { + get: function () { + return this.input_.required; + }, + /** + * @param required Sets the Text Field to required. + */ + set: function (required) { + this.input_.required = required; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "pattern", { + get: function () { + return this.input_.pattern; + }, + /** + * @param pattern Sets the input element's validation pattern. + */ + set: function (pattern) { + this.input_.pattern = pattern; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "minLength", { + get: function () { + return this.input_.minLength; + }, + /** + * @param minLength Sets the input element's minLength. + */ + set: function (minLength) { + this.input_.minLength = minLength; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "maxLength", { + get: function () { + return this.input_.maxLength; + }, + /** + * @param maxLength Sets the input element's maxLength. + */ + set: function (maxLength) { + // Chrome throws exception if maxLength is set to a value less than zero + if (maxLength < 0) { + this.input_.removeAttribute('maxLength'); + } + else { + this.input_.maxLength = maxLength; + } + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "min", { + get: function () { + return this.input_.min; + }, + /** + * @param min Sets the input element's min. + */ + set: function (min) { + this.input_.min = min; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "max", { + get: function () { + return this.input_.max; + }, + /** + * @param max Sets the input element's max. + */ + set: function (max) { + this.input_.max = max; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "step", { + get: function () { + return this.input_.step; + }, + /** + * @param step Sets the input element's step. + */ + set: function (step) { + this.input_.step = step; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "helperTextContent", { + /** + * Sets the helper text element content. + */ + set: function (content) { + this.foundation_.setHelperTextContent(content); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "leadingIconAriaLabel", { + /** + * Sets the aria label of the leading icon. + */ + set: function (label) { + this.foundation_.setLeadingIconAriaLabel(label); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "leadingIconContent", { + /** + * Sets the text content of the leading icon. + */ + set: function (content) { + this.foundation_.setLeadingIconContent(content); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "trailingIconAriaLabel", { + /** + * Sets the aria label of the trailing icon. + */ + set: function (label) { + this.foundation_.setTrailingIconAriaLabel(label); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "trailingIconContent", { + /** + * Sets the text content of the trailing icon. + */ + set: function (content) { + this.foundation_.setTrailingIconContent(content); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "useNativeValidation", { + /** + * Enables or disables the use of native validation. Use this for custom validation. + * @param useNativeValidation Set this to false to ignore native input validation. + */ + set: function (useNativeValidation) { + this.foundation_.setUseNativeValidation(useNativeValidation); + }, + enumerable: true, + configurable: true + }); + /** + * Focuses the input element. + */ + MDCTextField.prototype.focus = function () { + this.input_.focus(); + }; + /** + * Recomputes the outline SVG path for the outline element. + */ + MDCTextField.prototype.layout = function () { + var openNotch = this.foundation_.shouldFloat; + this.foundation_.notchOutline(openNotch); + }; + MDCTextField.prototype.getDefaultFoundation = function () { + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, this.getRootAdapterMethods_(), this.getInputAdapterMethods_(), this.getLabelAdapterMethods_(), this.getLineRippleAdapterMethods_(), this.getOutlineAdapterMethods_()); + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_12__["MDCTextFieldFoundation"](adapter, this.getFoundationMap_()); + }; + MDCTextField.prototype.getRootAdapterMethods_ = function () { + var _this = this; + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + hasClass: function (className) { return _this.root_.classList.contains(className); }, + registerTextFieldInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterTextFieldInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + registerValidationAttributeChangeHandler: function (handler) { + var getAttributesList = function (mutationsList) { + return mutationsList + .map(function (mutation) { return mutation.attributeName; }) + .filter(function (attributeName) { return attributeName; }); + }; + var observer = new MutationObserver(function (mutationsList) { return handler(getAttributesList(mutationsList)); }); + var config = { attributes: true }; + observer.observe(_this.input_, config); + return observer; + }, + deregisterValidationAttributeChangeHandler: function (observer) { return observer.disconnect(); }, + }; + // tslint:enable:object-literal-sort-keys + }; + MDCTextField.prototype.getInputAdapterMethods_ = function () { + var _this = this; + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + getNativeInput: function () { return _this.input_; }, + isFocused: function () { return document.activeElement === _this.input_; }, + registerInputInteractionHandler: function (evtType, handler) { + return _this.input_.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + deregisterInputInteractionHandler: function (evtType, handler) { + return _this.input_.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + }; + // tslint:enable:object-literal-sort-keys + }; + MDCTextField.prototype.getLabelAdapterMethods_ = function () { + var _this = this; + return { + floatLabel: function (shouldFloat) { return _this.label_ && _this.label_.float(shouldFloat); }, + getLabelWidth: function () { return _this.label_ ? _this.label_.getWidth() : 0; }, + hasLabel: function () { return Boolean(_this.label_); }, + shakeLabel: function (shouldShake) { return _this.label_ && _this.label_.shake(shouldShake); }, + }; + }; + MDCTextField.prototype.getLineRippleAdapterMethods_ = function () { + var _this = this; + return { + activateLineRipple: function () { + if (_this.lineRipple_) { + _this.lineRipple_.activate(); + } + }, + deactivateLineRipple: function () { + if (_this.lineRipple_) { + _this.lineRipple_.deactivate(); + } + }, + setLineRippleTransformOrigin: function (normalizedX) { + if (_this.lineRipple_) { + _this.lineRipple_.setRippleCenter(normalizedX); + } + }, + }; + }; + MDCTextField.prototype.getOutlineAdapterMethods_ = function () { + var _this = this; + return { + closeOutline: function () { return _this.outline_ && _this.outline_.closeNotch(); }, + hasOutline: function () { return Boolean(_this.outline_); }, + notchOutline: function (labelWidth) { return _this.outline_ && _this.outline_.notch(labelWidth); }, + }; + }; + /** + * @return A map of all subcomponents to subfoundations. + */ + MDCTextField.prototype.getFoundationMap_ = function () { + return { + characterCounter: this.characterCounter_ ? this.characterCounter_.foundation : undefined, + helperText: this.helperText_ ? this.helperText_.foundation : undefined, + leadingIcon: this.leadingIcon_ ? this.leadingIcon_.foundation : undefined, + trailingIcon: this.trailingIcon_ ? this.trailingIcon_.foundation : undefined, + }; + }; + MDCTextField.prototype.createRipple_ = function (rippleFactory) { + var _this = this; + var isTextArea = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].TEXTAREA); + var isOutlined = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].OUTLINED); + if (isTextArea || isOutlined) { + return null; + } + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, _material_ripple_component__WEBPACK_IMPORTED_MODULE_7__["MDCRipple"].createAdapter(this), { isSurfaceActive: function () { return _material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__["matches"](_this.input_, ':active'); }, registerInteractionHandler: function (evtType, handler) { return _this.input_.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); }, deregisterInteractionHandler: function (evtType, handler) { + return _this.input_.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + } }); + // tslint:enable:object-literal-sort-keys + return rippleFactory(this.root_, new _material_ripple_foundation__WEBPACK_IMPORTED_MODULE_8__["MDCRippleFoundation"](adapter)); + }; + return MDCTextField; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/constants.js": +/*!*******************************************************!*\ + !*** ./node_modules/@material/textfield/constants.js ***! + \*******************************************************/ +/*! exports provided: cssClasses, strings, numbers, VALIDATION_ATTR_WHITELIST, ALWAYS_FLOAT_TYPES */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VALIDATION_ATTR_WHITELIST", function() { return VALIDATION_ATTR_WHITELIST; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ALWAYS_FLOAT_TYPES", function() { return ALWAYS_FLOAT_TYPES; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var strings = { + ARIA_CONTROLS: 'aria-controls', + ICON_SELECTOR: '.mdc-text-field__icon', + INPUT_SELECTOR: '.mdc-text-field__input', + LABEL_SELECTOR: '.mdc-floating-label', + LINE_RIPPLE_SELECTOR: '.mdc-line-ripple', + OUTLINE_SELECTOR: '.mdc-notched-outline', +}; +var cssClasses = { + DENSE: 'mdc-text-field--dense', + DISABLED: 'mdc-text-field--disabled', + FOCUSED: 'mdc-text-field--focused', + FULLWIDTH: 'mdc-text-field--fullwidth', + HELPER_LINE: 'mdc-text-field-helper-line', + INVALID: 'mdc-text-field--invalid', + NO_LABEL: 'mdc-text-field--no-label', + OUTLINED: 'mdc-text-field--outlined', + ROOT: 'mdc-text-field', + TEXTAREA: 'mdc-text-field--textarea', + WITH_LEADING_ICON: 'mdc-text-field--with-leading-icon', + WITH_TRAILING_ICON: 'mdc-text-field--with-trailing-icon', +}; +var numbers = { + DENSE_LABEL_SCALE: 0.923, + LABEL_SCALE: 0.75, +}; +/** + * Whitelist based off of https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/HTML5/Constraint_validation + * under the "Validation-related attributes" section. + */ +var VALIDATION_ATTR_WHITELIST = [ + 'pattern', 'min', 'max', 'required', 'step', 'minlength', 'maxlength', +]; +/** + * Label should always float for these types as they show some UI even if value is empty. + */ +var ALWAYS_FLOAT_TYPES = [ + 'color', 'date', 'datetime-local', 'month', 'range', 'time', 'week', +]; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/foundation.js": +/*!********************************************************!*\ + !*** ./node_modules/@material/textfield/foundation.js ***! + \********************************************************/ +/*! exports provided: MDCTextFieldFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldFoundation", function() { return MDCTextFieldFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/constants.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var POINTERDOWN_EVENTS = ['mousedown', 'touchstart']; +var INTERACTION_EVENTS = ['click', 'keydown']; +var MDCTextFieldFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldFoundation, _super); + /** + * @param adapter + * @param foundationMap Map from subcomponent names to their subfoundations. + */ + function MDCTextFieldFoundation(adapter, foundationMap) { + if (foundationMap === void 0) { foundationMap = {}; } + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldFoundation.defaultAdapter, adapter)) || this; + _this.isFocused_ = false; + _this.receivedUserInput_ = false; + _this.isValid_ = true; + _this.useNativeValidation_ = true; + _this.helperText_ = foundationMap.helperText; + _this.characterCounter_ = foundationMap.characterCounter; + _this.leadingIcon_ = foundationMap.leadingIcon; + _this.trailingIcon_ = foundationMap.trailingIcon; + _this.inputFocusHandler_ = function () { return _this.activateFocus(); }; + _this.inputBlurHandler_ = function () { return _this.deactivateFocus(); }; + _this.inputInputHandler_ = function () { return _this.handleInput(); }; + _this.setPointerXOffset_ = function (evt) { return _this.setTransformOrigin(evt); }; + _this.textFieldInteractionHandler_ = function () { return _this.handleTextFieldInteraction(); }; + _this.validationAttributeChangeHandler_ = function (attributesList) { return _this.handleValidationAttributeChange(attributesList); }; + return _this; + } + Object.defineProperty(MDCTextFieldFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation.prototype, "shouldAlwaysFloat_", { + get: function () { + var type = this.getNativeInput_().type; + return _constants__WEBPACK_IMPORTED_MODULE_2__["ALWAYS_FLOAT_TYPES"].indexOf(type) >= 0; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation.prototype, "shouldFloat", { + get: function () { + return this.shouldAlwaysFloat_ || this.isFocused_ || Boolean(this.getValue()) || this.isBadInput_(); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation.prototype, "shouldShake", { + get: function () { + return !this.isFocused_ && !this.isValid() && Boolean(this.getValue()); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return true; }, + registerTextFieldInteractionHandler: function () { return undefined; }, + deregisterTextFieldInteractionHandler: function () { return undefined; }, + registerInputInteractionHandler: function () { return undefined; }, + deregisterInputInteractionHandler: function () { return undefined; }, + registerValidationAttributeChangeHandler: function () { return new MutationObserver(function () { return undefined; }); }, + deregisterValidationAttributeChangeHandler: function () { return undefined; }, + getNativeInput: function () { return null; }, + isFocused: function () { return false; }, + activateLineRipple: function () { return undefined; }, + deactivateLineRipple: function () { return undefined; }, + setLineRippleTransformOrigin: function () { return undefined; }, + shakeLabel: function () { return undefined; }, + floatLabel: function () { return undefined; }, + hasLabel: function () { return false; }, + getLabelWidth: function () { return 0; }, + hasOutline: function () { return false; }, + notchOutline: function () { return undefined; }, + closeOutline: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCTextFieldFoundation.prototype.init = function () { + var _this = this; + if (this.adapter_.isFocused()) { + this.inputFocusHandler_(); + } + else if (this.adapter_.hasLabel() && this.shouldFloat) { + this.notchOutline(true); + this.adapter_.floatLabel(true); + } + this.adapter_.registerInputInteractionHandler('focus', this.inputFocusHandler_); + this.adapter_.registerInputInteractionHandler('blur', this.inputBlurHandler_); + this.adapter_.registerInputInteractionHandler('input', this.inputInputHandler_); + POINTERDOWN_EVENTS.forEach(function (evtType) { + _this.adapter_.registerInputInteractionHandler(evtType, _this.setPointerXOffset_); + }); + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.registerTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_); + }); + this.validationObserver_ = + this.adapter_.registerValidationAttributeChangeHandler(this.validationAttributeChangeHandler_); + this.setCharacterCounter_(this.getValue().length); + }; + MDCTextFieldFoundation.prototype.destroy = function () { + var _this = this; + this.adapter_.deregisterInputInteractionHandler('focus', this.inputFocusHandler_); + this.adapter_.deregisterInputInteractionHandler('blur', this.inputBlurHandler_); + this.adapter_.deregisterInputInteractionHandler('input', this.inputInputHandler_); + POINTERDOWN_EVENTS.forEach(function (evtType) { + _this.adapter_.deregisterInputInteractionHandler(evtType, _this.setPointerXOffset_); + }); + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.deregisterTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_); + }); + this.adapter_.deregisterValidationAttributeChangeHandler(this.validationObserver_); + }; + /** + * Handles user interactions with the Text Field. + */ + MDCTextFieldFoundation.prototype.handleTextFieldInteraction = function () { + var nativeInput = this.adapter_.getNativeInput(); + if (nativeInput && nativeInput.disabled) { + return; + } + this.receivedUserInput_ = true; + }; + /** + * Handles validation attribute changes + */ + MDCTextFieldFoundation.prototype.handleValidationAttributeChange = function (attributesList) { + var _this = this; + attributesList.some(function (attributeName) { + if (_constants__WEBPACK_IMPORTED_MODULE_2__["VALIDATION_ATTR_WHITELIST"].indexOf(attributeName) > -1) { + _this.styleValidity_(true); + return true; + } + return false; + }); + if (attributesList.indexOf('maxlength') > -1) { + this.setCharacterCounter_(this.getValue().length); + } + }; + /** + * Opens/closes the notched outline. + */ + MDCTextFieldFoundation.prototype.notchOutline = function (openNotch) { + if (!this.adapter_.hasOutline()) { + return; + } + if (openNotch) { + var isDense = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].DENSE); + var labelScale = isDense ? _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].DENSE_LABEL_SCALE : _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].LABEL_SCALE; + var labelWidth = this.adapter_.getLabelWidth() * labelScale; + this.adapter_.notchOutline(labelWidth); + } + else { + this.adapter_.closeOutline(); + } + }; + /** + * Activates the text field focus state. + */ + MDCTextFieldFoundation.prototype.activateFocus = function () { + this.isFocused_ = true; + this.styleFocused_(this.isFocused_); + this.adapter_.activateLineRipple(); + if (this.adapter_.hasLabel()) { + this.notchOutline(this.shouldFloat); + this.adapter_.floatLabel(this.shouldFloat); + this.adapter_.shakeLabel(this.shouldShake); + } + if (this.helperText_) { + this.helperText_.showToScreenReader(); + } + }; + /** + * Sets the line ripple's transform origin, so that the line ripple activate + * animation will animate out from the user's click location. + */ + MDCTextFieldFoundation.prototype.setTransformOrigin = function (evt) { + var touches = evt.touches; + var targetEvent = touches ? touches[0] : evt; + var targetClientRect = targetEvent.target.getBoundingClientRect(); + var normalizedX = targetEvent.clientX - targetClientRect.left; + this.adapter_.setLineRippleTransformOrigin(normalizedX); + }; + /** + * Handles input change of text input and text area. + */ + MDCTextFieldFoundation.prototype.handleInput = function () { + this.autoCompleteFocus(); + this.setCharacterCounter_(this.getValue().length); + }; + /** + * Activates the Text Field's focus state in cases when the input value + * changes without user input (e.g. programmatically). + */ + MDCTextFieldFoundation.prototype.autoCompleteFocus = function () { + if (!this.receivedUserInput_) { + this.activateFocus(); + } + }; + /** + * Deactivates the Text Field's focus state. + */ + MDCTextFieldFoundation.prototype.deactivateFocus = function () { + this.isFocused_ = false; + this.adapter_.deactivateLineRipple(); + var isValid = this.isValid(); + this.styleValidity_(isValid); + this.styleFocused_(this.isFocused_); + if (this.adapter_.hasLabel()) { + this.notchOutline(this.shouldFloat); + this.adapter_.floatLabel(this.shouldFloat); + this.adapter_.shakeLabel(this.shouldShake); + } + if (!this.shouldFloat) { + this.receivedUserInput_ = false; + } + }; + MDCTextFieldFoundation.prototype.getValue = function () { + return this.getNativeInput_().value; + }; + /** + * @param value The value to set on the input Element. + */ + MDCTextFieldFoundation.prototype.setValue = function (value) { + // Prevent Safari from moving the caret to the end of the input when the value has not changed. + if (this.getValue() !== value) { + this.getNativeInput_().value = value; + } + this.setCharacterCounter_(value.length); + var isValid = this.isValid(); + this.styleValidity_(isValid); + if (this.adapter_.hasLabel()) { + this.notchOutline(this.shouldFloat); + this.adapter_.floatLabel(this.shouldFloat); + this.adapter_.shakeLabel(this.shouldShake); + } + }; + /** + * @return The custom validity state, if set; otherwise, the result of a native validity check. + */ + MDCTextFieldFoundation.prototype.isValid = function () { + return this.useNativeValidation_ + ? this.isNativeInputValid_() : this.isValid_; + }; + /** + * @param isValid Sets the custom validity state of the Text Field. + */ + MDCTextFieldFoundation.prototype.setValid = function (isValid) { + this.isValid_ = isValid; + this.styleValidity_(isValid); + var shouldShake = !isValid && !this.isFocused_; + if (this.adapter_.hasLabel()) { + this.adapter_.shakeLabel(shouldShake); + } + }; + /** + * Enables or disables the use of native validation. Use this for custom validation. + * @param useNativeValidation Set this to false to ignore native input validation. + */ + MDCTextFieldFoundation.prototype.setUseNativeValidation = function (useNativeValidation) { + this.useNativeValidation_ = useNativeValidation; + }; + MDCTextFieldFoundation.prototype.isDisabled = function () { + return this.getNativeInput_().disabled; + }; + /** + * @param disabled Sets the text-field disabled or enabled. + */ + MDCTextFieldFoundation.prototype.setDisabled = function (disabled) { + this.getNativeInput_().disabled = disabled; + this.styleDisabled_(disabled); + }; + /** + * @param content Sets the content of the helper text. + */ + MDCTextFieldFoundation.prototype.setHelperTextContent = function (content) { + if (this.helperText_) { + this.helperText_.setContent(content); + } + }; + /** + * Sets the aria label of the leading icon. + */ + MDCTextFieldFoundation.prototype.setLeadingIconAriaLabel = function (label) { + if (this.leadingIcon_) { + this.leadingIcon_.setAriaLabel(label); + } + }; + /** + * Sets the text content of the leading icon. + */ + MDCTextFieldFoundation.prototype.setLeadingIconContent = function (content) { + if (this.leadingIcon_) { + this.leadingIcon_.setContent(content); + } + }; + /** + * Sets the aria label of the trailing icon. + */ + MDCTextFieldFoundation.prototype.setTrailingIconAriaLabel = function (label) { + if (this.trailingIcon_) { + this.trailingIcon_.setAriaLabel(label); + } + }; + /** + * Sets the text content of the trailing icon. + */ + MDCTextFieldFoundation.prototype.setTrailingIconContent = function (content) { + if (this.trailingIcon_) { + this.trailingIcon_.setContent(content); + } + }; + /** + * Sets character counter values that shows characters used and the total character limit. + */ + MDCTextFieldFoundation.prototype.setCharacterCounter_ = function (currentLength) { + if (!this.characterCounter_) { + return; + } + var maxLength = this.getNativeInput_().maxLength; + if (maxLength === -1) { + throw new Error('MDCTextFieldFoundation: Expected maxlength html property on text input or textarea.'); + } + this.characterCounter_.setCounterValue(currentLength, maxLength); + }; + /** + * @return True if the Text Field input fails in converting the user-supplied value. + */ + MDCTextFieldFoundation.prototype.isBadInput_ = function () { + // The badInput property is not supported in IE 11 💩. + return this.getNativeInput_().validity.badInput || false; + }; + /** + * @return The result of native validity checking (ValidityState.valid). + */ + MDCTextFieldFoundation.prototype.isNativeInputValid_ = function () { + return this.getNativeInput_().validity.valid; + }; + /** + * Styles the component based on the validity state. + */ + MDCTextFieldFoundation.prototype.styleValidity_ = function (isValid) { + var INVALID = MDCTextFieldFoundation.cssClasses.INVALID; + if (isValid) { + this.adapter_.removeClass(INVALID); + } + else { + this.adapter_.addClass(INVALID); + } + if (this.helperText_) { + this.helperText_.setValidity(isValid); + } + }; + /** + * Styles the component based on the focused state. + */ + MDCTextFieldFoundation.prototype.styleFocused_ = function (isFocused) { + var FOCUSED = MDCTextFieldFoundation.cssClasses.FOCUSED; + if (isFocused) { + this.adapter_.addClass(FOCUSED); + } + else { + this.adapter_.removeClass(FOCUSED); + } + }; + /** + * Styles the component based on the disabled state. + */ + MDCTextFieldFoundation.prototype.styleDisabled_ = function (isDisabled) { + var _a = MDCTextFieldFoundation.cssClasses, DISABLED = _a.DISABLED, INVALID = _a.INVALID; + if (isDisabled) { + this.adapter_.addClass(DISABLED); + this.adapter_.removeClass(INVALID); + } + else { + this.adapter_.removeClass(DISABLED); + } + if (this.leadingIcon_) { + this.leadingIcon_.setDisabled(isDisabled); + } + if (this.trailingIcon_) { + this.trailingIcon_.setDisabled(isDisabled); + } + }; + /** + * @return The native text input element from the host environment, or an object with the same shape for unit tests. + */ + MDCTextFieldFoundation.prototype.getNativeInput_ = function () { + // this.adapter_ may be undefined in foundation unit tests. This happens when testdouble is creating a mock object + // and invokes the shouldShake/shouldFloat getters (which in turn call getValue(), which calls this method) before + // init() has been called from the MDCTextField constructor. To work around that issue, we return a dummy object. + var nativeInput = this.adapter_ ? this.adapter_.getNativeInput() : null; + return nativeInput || { + disabled: false, + maxLength: -1, + type: 'input', + validity: { + badInput: false, + valid: true, + }, + value: '', + }; + }; + return MDCTextFieldFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/component.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/component.js ***! + \*******************************************************************/ +/*! exports provided: MDCTextFieldHelperText */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperText", function() { return MDCTextFieldHelperText; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/helper-text/foundation.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldHelperText = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldHelperText, _super); + function MDCTextFieldHelperText() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextFieldHelperText.attachTo = function (root) { + return new MDCTextFieldHelperText(root); + }; + Object.defineProperty(MDCTextFieldHelperText.prototype, "foundation", { + get: function () { + return this.foundation_; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldHelperText.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + hasClass: function (className) { return _this.root_.classList.contains(className); }, + setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); }, + removeAttr: function (attr) { return _this.root_.removeAttribute(attr); }, + setContent: function (content) { + _this.root_.textContent = content; + }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldHelperTextFoundation"](adapter); + }; + return MDCTextFieldHelperText; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/constants.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/constants.js ***! + \*******************************************************************/ +/*! exports provided: strings, cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + HELPER_TEXT_PERSISTENT: 'mdc-text-field-helper-text--persistent', + HELPER_TEXT_VALIDATION_MSG: 'mdc-text-field-helper-text--validation-msg', + ROOT: 'mdc-text-field-helper-text', +}; +var strings = { + ARIA_HIDDEN: 'aria-hidden', + ROLE: 'role', + ROOT_SELECTOR: "." + cssClasses.ROOT, +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/foundation.js": +/*!********************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/foundation.js ***! + \********************************************************************/ +/*! exports provided: MDCTextFieldHelperTextFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperTextFoundation", function() { return MDCTextFieldHelperTextFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/helper-text/constants.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldHelperTextFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldHelperTextFoundation, _super); + function MDCTextFieldHelperTextFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldHelperTextFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCTextFieldHelperTextFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldHelperTextFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldHelperTextFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldHelperTextAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return false; }, + setAttr: function () { return undefined; }, + removeAttr: function () { return undefined; }, + setContent: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + /** + * Sets the content of the helper text field. + */ + MDCTextFieldHelperTextFoundation.prototype.setContent = function (content) { + this.adapter_.setContent(content); + }; + /** + * @param isPersistent Sets the persistency of the helper text. + */ + MDCTextFieldHelperTextFoundation.prototype.setPersistent = function (isPersistent) { + if (isPersistent) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_PERSISTENT); + } + else { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_PERSISTENT); + } + }; + /** + * @param isValidation True to make the helper text act as an error validation message. + */ + MDCTextFieldHelperTextFoundation.prototype.setValidation = function (isValidation) { + if (isValidation) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_VALIDATION_MSG); + } + else { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_VALIDATION_MSG); + } + }; + /** + * Makes the helper text visible to the screen reader. + */ + MDCTextFieldHelperTextFoundation.prototype.showToScreenReader = function () { + this.adapter_.removeAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ARIA_HIDDEN); + }; + /** + * Sets the validity of the helper text based on the input validity. + */ + MDCTextFieldHelperTextFoundation.prototype.setValidity = function (inputIsValid) { + var helperTextIsPersistent = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_PERSISTENT); + var helperTextIsValidationMsg = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_VALIDATION_MSG); + var validationMsgNeedsDisplay = helperTextIsValidationMsg && !inputIsValid; + if (validationMsgNeedsDisplay) { + this.adapter_.setAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ROLE, 'alert'); + } + else { + this.adapter_.removeAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ROLE); + } + if (!helperTextIsPersistent && !validationMsgNeedsDisplay) { + this.hide_(); + } + }; + /** + * Hides the help text from screen readers. + */ + MDCTextFieldHelperTextFoundation.prototype.hide_ = function () { + this.adapter_.setAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ARIA_HIDDEN, 'true'); + }; + return MDCTextFieldHelperTextFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldHelperTextFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/index.js": +/*!***************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/index.js ***! + \***************************************************************/ +/*! exports provided: helperTextCssClasses, helperTextStrings, MDCTextFieldHelperText, MDCTextFieldHelperTextFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/helper-text/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperText", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextFieldHelperText"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/helper-text/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperTextFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCTextFieldHelperTextFoundation"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/helper-text/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextCssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextStrings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/component.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/textfield/icon/component.js ***! + \************************************************************/ +/*! exports provided: MDCTextFieldIcon */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIcon", function() { return MDCTextFieldIcon; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/icon/foundation.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldIcon = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldIcon, _super); + function MDCTextFieldIcon() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextFieldIcon.attachTo = function (root) { + return new MDCTextFieldIcon(root); + }; + Object.defineProperty(MDCTextFieldIcon.prototype, "foundation", { + get: function () { + return this.foundation_; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldIcon.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + getAttr: function (attr) { return _this.root_.getAttribute(attr); }, + setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); }, + removeAttr: function (attr) { return _this.root_.removeAttribute(attr); }, + setContent: function (content) { + _this.root_.textContent = content; + }, + registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + notifyIconAction: function () { return _this.emit(_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldIconFoundation"].strings.ICON_EVENT, {} /* evtData */, true /* shouldBubble */); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldIconFoundation"](adapter); + }; + return MDCTextFieldIcon; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/constants.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/textfield/icon/constants.js ***! + \************************************************************/ +/*! exports provided: strings, cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var strings = { + ICON_EVENT: 'MDCTextField:icon', + ICON_ROLE: 'button', +}; +var cssClasses = { + ROOT: 'mdc-text-field__icon', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/foundation.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/textfield/icon/foundation.js ***! + \*************************************************************/ +/*! exports provided: MDCTextFieldIconFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIconFoundation", function() { return MDCTextFieldIconFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/icon/constants.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var INTERACTION_EVENTS = ['click', 'keydown']; +var MDCTextFieldIconFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldIconFoundation, _super); + function MDCTextFieldIconFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldIconFoundation.defaultAdapter, adapter)) || this; + _this.savedTabIndex_ = null; + _this.interactionHandler_ = function (evt) { return _this.handleInteraction(evt); }; + return _this; + } + Object.defineProperty(MDCTextFieldIconFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldIconFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldIconFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldIconAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + getAttr: function () { return null; }, + setAttr: function () { return undefined; }, + removeAttr: function () { return undefined; }, + setContent: function () { return undefined; }, + registerInteractionHandler: function () { return undefined; }, + deregisterInteractionHandler: function () { return undefined; }, + notifyIconAction: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCTextFieldIconFoundation.prototype.init = function () { + var _this = this; + this.savedTabIndex_ = this.adapter_.getAttr('tabindex'); + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.registerInteractionHandler(evtType, _this.interactionHandler_); + }); + }; + MDCTextFieldIconFoundation.prototype.destroy = function () { + var _this = this; + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.deregisterInteractionHandler(evtType, _this.interactionHandler_); + }); + }; + MDCTextFieldIconFoundation.prototype.setDisabled = function (disabled) { + if (!this.savedTabIndex_) { + return; + } + if (disabled) { + this.adapter_.setAttr('tabindex', '-1'); + this.adapter_.removeAttr('role'); + } + else { + this.adapter_.setAttr('tabindex', this.savedTabIndex_); + this.adapter_.setAttr('role', _constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ICON_ROLE); + } + }; + MDCTextFieldIconFoundation.prototype.setAriaLabel = function (label) { + this.adapter_.setAttr('aria-label', label); + }; + MDCTextFieldIconFoundation.prototype.setContent = function (content) { + this.adapter_.setContent(content); + }; + MDCTextFieldIconFoundation.prototype.handleInteraction = function (evt) { + var isEnterKey = evt.key === 'Enter' || evt.keyCode === 13; + if (evt.type === 'click' || isEnterKey) { + this.adapter_.notifyIconAction(); + } + }; + return MDCTextFieldIconFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldIconFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/index.js": +/*!********************************************************!*\ + !*** ./node_modules/@material/textfield/icon/index.js ***! + \********************************************************/ +/*! exports provided: iconCssClasses, iconStrings, MDCTextFieldIcon, MDCTextFieldIconFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/icon/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIcon", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextFieldIcon"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/icon/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIconFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCTextFieldIconFoundation"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/icon/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconCssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconStrings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/index.js": +/*!***************************************************!*\ + !*** ./node_modules/@material/textfield/index.js ***! + \***************************************************/ +/*! exports provided: MDCTextField, cssClasses, strings, numbers, VALIDATION_ATTR_WHITELIST, ALWAYS_FLOAT_TYPES, MDCTextFieldFoundation, characterCountCssClasses, characterCountStrings, helperTextCssClasses, helperTextStrings, iconCssClasses, iconStrings, MDCTextFieldCharacterCounter, MDCTextFieldCharacterCounterFoundation, MDCTextFieldHelperText, MDCTextFieldHelperTextFoundation, MDCTextFieldIcon, MDCTextFieldIconFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextField", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextField"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["strings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VALIDATION_ATTR_WHITELIST", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["VALIDATION_ATTR_WHITELIST"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ALWAYS_FLOAT_TYPES", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["ALWAYS_FLOAT_TYPES"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldFoundation"]; }); + +/* harmony import */ var _character_counter_index__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./character-counter/index */ "./node_modules/@material/textfield/character-counter/index.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountCssClasses", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["characterCountCssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountStrings", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["characterCountStrings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounter", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["MDCTextFieldCharacterCounter"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounterFoundation", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["MDCTextFieldCharacterCounterFoundation"]; }); + +/* harmony import */ var _helper_text_index__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./helper-text/index */ "./node_modules/@material/textfield/helper-text/index.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextCssClasses", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["helperTextCssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextStrings", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["helperTextStrings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperText", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["MDCTextFieldHelperText"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperTextFoundation", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["MDCTextFieldHelperTextFoundation"]; }); + +/* harmony import */ var _icon_index__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./icon/index */ "./node_modules/@material/textfield/icon/index.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconCssClasses", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["iconCssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconStrings", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["iconStrings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIcon", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["MDCTextFieldIcon"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIconFoundation", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["MDCTextFieldIconFoundation"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/component.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/top-app-bar/component.js ***! + \*********************************************************/ +/*! exports provided: MDCTopAppBar */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBar", function() { return MDCTopAppBar; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_ripple_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/ripple/component */ "./node_modules/@material/ripple/component.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _fixed_foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./fixed/foundation */ "./node_modules/@material/top-app-bar/fixed/foundation.js"); +/* harmony import */ var _short_foundation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./short/foundation */ "./node_modules/@material/top-app-bar/short/foundation.js"); +/* harmony import */ var _standard_foundation__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./standard/foundation */ "./node_modules/@material/top-app-bar/standard/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + + +var MDCTopAppBar = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTopAppBar, _super); + function MDCTopAppBar() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTopAppBar.attachTo = function (root) { + return new MDCTopAppBar(root); + }; + MDCTopAppBar.prototype.initialize = function (rippleFactory) { + if (rippleFactory === void 0) { rippleFactory = function (el) { return _material_ripple_component__WEBPACK_IMPORTED_MODULE_2__["MDCRipple"].attachTo(el); }; } + this.navIcon_ = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].NAVIGATION_ICON_SELECTOR); + // Get all icons in the toolbar and instantiate the ripples + var icons = [].slice.call(this.root_.querySelectorAll(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].ACTION_ITEM_SELECTOR)); + if (this.navIcon_) { + icons.push(this.navIcon_); + } + this.iconRipples_ = icons.map(function (icon) { + var ripple = rippleFactory(icon); + ripple.unbounded = true; + return ripple; + }); + this.scrollTarget_ = window; + }; + MDCTopAppBar.prototype.initialSyncWithDOM = function () { + this.handleNavigationClick_ = this.foundation_.handleNavigationClick.bind(this.foundation_); + this.handleWindowResize_ = this.foundation_.handleWindowResize.bind(this.foundation_); + this.handleTargetScroll_ = this.foundation_.handleTargetScroll.bind(this.foundation_); + this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_); + if (this.navIcon_) { + this.navIcon_.addEventListener('click', this.handleNavigationClick_); + } + var isFixed = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].FIXED_CLASS); + var isShort = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].SHORT_CLASS); + if (!isShort && !isFixed) { + window.addEventListener('resize', this.handleWindowResize_); + } + }; + MDCTopAppBar.prototype.destroy = function () { + this.iconRipples_.forEach(function (iconRipple) { return iconRipple.destroy(); }); + this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_); + if (this.navIcon_) { + this.navIcon_.removeEventListener('click', this.handleNavigationClick_); + } + var isFixed = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].FIXED_CLASS); + var isShort = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].SHORT_CLASS); + if (!isShort && !isFixed) { + window.removeEventListener('resize', this.handleWindowResize_); + } + _super.prototype.destroy.call(this); + }; + MDCTopAppBar.prototype.setScrollTarget = function (target) { + // Remove scroll handler from the previous scroll target + this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_); + this.scrollTarget_ = target; + // Initialize scroll handler on the new scroll target + this.handleTargetScroll_ = + this.foundation_.handleTargetScroll.bind(this.foundation_); + this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_); + }; + MDCTopAppBar.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + hasClass: function (className) { return _this.root_.classList.contains(className); }, + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + setStyle: function (property, value) { return _this.root_.style.setProperty(property, value); }, + getTopAppBarHeight: function () { return _this.root_.clientHeight; }, + notifyNavigationIconClicked: function () { return _this.emit(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].NAVIGATION_EVENT, {}); }, + getViewportScrollY: function () { + var win = _this.scrollTarget_; + var el = _this.scrollTarget_; + return win.pageYOffset !== undefined ? win.pageYOffset : el.scrollTop; + }, + getTotalActionItems: function () { return _this.root_.querySelectorAll(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].ACTION_ITEM_SELECTOR).length; }, + }; + // tslint:enable:object-literal-sort-keys + var foundation; + if (this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].SHORT_CLASS)) { + foundation = new _short_foundation__WEBPACK_IMPORTED_MODULE_5__["MDCShortTopAppBarFoundation"](adapter); + } + else if (this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].FIXED_CLASS)) { + foundation = new _fixed_foundation__WEBPACK_IMPORTED_MODULE_4__["MDCFixedTopAppBarFoundation"](adapter); + } + else { + foundation = new _standard_foundation__WEBPACK_IMPORTED_MODULE_6__["MDCTopAppBarFoundation"](adapter); + } + return foundation; + }; + return MDCTopAppBar; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/constants.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/top-app-bar/constants.js ***! + \*********************************************************/ +/*! exports provided: cssClasses, numbers, strings */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + FIXED_CLASS: 'mdc-top-app-bar--fixed', + FIXED_SCROLLED_CLASS: 'mdc-top-app-bar--fixed-scrolled', + SHORT_CLASS: 'mdc-top-app-bar--short', + SHORT_COLLAPSED_CLASS: 'mdc-top-app-bar--short-collapsed', + SHORT_HAS_ACTION_ITEM_CLASS: 'mdc-top-app-bar--short-has-action-item', +}; +var numbers = { + DEBOUNCE_THROTTLE_RESIZE_TIME_MS: 100, + MAX_TOP_APP_BAR_HEIGHT: 128, +}; +var strings = { + ACTION_ITEM_SELECTOR: '.mdc-top-app-bar__action-item', + NAVIGATION_EVENT: 'MDCTopAppBar:nav', + NAVIGATION_ICON_SELECTOR: '.mdc-top-app-bar__navigation-icon', + ROOT_SELECTOR: '.mdc-top-app-bar', + TITLE_SELECTOR: '.mdc-top-app-bar__title', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/fixed/foundation.js": +/*!****************************************************************!*\ + !*** ./node_modules/@material/top-app-bar/fixed/foundation.js ***! + \****************************************************************/ +/*! exports provided: MDCFixedTopAppBarFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFixedTopAppBarFoundation", function() { return MDCFixedTopAppBarFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _standard_foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../standard/foundation */ "./node_modules/@material/top-app-bar/standard/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCFixedTopAppBarFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCFixedTopAppBarFoundation, _super); + function MDCFixedTopAppBarFoundation() { + var _this = _super !== null && _super.apply(this, arguments) || this; + /** + * State variable for the previous scroll iteration top app bar state + */ + _this.wasScrolled_ = false; + return _this; + } + /** + * Scroll handler for applying/removing the modifier class on the fixed top app bar. + * @override + */ + MDCFixedTopAppBarFoundation.prototype.handleTargetScroll = function () { + var currentScroll = this.adapter_.getViewportScrollY(); + if (currentScroll <= 0) { + if (this.wasScrolled_) { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].FIXED_SCROLLED_CLASS); + this.wasScrolled_ = false; + } + } + else { + if (!this.wasScrolled_) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].FIXED_SCROLLED_CLASS); + this.wasScrolled_ = true; + } + } + }; + return MDCFixedTopAppBarFoundation; +}(_standard_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCFixedTopAppBarFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/foundation.js": +/*!**********************************************************!*\ + !*** ./node_modules/@material/top-app-bar/foundation.js ***! + \**********************************************************/ +/*! exports provided: MDCTopAppBarBaseFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarBaseFoundation", function() { return MDCTopAppBarBaseFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/top-app-bar/constants.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTopAppBarBaseFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTopAppBarBaseFoundation, _super); + /* istanbul ignore next: optional argument is not a branch statement */ + function MDCTopAppBarBaseFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTopAppBarBaseFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCTopAppBarBaseFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTopAppBarBaseFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTopAppBarBaseFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTopAppBarBaseFoundation, "defaultAdapter", { + /** + * See {@link MDCTopAppBarAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return false; }, + setStyle: function () { return undefined; }, + getTopAppBarHeight: function () { return 0; }, + notifyNavigationIconClicked: function () { return undefined; }, + getViewportScrollY: function () { return 0; }, + getTotalActionItems: function () { return 0; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + /** Other variants of TopAppBar foundation overrides this method */ + MDCTopAppBarBaseFoundation.prototype.handleTargetScroll = function () { }; // tslint:disable-line:no-empty + /** Other variants of TopAppBar foundation overrides this method */ + MDCTopAppBarBaseFoundation.prototype.handleWindowResize = function () { }; // tslint:disable-line:no-empty + MDCTopAppBarBaseFoundation.prototype.handleNavigationClick = function () { + this.adapter_.notifyNavigationIconClicked(); + }; + return MDCTopAppBarBaseFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTopAppBarBaseFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/index.js": +/*!*****************************************************!*\ + !*** ./node_modules/@material/top-app-bar/index.js ***! + \*****************************************************/ +/*! exports provided: MDCTopAppBar, cssClasses, numbers, strings, MDCTopAppBarBaseFoundation, MDCFixedTopAppBarFoundation, MDCShortTopAppBarFoundation, MDCTopAppBarFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/top-app-bar/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBar", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTopAppBar"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["strings"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/top-app-bar/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarBaseFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarBaseFoundation"]; }); + +/* harmony import */ var _fixed_foundation__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./fixed/foundation */ "./node_modules/@material/top-app-bar/fixed/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCFixedTopAppBarFoundation", function() { return _fixed_foundation__WEBPACK_IMPORTED_MODULE_3__["MDCFixedTopAppBarFoundation"]; }); + +/* harmony import */ var _short_foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./short/foundation */ "./node_modules/@material/top-app-bar/short/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCShortTopAppBarFoundation", function() { return _short_foundation__WEBPACK_IMPORTED_MODULE_4__["MDCShortTopAppBarFoundation"]; }); + +/* harmony import */ var _standard_foundation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./standard/foundation */ "./node_modules/@material/top-app-bar/standard/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarFoundation", function() { return _standard_foundation__WEBPACK_IMPORTED_MODULE_5__["MDCTopAppBarFoundation"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/short/foundation.js": +/*!****************************************************************!*\ + !*** ./node_modules/@material/top-app-bar/short/foundation.js ***! + \****************************************************************/ +/*! exports provided: MDCShortTopAppBarFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCShortTopAppBarFoundation", function() { return MDCShortTopAppBarFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../foundation */ "./node_modules/@material/top-app-bar/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCShortTopAppBarFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCShortTopAppBarFoundation, _super); + /* istanbul ignore next: optional argument is not a branch statement */ + function MDCShortTopAppBarFoundation(adapter) { + var _this = _super.call(this, adapter) || this; + _this.isCollapsed_ = false; + _this.isAlwaysCollapsed_ = false; + return _this; + } + Object.defineProperty(MDCShortTopAppBarFoundation.prototype, "isCollapsed", { + // Public visibility for backward compatibility. + get: function () { + return this.isCollapsed_; + }, + enumerable: true, + configurable: true + }); + MDCShortTopAppBarFoundation.prototype.init = function () { + _super.prototype.init.call(this); + if (this.adapter_.getTotalActionItems() > 0) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_HAS_ACTION_ITEM_CLASS); + } + // If initialized with SHORT_COLLAPSED_CLASS, the bar should always be collapsed + this.setAlwaysCollapsed(this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_COLLAPSED_CLASS)); + }; + /** + * Set if the short top app bar should always be collapsed. + * + * @param value When `true`, bar will always be collapsed. When `false`, bar may collapse or expand based on scroll. + */ + MDCShortTopAppBarFoundation.prototype.setAlwaysCollapsed = function (value) { + this.isAlwaysCollapsed_ = !!value; + if (this.isAlwaysCollapsed_) { + this.collapse_(); + } + else { + // let maybeCollapseBar_ determine if the bar should be collapsed + this.maybeCollapseBar_(); + } + }; + MDCShortTopAppBarFoundation.prototype.getAlwaysCollapsed = function () { + return this.isAlwaysCollapsed_; + }; + /** + * Scroll handler for applying/removing the collapsed modifier class on the short top app bar. + * @override + */ + MDCShortTopAppBarFoundation.prototype.handleTargetScroll = function () { + this.maybeCollapseBar_(); + }; + MDCShortTopAppBarFoundation.prototype.maybeCollapseBar_ = function () { + if (this.isAlwaysCollapsed_) { + return; + } + var currentScroll = this.adapter_.getViewportScrollY(); + if (currentScroll <= 0) { + if (this.isCollapsed_) { + this.uncollapse_(); + } + } + else { + if (!this.isCollapsed_) { + this.collapse_(); + } + } + }; + MDCShortTopAppBarFoundation.prototype.uncollapse_ = function () { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_COLLAPSED_CLASS); + this.isCollapsed_ = false; + }; + MDCShortTopAppBarFoundation.prototype.collapse_ = function () { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_COLLAPSED_CLASS); + this.isCollapsed_ = true; + }; + return MDCShortTopAppBarFoundation; +}(_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarBaseFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCShortTopAppBarFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/standard/foundation.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@material/top-app-bar/standard/foundation.js ***! + \*******************************************************************/ +/*! exports provided: MDCTopAppBarFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarFoundation", function() { return MDCTopAppBarFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../foundation */ "./node_modules/@material/top-app-bar/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var INITIAL_VALUE = 0; +var MDCTopAppBarFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTopAppBarFoundation, _super); + /* istanbul ignore next: optional argument is not a branch statement */ + function MDCTopAppBarFoundation(adapter) { + var _this = _super.call(this, adapter) || this; + /** + * Indicates if the top app bar was docked in the previous scroll handler iteration. + */ + _this.wasDocked_ = true; + /** + * Indicates if the top app bar is docked in the fully shown position. + */ + _this.isDockedShowing_ = true; + /** + * Variable for current scroll position of the top app bar + */ + _this.currentAppBarOffsetTop_ = 0; + /** + * Used to prevent the top app bar from being scrolled out of view during resize events + */ + _this.isCurrentlyBeingResized_ = false; + /** + * The timeout that's used to throttle the resize events + */ + _this.resizeThrottleId_ = INITIAL_VALUE; + /** + * The timeout that's used to debounce toggling the isCurrentlyBeingResized_ variable after a resize + */ + _this.resizeDebounceId_ = INITIAL_VALUE; + _this.lastScrollPosition_ = _this.adapter_.getViewportScrollY(); + _this.topAppBarHeight_ = _this.adapter_.getTopAppBarHeight(); + return _this; + } + MDCTopAppBarFoundation.prototype.destroy = function () { + _super.prototype.destroy.call(this); + this.adapter_.setStyle('top', ''); + }; + /** + * Scroll handler for the default scroll behavior of the top app bar. + * @override + */ + MDCTopAppBarFoundation.prototype.handleTargetScroll = function () { + var currentScrollPosition = Math.max(this.adapter_.getViewportScrollY(), 0); + var diff = currentScrollPosition - this.lastScrollPosition_; + this.lastScrollPosition_ = currentScrollPosition; + // If the window is being resized the lastScrollPosition_ needs to be updated but the + // current scroll of the top app bar should stay in the same position. + if (!this.isCurrentlyBeingResized_) { + this.currentAppBarOffsetTop_ -= diff; + if (this.currentAppBarOffsetTop_ > 0) { + this.currentAppBarOffsetTop_ = 0; + } + else if (Math.abs(this.currentAppBarOffsetTop_) > this.topAppBarHeight_) { + this.currentAppBarOffsetTop_ = -this.topAppBarHeight_; + } + this.moveTopAppBar_(); + } + }; + /** + * Top app bar resize handler that throttle/debounce functions that execute updates. + * @override + */ + MDCTopAppBarFoundation.prototype.handleWindowResize = function () { + var _this = this; + // Throttle resize events 10 p/s + if (!this.resizeThrottleId_) { + this.resizeThrottleId_ = setTimeout(function () { + _this.resizeThrottleId_ = INITIAL_VALUE; + _this.throttledResizeHandler_(); + }, _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"].DEBOUNCE_THROTTLE_RESIZE_TIME_MS); + } + this.isCurrentlyBeingResized_ = true; + if (this.resizeDebounceId_) { + clearTimeout(this.resizeDebounceId_); + } + this.resizeDebounceId_ = setTimeout(function () { + _this.handleTargetScroll(); + _this.isCurrentlyBeingResized_ = false; + _this.resizeDebounceId_ = INITIAL_VALUE; + }, _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"].DEBOUNCE_THROTTLE_RESIZE_TIME_MS); + }; + /** + * Function to determine if the DOM needs to update. + */ + MDCTopAppBarFoundation.prototype.checkForUpdate_ = function () { + var offscreenBoundaryTop = -this.topAppBarHeight_; + var hasAnyPixelsOffscreen = this.currentAppBarOffsetTop_ < 0; + var hasAnyPixelsOnscreen = this.currentAppBarOffsetTop_ > offscreenBoundaryTop; + var partiallyShowing = hasAnyPixelsOffscreen && hasAnyPixelsOnscreen; + // If it's partially showing, it can't be docked. + if (partiallyShowing) { + this.wasDocked_ = false; + } + else { + // Not previously docked and not partially showing, it's now docked. + if (!this.wasDocked_) { + this.wasDocked_ = true; + return true; + } + else if (this.isDockedShowing_ !== hasAnyPixelsOnscreen) { + this.isDockedShowing_ = hasAnyPixelsOnscreen; + return true; + } + } + return partiallyShowing; + }; + /** + * Function to move the top app bar if needed. + */ + MDCTopAppBarFoundation.prototype.moveTopAppBar_ = function () { + if (this.checkForUpdate_()) { + // Once the top app bar is fully hidden we use the max potential top app bar height as our offset + // so the top app bar doesn't show if the window resizes and the new height > the old height. + var offset = this.currentAppBarOffsetTop_; + if (Math.abs(offset) >= this.topAppBarHeight_) { + offset = -_constants__WEBPACK_IMPORTED_MODULE_1__["numbers"].MAX_TOP_APP_BAR_HEIGHT; + } + this.adapter_.setStyle('top', offset + 'px'); + } + }; + /** + * Throttled function that updates the top app bar scrolled values if the + * top app bar height changes. + */ + MDCTopAppBarFoundation.prototype.throttledResizeHandler_ = function () { + var currentHeight = this.adapter_.getTopAppBarHeight(); + if (this.topAppBarHeight_ !== currentHeight) { + this.wasDocked_ = false; + // Since the top app bar has a different height depending on the screen width, this + // will ensure that the top app bar remains in the correct location if + // completely hidden and a resize makes the top app bar a different height. + this.currentAppBarOffsetTop_ -= this.topAppBarHeight_ - currentHeight; + this.topAppBarHeight_ = currentHeight; + } + this.handleTargetScroll(); + }; + return MDCTopAppBarFoundation; +}(_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarBaseFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTopAppBarFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/parallax-js/dist/parallax.js": +/*!***************************************************!*\ + !*** ./node_modules/parallax-js/dist/parallax.js ***! + \***************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(global) {var require;var require;(function(f){if(true){module.exports=f()}else { var g; }})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return require(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o 1) { + for (var i = 1; i < arguments.length; i++) { + args[i - 1] = arguments[i]; + } + } + queue.push(new Item(fun, args)); + if (queue.length === 1 && !draining) { + runTimeout(drainQueue); + } +}; + +// v8 likes predictible objects +function Item(fun, array) { + this.fun = fun; + this.array = array; +} +Item.prototype.run = function () { + this.fun.apply(null, this.array); +}; +process.title = 'browser'; +process.browser = true; +process.env = {}; +process.argv = []; +process.version = ''; // empty string to avoid regexp issues +process.versions = {}; + +function noop() {} + +process.on = noop; +process.addListener = noop; +process.once = noop; +process.off = noop; +process.removeListener = noop; +process.removeAllListeners = noop; +process.emit = noop; +process.prependListener = noop; +process.prependOnceListener = noop; + +process.listeners = function (name) { return [] } + +process.binding = function (name) { + throw new Error('process.binding is not supported'); +}; + +process.cwd = function () { return '/' }; +process.chdir = function (dir) { + throw new Error('process.chdir is not supported'); +}; +process.umask = function() { return 0; }; + +},{}],4:[function(require,module,exports){ +(function (global){ +var now = require('performance-now') + , root = typeof window === 'undefined' ? global : window + , vendors = ['moz', 'webkit'] + , suffix = 'AnimationFrame' + , raf = root['request' + suffix] + , caf = root['cancel' + suffix] || root['cancelRequest' + suffix] + +for(var i = 0; !raf && i < vendors.length; i++) { + raf = root[vendors[i] + 'Request' + suffix] + caf = root[vendors[i] + 'Cancel' + suffix] + || root[vendors[i] + 'CancelRequest' + suffix] +} + +// Some versions of FF have rAF but not cAF +if(!raf || !caf) { + var last = 0 + , id = 0 + , queue = [] + , frameDuration = 1000 / 60 + + raf = function(callback) { + if(queue.length === 0) { + var _now = now() + , next = Math.max(0, frameDuration - (_now - last)) + last = next + _now + setTimeout(function() { + var cp = queue.slice(0) + // Clear queue here to prevent + // callbacks from appending listeners + // to the current frame's queue + queue.length = 0 + for(var i = 0; i < cp.length; i++) { + if(!cp[i].cancelled) { + try{ + cp[i].callback(last) + } catch(e) { + setTimeout(function() { throw e }, 0) + } + } + } + }, Math.round(next)) + } + queue.push({ + handle: ++id, + callback: callback, + cancelled: false + }) + return id + } + + caf = function(handle) { + for(var i = 0; i < queue.length; i++) { + if(queue[i].handle === handle) { + queue[i].cancelled = true + } + } + } +} + +module.exports = function(fn) { + // Wrap in a new function to prevent + // `cancel` potentially being assigned + // to the native rAF function + return raf.call(root, fn) +} +module.exports.cancel = function() { + caf.apply(root, arguments) +} +module.exports.polyfill = function() { + root.requestAnimationFrame = raf + root.cancelAnimationFrame = caf +} + +}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) + +},{"performance-now":2}],5:[function(require,module,exports){ +'use strict'; + +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +/** +* Parallax.js +* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org +* @description Creates a parallax effect between an array of layers, +* driving the motion from the gyroscope output of a smartdevice. +* If no gyroscope is available, the cursor position is used. +*/ + +var rqAnFr = require('raf'); +var objectAssign = require('object-assign'); + +var helpers = { + propertyCache: {}, + vendors: [null, ['-webkit-', 'webkit'], ['-moz-', 'Moz'], ['-o-', 'O'], ['-ms-', 'ms']], + + clamp: function clamp(value, min, max) { + return min < max ? value < min ? min : value > max ? max : value : value < max ? max : value > min ? min : value; + }, + data: function data(element, name) { + return helpers.deserialize(element.getAttribute('data-' + name)); + }, + deserialize: function deserialize(value) { + if (value === 'true') { + return true; + } else if (value === 'false') { + return false; + } else if (value === 'null') { + return null; + } else if (!isNaN(parseFloat(value)) && isFinite(value)) { + return parseFloat(value); + } else { + return value; + } + }, + camelCase: function camelCase(value) { + return value.replace(/-+(.)?/g, function (match, character) { + return character ? character.toUpperCase() : ''; + }); + }, + accelerate: function accelerate(element) { + helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)'); + helpers.css(element, 'transform-style', 'preserve-3d'); + helpers.css(element, 'backface-visibility', 'hidden'); + }, + transformSupport: function transformSupport(value) { + var element = document.createElement('div'), + propertySupport = false, + propertyValue = null, + featureSupport = false, + cssProperty = null, + jsProperty = null; + for (var i = 0, l = helpers.vendors.length; i < l; i++) { + if (helpers.vendors[i] !== null) { + cssProperty = helpers.vendors[i][0] + 'transform'; + jsProperty = helpers.vendors[i][1] + 'Transform'; + } else { + cssProperty = 'transform'; + jsProperty = 'transform'; + } + if (element.style[jsProperty] !== undefined) { + propertySupport = true; + break; + } + } + switch (value) { + case '2D': + featureSupport = propertySupport; + break; + case '3D': + if (propertySupport) { + var body = document.body || document.createElement('body'), + documentElement = document.documentElement, + documentOverflow = documentElement.style.overflow, + isCreatedBody = false; + + if (!document.body) { + isCreatedBody = true; + documentElement.style.overflow = 'hidden'; + documentElement.appendChild(body); + body.style.overflow = 'hidden'; + body.style.background = ''; + } + + body.appendChild(element); + element.style[jsProperty] = 'translate3d(1px,1px,1px)'; + propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty); + featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none'; + documentElement.style.overflow = documentOverflow; + body.removeChild(element); + + if (isCreatedBody) { + body.removeAttribute('style'); + body.parentNode.removeChild(body); + } + } + break; + } + return featureSupport; + }, + css: function css(element, property, value) { + var jsProperty = helpers.propertyCache[property]; + if (!jsProperty) { + for (var i = 0, l = helpers.vendors.length; i < l; i++) { + if (helpers.vendors[i] !== null) { + jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property); + } else { + jsProperty = property; + } + if (element.style[jsProperty] !== undefined) { + helpers.propertyCache[property] = jsProperty; + break; + } + } + } + element.style[jsProperty] = value; + } +}; + +var MAGIC_NUMBER = 30, + DEFAULTS = { + relativeInput: false, + clipRelativeInput: false, + inputElement: null, + hoverOnly: false, + calibrationThreshold: 100, + calibrationDelay: 500, + supportDelay: 500, + calibrateX: false, + calibrateY: true, + invertX: true, + invertY: true, + limitX: false, + limitY: false, + scalarX: 10.0, + scalarY: 10.0, + frictionX: 0.1, + frictionY: 0.1, + originX: 0.5, + originY: 0.5, + pointerEvents: false, + precision: 1, + onReady: null, + selector: null +}; + +var Parallax = function () { + function Parallax(element, options) { + _classCallCheck(this, Parallax); + + this.element = element; + + var data = { + calibrateX: helpers.data(this.element, 'calibrate-x'), + calibrateY: helpers.data(this.element, 'calibrate-y'), + invertX: helpers.data(this.element, 'invert-x'), + invertY: helpers.data(this.element, 'invert-y'), + limitX: helpers.data(this.element, 'limit-x'), + limitY: helpers.data(this.element, 'limit-y'), + scalarX: helpers.data(this.element, 'scalar-x'), + scalarY: helpers.data(this.element, 'scalar-y'), + frictionX: helpers.data(this.element, 'friction-x'), + frictionY: helpers.data(this.element, 'friction-y'), + originX: helpers.data(this.element, 'origin-x'), + originY: helpers.data(this.element, 'origin-y'), + pointerEvents: helpers.data(this.element, 'pointer-events'), + precision: helpers.data(this.element, 'precision'), + relativeInput: helpers.data(this.element, 'relative-input'), + clipRelativeInput: helpers.data(this.element, 'clip-relative-input'), + hoverOnly: helpers.data(this.element, 'hover-only'), + inputElement: document.querySelector(helpers.data(this.element, 'input-element')), + selector: helpers.data(this.element, 'selector') + }; + + for (var key in data) { + if (data[key] === null) { + delete data[key]; + } + } + + objectAssign(this, DEFAULTS, data, options); + + if (!this.inputElement) { + this.inputElement = this.element; + } + + this.calibrationTimer = null; + this.calibrationFlag = true; + this.enabled = false; + this.depthsX = []; + this.depthsY = []; + this.raf = null; + + this.bounds = null; + this.elementPositionX = 0; + this.elementPositionY = 0; + this.elementWidth = 0; + this.elementHeight = 0; + + this.elementCenterX = 0; + this.elementCenterY = 0; + + this.elementRangeX = 0; + this.elementRangeY = 0; + + this.calibrationX = 0; + this.calibrationY = 0; + + this.inputX = 0; + this.inputY = 0; + + this.motionX = 0; + this.motionY = 0; + + this.velocityX = 0; + this.velocityY = 0; + + this.onMouseMove = this.onMouseMove.bind(this); + this.onDeviceOrientation = this.onDeviceOrientation.bind(this); + this.onDeviceMotion = this.onDeviceMotion.bind(this); + this.onOrientationTimer = this.onOrientationTimer.bind(this); + this.onMotionTimer = this.onMotionTimer.bind(this); + this.onCalibrationTimer = this.onCalibrationTimer.bind(this); + this.onAnimationFrame = this.onAnimationFrame.bind(this); + this.onWindowResize = this.onWindowResize.bind(this); + + this.windowWidth = null; + this.windowHeight = null; + this.windowCenterX = null; + this.windowCenterY = null; + this.windowRadiusX = null; + this.windowRadiusY = null; + this.portrait = false; + this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i); + this.motionSupport = !!window.DeviceMotionEvent && !this.desktop; + this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop; + this.orientationStatus = 0; + this.motionStatus = 0; + + this.initialise(); + } + + _createClass(Parallax, [{ + key: 'initialise', + value: function initialise() { + if (this.transform2DSupport === undefined) { + this.transform2DSupport = helpers.transformSupport('2D'); + this.transform3DSupport = helpers.transformSupport('3D'); + } + + // Configure Context Styles + if (this.transform3DSupport) { + helpers.accelerate(this.element); + } + + var style = window.getComputedStyle(this.element); + if (style.getPropertyValue('position') === 'static') { + this.element.style.position = 'relative'; + } + + // Pointer events + if (!this.pointerEvents) { + this.element.style.pointerEvents = 'none'; + } + + // Setup + this.updateLayers(); + this.updateDimensions(); + this.enable(); + this.queueCalibration(this.calibrationDelay); + } + }, { + key: 'doReadyCallback', + value: function doReadyCallback() { + if (this.onReady) { + this.onReady(); + } + } + }, { + key: 'updateLayers', + value: function updateLayers() { + if (this.selector) { + this.layers = this.element.querySelectorAll(this.selector); + } else { + this.layers = this.element.children; + } + + if (!this.layers.length) { + console.warn('ParallaxJS: Your scene does not have any layers.'); + } + + this.depthsX = []; + this.depthsY = []; + + for (var index = 0; index < this.layers.length; index++) { + var layer = this.layers[index]; + + if (this.transform3DSupport) { + helpers.accelerate(layer); + } + + layer.style.position = index ? 'absolute' : 'relative'; + layer.style.display = 'block'; + layer.style.left = 0; + layer.style.top = 0; + + var depth = helpers.data(layer, 'depth') || 0; + this.depthsX.push(helpers.data(layer, 'depth-x') || depth); + this.depthsY.push(helpers.data(layer, 'depth-y') || depth); + } + } + }, { + key: 'updateDimensions', + value: function updateDimensions() { + this.windowWidth = window.innerWidth; + this.windowHeight = window.innerHeight; + this.windowCenterX = this.windowWidth * this.originX; + this.windowCenterY = this.windowHeight * this.originY; + this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX); + this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY); + } + }, { + key: 'updateBounds', + value: function updateBounds() { + this.bounds = this.inputElement.getBoundingClientRect(); + this.elementPositionX = this.bounds.left; + this.elementPositionY = this.bounds.top; + this.elementWidth = this.bounds.width; + this.elementHeight = this.bounds.height; + this.elementCenterX = this.elementWidth * this.originX; + this.elementCenterY = this.elementHeight * this.originY; + this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX); + this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY); + } + }, { + key: 'queueCalibration', + value: function queueCalibration(delay) { + clearTimeout(this.calibrationTimer); + this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay); + } + }, { + key: 'enable', + value: function enable() { + if (this.enabled) { + return; + } + this.enabled = true; + + if (this.orientationSupport) { + this.portrait = false; + window.addEventListener('deviceorientation', this.onDeviceOrientation); + this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay); + } else if (this.motionSupport) { + this.portrait = false; + window.addEventListener('devicemotion', this.onDeviceMotion); + this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay); + } else { + this.calibrationX = 0; + this.calibrationY = 0; + this.portrait = false; + window.addEventListener('mousemove', this.onMouseMove); + this.doReadyCallback(); + } + + window.addEventListener('resize', this.onWindowResize); + this.raf = rqAnFr(this.onAnimationFrame); + } + }, { + key: 'disable', + value: function disable() { + if (!this.enabled) { + return; + } + this.enabled = false; + + if (this.orientationSupport) { + window.removeEventListener('deviceorientation', this.onDeviceOrientation); + } else if (this.motionSupport) { + window.removeEventListener('devicemotion', this.onDeviceMotion); + } else { + window.removeEventListener('mousemove', this.onMouseMove); + } + + window.removeEventListener('resize', this.onWindowResize); + rqAnFr.cancel(this.raf); + } + }, { + key: 'calibrate', + value: function calibrate(x, y) { + this.calibrateX = x === undefined ? this.calibrateX : x; + this.calibrateY = y === undefined ? this.calibrateY : y; + } + }, { + key: 'invert', + value: function invert(x, y) { + this.invertX = x === undefined ? this.invertX : x; + this.invertY = y === undefined ? this.invertY : y; + } + }, { + key: 'friction', + value: function friction(x, y) { + this.frictionX = x === undefined ? this.frictionX : x; + this.frictionY = y === undefined ? this.frictionY : y; + } + }, { + key: 'scalar', + value: function scalar(x, y) { + this.scalarX = x === undefined ? this.scalarX : x; + this.scalarY = y === undefined ? this.scalarY : y; + } + }, { + key: 'limit', + value: function limit(x, y) { + this.limitX = x === undefined ? this.limitX : x; + this.limitY = y === undefined ? this.limitY : y; + } + }, { + key: 'origin', + value: function origin(x, y) { + this.originX = x === undefined ? this.originX : x; + this.originY = y === undefined ? this.originY : y; + } + }, { + key: 'setInputElement', + value: function setInputElement(element) { + this.inputElement = element; + this.updateDimensions(); + } + }, { + key: 'setPosition', + value: function setPosition(element, x, y) { + x = x.toFixed(this.precision) + 'px'; + y = y.toFixed(this.precision) + 'px'; + if (this.transform3DSupport) { + helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)'); + } else if (this.transform2DSupport) { + helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')'); + } else { + element.style.left = x; + element.style.top = y; + } + } + }, { + key: 'onOrientationTimer', + value: function onOrientationTimer() { + if (this.orientationSupport && this.orientationStatus === 0) { + this.disable(); + this.orientationSupport = false; + this.enable(); + } else { + this.doReadyCallback(); + } + } + }, { + key: 'onMotionTimer', + value: function onMotionTimer() { + if (this.motionSupport && this.motionStatus === 0) { + this.disable(); + this.motionSupport = false; + this.enable(); + } else { + this.doReadyCallback(); + } + } + }, { + key: 'onCalibrationTimer', + value: function onCalibrationTimer() { + this.calibrationFlag = true; + } + }, { + key: 'onWindowResize', + value: function onWindowResize() { + this.updateDimensions(); + } + }, { + key: 'onAnimationFrame', + value: function onAnimationFrame() { + this.updateBounds(); + var calibratedInputX = this.inputX - this.calibrationX, + calibratedInputY = this.inputY - this.calibrationY; + if (Math.abs(calibratedInputX) > this.calibrationThreshold || Math.abs(calibratedInputY) > this.calibrationThreshold) { + this.queueCalibration(0); + } + if (this.portrait) { + this.motionX = this.calibrateX ? calibratedInputY : this.inputY; + this.motionY = this.calibrateY ? calibratedInputX : this.inputX; + } else { + this.motionX = this.calibrateX ? calibratedInputX : this.inputX; + this.motionY = this.calibrateY ? calibratedInputY : this.inputY; + } + this.motionX *= this.elementWidth * (this.scalarX / 100); + this.motionY *= this.elementHeight * (this.scalarY / 100); + if (!isNaN(parseFloat(this.limitX))) { + this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX); + } + if (!isNaN(parseFloat(this.limitY))) { + this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY); + } + this.velocityX += (this.motionX - this.velocityX) * this.frictionX; + this.velocityY += (this.motionY - this.velocityY) * this.frictionY; + for (var index = 0; index < this.layers.length; index++) { + var layer = this.layers[index], + depthX = this.depthsX[index], + depthY = this.depthsY[index], + xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)), + yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1)); + this.setPosition(layer, xOffset, yOffset); + } + this.raf = rqAnFr(this.onAnimationFrame); + } + }, { + key: 'rotate', + value: function rotate(beta, gamma) { + // Extract Rotation + var x = (beta || 0) / MAGIC_NUMBER, + // -90 :: 90 + y = (gamma || 0) / MAGIC_NUMBER; // -180 :: 180 + + // Detect Orientation Change + var portrait = this.windowHeight > this.windowWidth; + if (this.portrait !== portrait) { + this.portrait = portrait; + this.calibrationFlag = true; + } + + if (this.calibrationFlag) { + this.calibrationFlag = false; + this.calibrationX = x; + this.calibrationY = y; + } + + this.inputX = x; + this.inputY = y; + } + }, { + key: 'onDeviceOrientation', + value: function onDeviceOrientation(event) { + var beta = event.beta; + var gamma = event.gamma; + if (beta !== null && gamma !== null) { + this.orientationStatus = 1; + this.rotate(beta, gamma); + } + } + }, { + key: 'onDeviceMotion', + value: function onDeviceMotion(event) { + var beta = event.rotationRate.beta; + var gamma = event.rotationRate.gamma; + if (beta !== null && gamma !== null) { + this.motionStatus = 1; + this.rotate(beta, gamma); + } + } + }, { + key: 'onMouseMove', + value: function onMouseMove(event) { + var clientX = event.clientX, + clientY = event.clientY; + + // reset input to center if hoverOnly is set and we're not hovering the element + if (this.hoverOnly && (clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth || clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight)) { + this.inputX = 0; + this.inputY = 0; + return; + } + + if (this.relativeInput) { + // Clip mouse coordinates inside element bounds. + if (this.clipRelativeInput) { + clientX = Math.max(clientX, this.elementPositionX); + clientX = Math.min(clientX, this.elementPositionX + this.elementWidth); + clientY = Math.max(clientY, this.elementPositionY); + clientY = Math.min(clientY, this.elementPositionY + this.elementHeight); + } + // Calculate input relative to the element. + if (this.elementRangeX && this.elementRangeY) { + this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX; + this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY; + } + } else { + // Calculate input relative to the window. + if (this.windowRadiusX && this.windowRadiusY) { + this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX; + this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY; + } + } + } + }, { + key: 'destroy', + value: function destroy() { + this.disable(); + + clearTimeout(this.calibrationTimer); + clearTimeout(this.detectionTimer); + + this.element.removeAttribute('style'); + for (var index = 0; index < this.layers.length; index++) { + this.layers[index].removeAttribute('style'); + } + + delete this.element; + delete this.layers; + } + }, { + key: 'version', + value: function version() { + return '3.1.0'; + } + }]); + + return Parallax; +}(); + +module.exports = Parallax; + +},{"object-assign":1,"raf":4}]},{},[5])(5) +}); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/object-assign/index.js","node_modules/performance-now/lib/performance-now.js","node_modules/process/browser.js","node_modules/raf/index.js","src/parallax.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACxLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACxEA;;;;;;;;AAQA,IAAM,SAAS,QAAQ,KAAR,CAAf;AACA,IAAM,eAAe,QAAQ,eAAR,CAArB;;AAEA,IAAM,UAAU;AACd,iBAAe,EADD;AAEd,WAAS,CAAC,IAAD,EAAO,CAAC,UAAD,EAAY,QAAZ,CAAP,EAA8B,CAAC,OAAD,EAAS,KAAT,CAA9B,EAA+C,CAAC,KAAD,EAAO,GAAP,CAA/C,EAA4D,CAAC,MAAD,EAAQ,IAAR,CAA5D,CAFK;;AAId,OAJc,iBAIR,KAJQ,EAID,GAJC,EAII,GAJJ,EAIS;AACrB,WAAO,MAAM,GAAN,GACF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,KADtC,GAEF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,K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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated by CoffeeScript 1.12.2\n(function() {\n  var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - nodeLoadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    moduleLoadTime = getNanoSeconds();\n    upTime = process.uptime() * 1e9;\n    nodeLoadTime = moduleLoadTime - upTime;\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n\n//# sourceMappingURL=performance-now.js.map\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","var now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n","/**\n* Parallax.js\n* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org\n* @description Creates a parallax effect between an array of layers,\n*              driving the motion from the gyroscope output of a smartdevice.\n*              If no gyroscope is available, the cursor position is used.\n*/\n\nconst rqAnFr = require('raf')\nconst objectAssign = require('object-assign')\n\nconst helpers = {\n  propertyCache: {},\n  vendors: [null, ['-webkit-','webkit'], ['-moz-','Moz'], ['-o-','O'], ['-ms-','ms']],\n\n  clamp(value, min, max) {\n    return min < max\n      ? (value < min ? min : value > max ? max : value)\n      : (value < max ? max : value > min ? min : value)\n  },\n\n  data(element, name) {\n    return helpers.deserialize(element.getAttribute('data-'+name))\n  },\n\n  deserialize(value) {\n    if (value === 'true') {\n      return true\n    } else if (value === 'false') {\n      return false\n    } else if (value === 'null') {\n      return null\n    } else if (!isNaN(parseFloat(value)) && isFinite(value)) {\n      return parseFloat(value)\n    } else {\n      return value\n    }\n  },\n\n  camelCase(value) {\n    return value.replace(/-+(.)?/g, (match, character) => {\n      return character ? character.toUpperCase() : ''\n    })\n  },\n\n  accelerate(element) {\n    helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)')\n    helpers.css(element, 'transform-style', 'preserve-3d')\n    helpers.css(element, 'backface-visibility', 'hidden')\n  },\n\n  transformSupport(value) {\n    let element = document.createElement('div'),\n        propertySupport = false,\n        propertyValue = null,\n        featureSupport = false,\n        cssProperty = null,\n        jsProperty = null\n    for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n      if (helpers.vendors[i] !== null) {\n        cssProperty = helpers.vendors[i][0] + 'transform'\n        jsProperty = helpers.vendors[i][1] + 'Transform'\n      } else {\n        cssProperty = 'transform'\n        jsProperty = 'transform'\n      }\n      if (element.style[jsProperty] !== undefined) {\n        propertySupport = true\n        break\n      }\n    }\n    switch(value) {\n      case '2D':\n        featureSupport = propertySupport\n        break\n      case '3D':\n        if (propertySupport) {\n          let body = document.body || document.createElement('body'),\n              documentElement = document.documentElement,\n              documentOverflow = documentElement.style.overflow,\n              isCreatedBody = false\n\n          if (!document.body) {\n            isCreatedBody = true\n            documentElement.style.overflow = 'hidden'\n            documentElement.appendChild(body)\n            body.style.overflow = 'hidden'\n            body.style.background = ''\n          }\n\n          body.appendChild(element)\n          element.style[jsProperty] = 'translate3d(1px,1px,1px)'\n          propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty)\n          featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none'\n          documentElement.style.overflow = documentOverflow\n          body.removeChild(element)\n\n          if ( isCreatedBody ) {\n            body.removeAttribute('style')\n            body.parentNode.removeChild(body)\n          }\n        }\n        break\n    }\n    return featureSupport\n  },\n\n  css(element, property, value) {\n    let jsProperty = helpers.propertyCache[property]\n    if (!jsProperty) {\n      for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n        if (helpers.vendors[i] !== null) {\n          jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property)\n        } else {\n          jsProperty = property\n        }\n        if (element.style[jsProperty] !== undefined) {\n          helpers.propertyCache[property] = jsProperty\n          break\n        }\n      }\n    }\n    element.style[jsProperty] = value\n  }\n\n}\n\nconst MAGIC_NUMBER = 30,\n      DEFAULTS = {\n        relativeInput: false,\n        clipRelativeInput: false,\n        inputElement: null,\n        hoverOnly: false,\n        calibrationThreshold: 100,\n        calibrationDelay: 500,\n        supportDelay: 500,\n        calibrateX: false,\n        calibrateY: true,\n        invertX: true,\n        invertY: true,\n        limitX: false,\n        limitY: false,\n        scalarX: 10.0,\n        scalarY: 10.0,\n        frictionX: 0.1,\n        frictionY: 0.1,\n        originX: 0.5,\n        originY: 0.5,\n        pointerEvents: false,\n        precision: 1,\n        onReady: null,\n        selector: null\n      }\n\nclass Parallax {\n  constructor(element, options) {\n\n    this.element = element\n\n    const data = {\n      calibrateX: helpers.data(this.element, 'calibrate-x'),\n      calibrateY: helpers.data(this.element, 'calibrate-y'),\n      invertX: helpers.data(this.element, 'invert-x'),\n      invertY: helpers.data(this.element, 'invert-y'),\n      limitX: helpers.data(this.element, 'limit-x'),\n      limitY: helpers.data(this.element, 'limit-y'),\n      scalarX: helpers.data(this.element, 'scalar-x'),\n      scalarY: helpers.data(this.element, 'scalar-y'),\n      frictionX: helpers.data(this.element, 'friction-x'),\n      frictionY: helpers.data(this.element, 'friction-y'),\n      originX: helpers.data(this.element, 'origin-x'),\n      originY: helpers.data(this.element, 'origin-y'),\n      pointerEvents: helpers.data(this.element, 'pointer-events'),\n      precision: helpers.data(this.element, 'precision'),\n      relativeInput: helpers.data(this.element, 'relative-input'),\n      clipRelativeInput: helpers.data(this.element, 'clip-relative-input'),\n      hoverOnly: helpers.data(this.element, 'hover-only'),\n      inputElement: document.querySelector(helpers.data(this.element, 'input-element')),\n      selector: helpers.data(this.element, 'selector')\n    }\n\n    for (let key in data) {\n      if (data[key] === null) {\n        delete data[key]\n      }\n    }\n\n    objectAssign(this, DEFAULTS, data, options)\n\n    if(!this.inputElement) {\n      this.inputElement = this.element\n    }\n\n    this.calibrationTimer = null\n    this.calibrationFlag = true\n    this.enabled = false\n    this.depthsX = []\n    this.depthsY = []\n    this.raf = null\n\n    this.bounds = null\n    this.elementPositionX = 0\n    this.elementPositionY = 0\n    this.elementWidth = 0\n    this.elementHeight = 0\n\n    this.elementCenterX = 0\n    this.elementCenterY = 0\n\n    this.elementRangeX = 0\n    this.elementRangeY = 0\n\n    this.calibrationX = 0\n    this.calibrationY = 0\n\n    this.inputX = 0\n    this.inputY = 0\n\n    this.motionX = 0\n    this.motionY = 0\n\n    this.velocityX = 0\n    this.velocityY = 0\n\n    this.onMouseMove = this.onMouseMove.bind(this)\n    this.onDeviceOrientation = this.onDeviceOrientation.bind(this)\n    this.onDeviceMotion = this.onDeviceMotion.bind(this)\n    this.onOrientationTimer = this.onOrientationTimer.bind(this)\n    this.onMotionTimer = this.onMotionTimer.bind(this)\n    this.onCalibrationTimer = this.onCalibrationTimer.bind(this)\n    this.onAnimationFrame = this.onAnimationFrame.bind(this)\n    this.onWindowResize = this.onWindowResize.bind(this)\n\n    this.windowWidth = null\n    this.windowHeight = null\n    this.windowCenterX = null\n    this.windowCenterY = null\n    this.windowRadiusX = null\n    this.windowRadiusY = null\n    this.portrait = false\n    this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i)\n    this.motionSupport = !!window.DeviceMotionEvent && !this.desktop\n    this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop\n    this.orientationStatus = 0\n    this.motionStatus = 0\n\n    this.initialise()\n  }\n\n  initialise() {\n    if (this.transform2DSupport === undefined) {\n      this.transform2DSupport = helpers.transformSupport('2D')\n      this.transform3DSupport = helpers.transformSupport('3D')\n    }\n\n    // Configure Context Styles\n    if (this.transform3DSupport) {\n      helpers.accelerate(this.element)\n    }\n\n    let style = window.getComputedStyle(this.element)\n    if (style.getPropertyValue('position') === 'static') {\n      this.element.style.position = 'relative'\n    }\n\n    // Pointer events\n    if(!this.pointerEvents) {\n      this.element.style.pointerEvents = 'none'\n    }\n\n    // Setup\n    this.updateLayers()\n    this.updateDimensions()\n    this.enable()\n    this.queueCalibration(this.calibrationDelay)\n  }\n\n  doReadyCallback() {\n    if(this.onReady) {\n      this.onReady()\n    }\n  }\n\n  updateLayers() {\n    if(this.selector) {\n      this.layers = this.element.querySelectorAll(this.selector)\n    } else {\n      this.layers = this.element.children\n    }\n\n    if(!this.layers.length) {\n      console.warn('ParallaxJS: Your scene does not have any layers.')\n    }\n\n    this.depthsX = []\n    this.depthsY = []\n\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index]\n\n      if (this.transform3DSupport) {\n        helpers.accelerate(layer)\n      }\n\n      layer.style.position = index ? 'absolute' : 'relative'\n      layer.style.display = 'block'\n      layer.style.left = 0\n      layer.style.top = 0\n\n      let depth = helpers.data(layer, 'depth') || 0\n      this.depthsX.push(helpers.data(layer, 'depth-x') || depth)\n      this.depthsY.push(helpers.data(layer, 'depth-y') || depth)\n    }\n  }\n\n  updateDimensions() {\n    this.windowWidth = window.innerWidth\n    this.windowHeight = window.innerHeight\n    this.windowCenterX = this.windowWidth * this.originX\n    this.windowCenterY = this.windowHeight * this.originY\n    this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX)\n    this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY)\n  }\n\n  updateBounds() {\n    this.bounds = this.inputElement.getBoundingClientRect()\n    this.elementPositionX = this.bounds.left\n    this.elementPositionY = this.bounds.top\n    this.elementWidth = this.bounds.width\n    this.elementHeight = this.bounds.height\n    this.elementCenterX = this.elementWidth * this.originX\n    this.elementCenterY = this.elementHeight * this.originY\n    this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX)\n    this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY)\n  }\n\n  queueCalibration(delay) {\n    clearTimeout(this.calibrationTimer)\n    this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay)\n  }\n\n  enable() {\n    if (this.enabled) {\n      return\n    }\n    this.enabled = true\n\n    if (this.orientationSupport) {\n      this.portrait = false\n      window.addEventListener('deviceorientation', this.onDeviceOrientation)\n      this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay)\n    } else if (this.motionSupport) {\n      this.portrait = false\n      window.addEventListener('devicemotion', this.onDeviceMotion)\n      this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay)\n    } else {\n      this.calibrationX = 0\n      this.calibrationY = 0\n      this.portrait = false\n      window.addEventListener('mousemove', this.onMouseMove)\n      this.doReadyCallback()\n    }\n\n    window.addEventListener('resize', this.onWindowResize)\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  disable() {\n    if (!this.enabled) {\n      return\n    }\n    this.enabled = false\n\n    if (this.orientationSupport) {\n      window.removeEventListener('deviceorientation', this.onDeviceOrientation)\n    } else if (this.motionSupport) {\n      window.removeEventListener('devicemotion', this.onDeviceMotion)\n    } else {\n      window.removeEventListener('mousemove', this.onMouseMove)\n    }\n\n    window.removeEventListener('resize', this.onWindowResize)\n    rqAnFr.cancel(this.raf)\n  }\n\n  calibrate(x, y) {\n    this.calibrateX = x === undefined ? this.calibrateX : x\n    this.calibrateY = y === undefined ? this.calibrateY : y\n  }\n\n  invert(x, y) {\n    this.invertX = x === undefined ? this.invertX : x\n    this.invertY = y === undefined ? this.invertY : y\n  }\n\n  friction(x, y) {\n    this.frictionX = x === undefined ? this.frictionX : x\n    this.frictionY = y === undefined ? this.frictionY : y\n  }\n\n  scalar(x, y) {\n    this.scalarX = x === undefined ? this.scalarX : x\n    this.scalarY = y === undefined ? this.scalarY : y\n  }\n\n  limit(x, y) {\n    this.limitX = x === undefined ? this.limitX : x\n    this.limitY = y === undefined ? this.limitY : y\n  }\n\n  origin(x, y) {\n    this.originX = x === undefined ? this.originX : x\n    this.originY = y === undefined ? this.originY : y\n  }\n\n  setInputElement(element) {\n    this.inputElement = element\n    this.updateDimensions()\n  }\n\n  setPosition(element, x, y) {\n    x = x.toFixed(this.precision) + 'px'\n    y = y.toFixed(this.precision) + 'px'\n    if (this.transform3DSupport) {\n      helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)')\n    } else if (this.transform2DSupport) {\n      helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')')\n    } else {\n      element.style.left = x\n      element.style.top = y\n    }\n  }\n\n  onOrientationTimer() {\n    if (this.orientationSupport && this.orientationStatus === 0) {\n      this.disable()\n      this.orientationSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onMotionTimer() {\n    if (this.motionSupport && this.motionStatus === 0) {\n      this.disable()\n      this.motionSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onCalibrationTimer() {\n    this.calibrationFlag = true\n  }\n\n  onWindowResize() {\n    this.updateDimensions()\n  }\n\n  onAnimationFrame() {\n    this.updateBounds()\n    let calibratedInputX = this.inputX - this.calibrationX,\n        calibratedInputY = this.inputY - this.calibrationY\n    if ((Math.abs(calibratedInputX) > this.calibrationThreshold) || (Math.abs(calibratedInputY) > this.calibrationThreshold)) {\n      this.queueCalibration(0)\n    }\n    if (this.portrait) {\n      this.motionX = this.calibrateX ? calibratedInputY : this.inputY\n      this.motionY = this.calibrateY ? calibratedInputX : this.inputX\n    } else {\n      this.motionX = this.calibrateX ? calibratedInputX : this.inputX\n      this.motionY = this.calibrateY ? calibratedInputY : this.inputY\n    }\n    this.motionX *= this.elementWidth * (this.scalarX / 100)\n    this.motionY *= this.elementHeight * (this.scalarY / 100)\n    if (!isNaN(parseFloat(this.limitX))) {\n      this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX)\n    }\n    if (!isNaN(parseFloat(this.limitY))) {\n      this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY)\n    }\n    this.velocityX += (this.motionX - this.velocityX) * this.frictionX\n    this.velocityY += (this.motionY - this.velocityY) * this.frictionY\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index],\n          depthX = this.depthsX[index],\n          depthY = this.depthsY[index],\n          xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)),\n          yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1))\n      this.setPosition(layer, xOffset, yOffset)\n    }\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  rotate(beta, gamma){\n    // Extract Rotation\n    let x = (beta || 0) / MAGIC_NUMBER, //  -90 :: 90\n        y = (gamma || 0) / MAGIC_NUMBER // -180 :: 180\n\n    // Detect Orientation Change\n    let portrait = this.windowHeight > this.windowWidth\n    if (this.portrait !== portrait) {\n      this.portrait = portrait\n      this.calibrationFlag = true\n    }\n\n    if (this.calibrationFlag) {\n      this.calibrationFlag = false\n      this.calibrationX = x\n      this.calibrationY = y\n    }\n\n    this.inputX = x\n    this.inputY = y\n  }\n\n  onDeviceOrientation(event) {\n    let beta = event.beta\n    let gamma = event.gamma\n    if (beta !== null && gamma !== null) {\n      this.orientationStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onDeviceMotion(event) {\n    let beta = event.rotationRate.beta\n    let gamma = event.rotationRate.gamma\n    if (beta !== null && gamma !== null) {\n      this.motionStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onMouseMove(event) {\n    let clientX = event.clientX,\n        clientY = event.clientY\n\n    // reset input to center if hoverOnly is set and we're not hovering the element\n    if(this.hoverOnly &&\n      ((clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth) ||\n      (clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight))) {\n        this.inputX = 0\n        this.inputY = 0\n        return\n      }\n\n    if (this.relativeInput) {\n      // Clip mouse coordinates inside element bounds.\n      if (this.clipRelativeInput) {\n        clientX = Math.max(clientX, this.elementPositionX)\n        clientX = Math.min(clientX, this.elementPositionX + this.elementWidth)\n        clientY = Math.max(clientY, this.elementPositionY)\n        clientY = Math.min(clientY, this.elementPositionY + this.elementHeight)\n      }\n      // Calculate input relative to the element.\n      if(this.elementRangeX && this.elementRangeY) {\n        this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX\n        this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY\n      }\n    } else {\n      // Calculate input relative to the window.\n      if(this.windowRadiusX && this.windowRadiusY) {\n        this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX\n        this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY\n      }\n    }\n  }\n\n  destroy() {\n    this.disable()\n\n    clearTimeout(this.calibrationTimer)\n    clearTimeout(this.detectionTimer)\n\n    this.element.removeAttribute('style')\n    for (let index = 0; index < this.layers.length; index++) {\n      this.layers[index].removeAttribute('style')\n    }\n\n    delete this.element\n    delete this.layers\n  }\n\n  version() {\n    return '3.1.0'\n  }\n\n}\n\nmodule.exports = Parallax\n"]} + +/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../webpack/buildin/global.js */ "./node_modules/webpack/buildin/global.js"))) + +/***/ }), + +/***/ "./node_modules/tslib/tslib.es6.js": +/*!*****************************************!*\ + !*** ./node_modules/tslib/tslib.es6.js ***! + \*****************************************/ +/*! exports provided: __extends, __assign, __rest, __decorate, __param, __metadata, __awaiter, __generator, __exportStar, __values, __read, __spread, __spreadArrays, __await, __asyncGenerator, __asyncDelegator, __asyncValues, __makeTemplateObject, __importStar, __importDefault */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__extends", function() { return __extends; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__assign", function() { return __assign; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__rest", function() { return __rest; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__decorate", function() { return __decorate; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__param", function() { return __param; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__metadata", function() { return __metadata; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__awaiter", function() { return __awaiter; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__generator", function() { return __generator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__exportStar", function() { return __exportStar; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__values", function() { return __values; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__read", function() { return __read; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__spread", function() { return __spread; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__spreadArrays", function() { return __spreadArrays; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__await", function() { return __await; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncGenerator", function() { return __asyncGenerator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncDelegator", function() { return __asyncDelegator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncValues", function() { return __asyncValues; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__makeTemplateObject", function() { return __makeTemplateObject; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__importStar", function() { return __importStar; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__importDefault", function() { return __importDefault; }); +/*! ***************************************************************************** +Copyright (c) Microsoft Corporation. All rights reserved. +Licensed under the Apache License, Version 2.0 (the "License"); you may not use +this file except in compliance with the License. You may obtain a copy of the +License at http://www.apache.org/licenses/LICENSE-2.0 + +THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED +WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, +MERCHANTABLITY OR NON-INFRINGEMENT. + +See the Apache Version 2.0 License for specific language governing permissions +and limitations under the License. +***************************************************************************** */ +/* global Reflect, Promise */ + +var extendStatics = function(d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); +}; + +function __extends(d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); +} + +var __assign = function() { + __assign = Object.assign || function __assign(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + } + return __assign.apply(this, arguments); +} + +function __rest(s, e) { + var t = {}; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) + t[p] = s[p]; + if (s != null && typeof Object.getOwnPropertySymbols === "function") + for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { + if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) + t[p[i]] = s[p[i]]; + } + return t; +} + +function __decorate(decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +} + +function __param(paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +} + +function __metadata(metadataKey, metadataValue) { + if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); +} + +function __awaiter(thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +} + +function __generator(thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +} + +function __exportStar(m, exports) { + for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; +} + +function __values(o) { + var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; + if (m) return m.call(o); + return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; + } + }; +} + +function __read(o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +} + +function __spread() { + for (var ar = [], i = 0; i < arguments.length; i++) + ar = ar.concat(__read(arguments[i])); + return ar; +} + +function __spreadArrays() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; +}; + +function __await(v) { + return this instanceof __await ? (this.v = v, this) : new __await(v); +} + +function __asyncGenerator(thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; + function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +} + +function __asyncDelegator(o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; } +} + +function __asyncValues(o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +} + +function __makeTemplateObject(cooked, raw) { + if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } + return cooked; +}; + +function __importStar(mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; + result.default = mod; + return result; +} + +function __importDefault(mod) { + return (mod && mod.__esModule) ? mod : { default: mod }; +} + + +/***/ }), + +/***/ "./node_modules/webpack/buildin/global.js": +/*!***********************************!*\ + !*** (webpack)/buildin/global.js ***! + \***********************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +var g; + +// This works in non-strict mode +g = (function() { + return this; +})(); + +try { + // This works if eval is allowed (see CSP) + g = g || new Function("return this")(); +} catch (e) { + // This works if the window reference is available + if (typeof window === "object") g = window; +} + +// g can still be undefined, but nothing to do about it... +// We return undefined, instead of nothing here, so it's +// easier to handle this case. if(!global) { ...} + +module.exports = g; + + +/***/ }), + +/***/ "./src/scss/index.scss": +/*!*****************************!*\ + !*** ./src/scss/index.scss ***! + \*****************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +module.exports = __webpack_require__.p + "bundle.css"; + +/***/ }), + +/***/ "./src/ts/components/mdcConf.ts": +/*!**************************************!*\ + !*** ./src/ts/components/mdcConf.ts ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _material_ripple__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @material/ripple */ "./node_modules/@material/ripple/index.js"); +/* harmony import */ var _material_textfield__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/textfield */ "./node_modules/@material/textfield/index.js"); +/* harmony import */ var _material_top_app_bar__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/top-app-bar */ "./node_modules/@material/top-app-bar/index.js"); +/** + * Copyright 2019 Mashiro + * @description material-components initial configuration + * @author Mashiro + * @license MIT + */ + + + +const Conf = [['.mdc-top-app-bar', _material_top_app_bar__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBar"]], ['.mdc-text-field', _material_textfield__WEBPACK_IMPORTED_MODULE_1__["MDCTextField"]], [['.mdc-button', '.primary-action'], _material_ripple__WEBPACK_IMPORTED_MODULE_0__["MDCRipple"]]]; +/* harmony default export */ __webpack_exports__["default"] = (Conf); + +/***/ }), + +/***/ "./src/ts/components/mdcInit.ts": +/*!**************************************!*\ + !*** ./src/ts/components/mdcInit.ts ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _mdcConf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./mdcConf */ "./src/ts/components/mdcConf.ts"); +/** + * Copyright 2019 Mashiro + * @description material-components initial handler + * @author Mashiro + * @license MIT + */ + +const Conf = _mdcConf__WEBPACK_IMPORTED_MODULE_0__["default"]; +/** + * Initial [material-components-web](https://github.com/material-components/material-components-web/) + * through configuration in `mdcConf.ts``. + * See + */ + +/* harmony default export */ __webpack_exports__["default"] = (function () { + let components = []; + + for (const i of Conf) { + if (typeof i[0] == 'string') { + const component = i[0]; + const constructor = i[1]; + components.map.call(document.querySelectorAll(component), function (e) { + return new constructor(e); + }); + } else if (typeof i[0] == 'object') { + const component = i[0].join(','); + const constructor = i[1]; + components.map.call(document.querySelectorAll(component), function (e) { + return new constructor(e); + }); + } + } +}); + +/***/ }), + +/***/ "./src/ts/index.ts": +/*!*************************!*\ + !*** ./src/ts/index.ts ***! + \*************************/ +/*! no exports provided */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _modules_coverImgInit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./modules/coverImgInit */ "./src/ts/modules/coverImgInit.ts"); +/* harmony import */ var _modules_headerBarScrollHandler__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./modules/headerBarScrollHandler */ "./src/ts/modules/headerBarScrollHandler.ts"); +/* harmony import */ var _components_mdcInit__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./components/mdcInit */ "./src/ts/components/mdcInit.ts"); +/** + * Copyright 2019 Mashiro + * @description Main + * @author Mashiro + * @license MIT + */ + + + + +window.onscroll = function () { + Object(_modules_headerBarScrollHandler__WEBPACK_IMPORTED_MODULE_1__["default"])(); +}; + +window.onload = function () { + Object(_modules_coverImgInit__WEBPACK_IMPORTED_MODULE_0__["default"])(); + Object(_components_mdcInit__WEBPACK_IMPORTED_MODULE_2__["default"])(); +}; + +/***/ }), + +/***/ "./src/ts/modules/coverImgInit.ts": +/*!****************************************!*\ + !*** ./src/ts/modules/coverImgInit.ts ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var parallax_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! parallax-js */ "./node_modules/parallax-js/dist/parallax.js"); +/* harmony import */ var parallax_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(parallax_js__WEBPACK_IMPORTED_MODULE_0__); +/** + * Copyright 2019 Mashiro + * @description Sakura theme module + * @author Mashiro + * @license MIT + */ + +/** + * Initial index cover image and image box. + * Include Parallax box initial and `#cover-img-container` size initial. + */ + +/* harmony default export */ __webpack_exports__["default"] = (function () { + let coverImgContainer = document.querySelector("#cover-img-container"); + coverImgContainer.style.height = `${window.innerHeight}px`; + let headerTopAfter = document.querySelector("#header-top-after"); + headerTopAfter.style.height = `${window.innerHeight}px`; + + /** + * cover: `img#cover-img` + */ + let coverImg = {}; + /** + * mark: `figure#cover-img-container` + */ + + let coverBox = {}; + /** + * layer: `div#img-view` + */ + + let coverView = {}; + coverImg.e = document.querySelector("#cover-img"); + coverImg.w = coverImg.e.naturalWidth; + coverImg.h = coverImg.e.naturalHeight; + coverBox.e = document.querySelector("#cover-img-container"); + coverBox.w = coverBox.e.offsetWidth; + coverBox.h = coverBox.e.offsetHeight; + coverView.e = document.querySelector("#img-view"); + coverBox.e.style.height = `${window.innerHeight}px`; + coverBox.f = coverBox.w >= 1000 || coverBox.h >= 1000 ? 1000 : 500; + + if (coverBox.w >= coverBox.h) { + coverBox.i = coverBox.w / coverBox.f * 50; + coverBox.y = coverBox.i; + coverBox.x = coverBox.i * coverBox.w / coverBox.h; + } else { + coverBox.i = coverBox.h / coverBox.f * 50; + coverBox.x = coverBox.i; + coverBox.y = coverBox.i * coverBox.h / coverBox.w; + } + + coverView.e.style.cssText = ` + width: ${coverBox.w + coverBox.x}px; + height: ${coverBox.h + coverBox.y}px; + margin-left: ${-0.5 * coverBox.x}px; + margin-top: ${-0.5 * coverBox.y}px`; + coverImg.e.style.cssText = ` + width: ${coverView.w + coverView.x}px; + height: ${coverView.h + coverView.y}px`; + + if (!coverImg.w) { + coverImg.w = coverImg.e.offsetWidth; + coverImg.h = coverImg.e.offsetHeight; + } + + coverImg._w = coverImg.e.parentElement.offsetWidth; + coverImg._h = coverImg.e.parentElement.offsetHeight; + coverImg.ratio = coverImg.h / coverImg.w; + + if (coverImg._h / coverImg._w > coverImg.ratio) { + coverImg.e.style.height = coverImg._h + 'px'; + coverImg.e.style.width = coverImg._h / coverImg.ratio + 'px'; + } else { + coverImg.e.style.width = coverImg._w + 'px'; + coverImg.e.style.height = coverImg._w * coverImg.ratio + 'px'; + } + + coverImg.e.style.left = (coverImg._w - parseInt(coverImg.e.style.width)) / 2 + 'px'; + coverImg.e.style.top = (coverImg._h - parseInt(coverImg.e.style.height)) / 2 + 'px'; + let scene = document.querySelector('#cover-img-container'); + let parallaxInstance = new parallax_js__WEBPACK_IMPORTED_MODULE_0___default.a(scene); +}); + +/***/ }), + +/***/ "./src/ts/modules/headerBarScrollHandler.ts": +/*!**************************************************!*\ + !*** ./src/ts/modules/headerBarScrollHandler.ts ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _scrollDirection__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./scrollDirection */ "./src/ts/modules/scrollDirection.ts"); +/** + * @description Sakura theme module + * @author Mashiro + * @since 19/10/31 + * @license MIT + */ + +/** + * Site top bar handler when page scroll + */ + +/* harmony default export */ __webpack_exports__["default"] = (function () { + let ele = document.querySelector("#nav-header"); + + if (Object(_scrollDirection__WEBPACK_IMPORTED_MODULE_0__["default"])('y') == 'down') { + ele.style.top = `-120px`; + } else if (Object(_scrollDirection__WEBPACK_IMPORTED_MODULE_0__["default"])('y') == 'up') { + ele.style.top = `0px`; + } +}); + +/***/ }), + +/***/ "./src/ts/modules/scrollDirection.ts": +/*!*******************************************!*\ + !*** ./src/ts/modules/scrollDirection.ts ***! + \*******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/** + * @description Sakura theme module + * @author Mashiro + * @since 19/10/31 + * @license MIT + */ +let scrollAction = { + x: undefined, + y: undefined, + d: undefined +}; +/** + * Detect window scroll direction + * @param {string} direction option: `Y`/`y` - horizontal; `X`/`x` - vertical + * @return {string} return window scroll direction + */ + +/* harmony default export */ __webpack_exports__["default"] = (function (direction) { + if (scrollAction.x == undefined) { + scrollAction.x = window.pageXOffset; + scrollAction.y = window.pageYOffset; + } + + let diffX = scrollAction.x - window.pageXOffset; + let diffY = scrollAction.y - window.pageYOffset; + + if (direction == 'x' || direction == 'X') { + if (diffX < 0) { + scrollAction.d = 'right'; + } else if (diffX > 0) { + scrollAction.d = 'left'; + } + } else { + if (diffY < 0) { + scrollAction.d = 'down'; + } else if (diffY > 0) { + scrollAction.d = 'up'; + } + } + + scrollAction.x = window.pageXOffset; + scrollAction.y = window.pageYOffset; + return scrollAction.d; +}); + +/***/ }), + +/***/ 0: +/*!*****************************************************!*\ + !*** multi ./src/scss/index.scss ./src/ts/index.ts ***! + \*****************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +__webpack_require__(/*! ./src/scss/index.scss */"./src/scss/index.scss"); +module.exports = __webpack_require__(/*! ./src/ts/index.ts */"./src/ts/index.ts"); + + +/***/ }) + +/******/ }); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./node_modules/@material/base/component.js","webpack:///./node_modules/@material/base/foundation.js","webpack:///./node_modules/@material/dom/events.js","webpack:///./node_modules/@material/dom/ponyfill.js","webpack:///./node_modules/@material/floating-label/component.js","webpack:///./node_modules/@material/floating-label/constants.js","webpack:///./node_modules/@material/floating-label/foundation.js","webpack:///./node_modules/@material/line-ripple/component.js","webpack:///./node_modules/@material/line-ripple/constants.js","webpack:///./node_modules/@material/line-ripple/foundation.js","webpack:///./node_modules/@material/notched-outline/component.js","webpack:///./node_modules/@material/notched-outline/constants.js","webpack:///./node_modules/@material/notched-outline/foundation.js","webpack:///./node_modules/@material/ripple/component.js","webpack:///./node_modules/@material/ripple/constants.js","webpack:///./node_modules/@material/ripple/foundation.js","webpack:///./node_modules/@material/ripple/index.js","webpack:///./node_modules/@material/ripple/util.js","webpack:///./node_modules/@material/textfield/character-counter/component.js","webpack:///./node_modules/@material/textfield/character-counter/constants.js","webpack:///./node_modules/@material/textfield/character-counter/foundation.js","webpack:///./node_modules/@material/textfield/character-counter/index.js","webpack:///./node_modules/@material/textfield/component.js","webpack:///./node_modules/@material/textfield/constants.js","webpack:///./node_modules/@material/textfield/foundation.js","webpack:///./node_modules/@material/textfield/helper-text/component.js","webpack:///./node_modules/@material/textfield/helper-text/constants.js","webpack:///./node_modules/@material/textfield/helper-text/foundation.js","webpack:///./node_modules/@material/textfield/helper-text/index.js","webpack:///./node_modules/@material/textfield/icon/component.js","webpack:///./node_modules/@material/textfield/icon/constants.js","webpack:///./node_modules/@material/textfield/icon/foundation.js","webpack:///./node_modules/@material/textfield/icon/index.js","webpack:///./node_modules/@material/textfield/index.js","webpack:///./node_modules/@material/top-app-bar/component.js","webpack:///./node_modules/@material/top-app-bar/constants.js","webpack:///./node_modules/@material/top-app-bar/fixed/foundation.js","webpack:///./node_modules/@material/top-app-bar/foundation.js","webpack:///./node_modules/@material/top-app-bar/index.js","webpack:///./node_modules/@material/top-app-bar/short/foundation.js","webpack:///./node_modules/@material/top-app-bar/standard/foundation.js","webpack:///./node_modules/parallax-js/dist/parallax.js","webpack:///./node_modules/tslib/tslib.es6.js","webpack:///(webpack)/buildin/global.js","webpack:///./src/scss/index.scss","webpack:///./src/ts/components/mdcConf.ts","webpack:///./src/ts/components/mdcInit.ts","webpack:///./src/ts/index.ts","webpack:///./src/ts/modules/coverImgInit.ts","webpack:///./src/ts/modules/headerBarScrollHandler.ts","webpack:///./src/ts/modules/scrollDirection.ts"],"names":["Conf","MDCTopAppBar","MDCTextField","MDCRipple","mdcConf","components","i","component","constructor","map","call","document","querySelectorAll","e","join","window","onscroll","headerBarScrollHandler","onload","coverImgIni","mdcInit","coverImgContainer","querySelector","style","height","innerHeight","headerTopAfter","coverImg","coverBox","coverView","w","naturalWidth","h","naturalHeight","offsetWidth","offsetHeight","f","y","x","cssText","_w","parentElement","_h","ratio","width","left","parseInt","top","scene","parallaxInstance","Parallax","ele","scrollDirection","scrollAction","undefined","d","direction","pageXOffset","pageYOffset","diffX","diffY"],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;;AClFA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACY;AAC7C;AACA;AACA;AACA,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA,oCAAoC,8CAAgB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kFAAkF;AAClF;AACA,0CAA0C,yDAAa,GAAG;AAC1D;AACA,0EAA0E;AAC1E;AACA;AACA,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,sBAAsB;AAC5D;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACuB;AACxB;AACe,2EAAY,EAAC;AAC5B,qC;;;;;;;;;;;;ACrGA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,cAAc;AAC/C;AACA;AACA;AACA;AACA;AACA,yEAAyE;AACzE;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,oDAAoD;AACpD;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,2DAA2D;AAC3D;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACwB;AACzB;AACe,4EAAa,EAAC;AAC7B,sC;;;;;;;;;;;;AC3EA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,+BAA+B,oBAAoB;AACnD,kCAAkC,sBAAsB;AACxD;AACA;AACA;AACA,qEAAqE,kBAAkB,EAAE;AACzF;AACA;AACA;AACA,iBAAiB;AACjB,aAAa;AACb;AACA;AACA,SAAS;AACT;AACA;AACA,+BAA+B,gBAAgB;AAC/C;AACA,kC;;;;;;;;;;;;AClDA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA,oC;;;;;;;;;;;;AC7CA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACE;AAC1D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,mCAAmC,gCAAgC,EAAE;AACrE,qEAAqE,uCAAuC,EAAE;AAC9G,uEAAuE,yCAAyC,EAAE;AAClH;AACA;AACA,mBAAmB,sEAA0B;AAC7C;AACA;AACA,CAAC,CAAC,qEAAY;AACc;AAC5B,qC;;;;;;;;;;;;ACpEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,qC;;;;;;;;;;;;AC3BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACjB;AACzC;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD,uDAAuD,yCAAyC;AAChG;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,8BAA8B;AAC9C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,UAAU,EAAE;AACnD,yDAAyD,kBAAkB,EAAE;AAC7E,2DAA2D,kBAAkB,EAAE;AAC/E;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACuB;AACtC;AACe,yFAA0B,EAAC;AAC1C,sC;;;;;;;;;;;;ACzGA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACD;AACvD;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,4CAA4C,kDAAkD,EAAE;AAChG,sDAAsD,2DAA2D,EAAE;AACnH,+DAA+D,uCAAuC,EAAE;AACxG,iEAAiE,yCAAyC,EAAE;AAC5G;AACA;AACA,mBAAmB,mEAAuB;AAC1C;AACA;AACA,CAAC,CAAC,qEAAY;AACW;AACzB,qC;;;;;;;;;;;;ACvEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACsB;AACtB,qC;;;;;;;;;;;;AC3BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACjB;AACzC;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD,sDAAsD,uCAAuC;AAC7F;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,2BAA2B;AAC3C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,cAAc,EAAE;AACvD,uCAAuC,kBAAkB,EAAE;AAC3D,mDAAmD,kBAAkB,EAAE;AACvE,qDAAqD,kBAAkB,EAAE;AACzE;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qDAAU;AAC5C,+BAA+B,qDAAU;AACzC;AACA;AACA;AACA;AACA;AACA,+BAA+B,qDAAU;AACzC;AACA;AACA;AACA;AACA,oDAAoD,qDAAU;AAC9D;AACA;AACA,0CAA0C,qDAAU;AACpD,0CAA0C,qDAAU;AACpD;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACoB;AACnC;AACe,sFAAuB,EAAC;AACvC,sC;;;;;;;;;;;;AC1FA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACyB;AAC/B;AACS;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,kDAAO;AAC7D,mDAAmD,8FAA0B;AAC7E;AACA;AACA,qCAAqC,qDAAU;AAC/C;AACA;AACA,aAAa;AACb;AACA;AACA,qCAAqC,qDAAU;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,qDAAqD,qEAAqE,EAAE;AAC5H,mDAAmD,0DAA0D,EAAE;AAC/G;AACA;AACA,mBAAmB,uEAA2B;AAC9C;AACA;AACA,CAAC,CAAC,qEAAY;AACe;AAC7B,qC;;;;;;;;;;;;AC/EA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACwC;AACxC,qC;;;;;;;;;;;;ACnCA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACC;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,+BAA+B;AAC/C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,oDAAoD,kBAAkB,EAAE;AACxE,uDAAuD,kBAAkB,EAAE;AAC3E;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,kDAAO,uBAAuB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACwB;AACvC;AACe,0FAA2B,EAAC;AAC3C,sC;;;;;;;;;;;;AC5FA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACJ;AACH;AACE;AACpB;AAC/B;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,SAAS,0BAA0B;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,gDAAgD,EAAE;AAC9F,iDAAiD,QAAQ,0DAAyB,SAAS,EAAE;AAC7F,8CAA8C,+CAA+C,EAAE;AAC/F,oDAAoD,wCAAwC,EAAE;AAC9F;AACA,sFAAsF,yEAAY;AAClG,aAAa;AACb;AACA,4EAA4E,yEAAY;AACxF,aAAa;AACb,yDAAyD,sDAAsD,EAAE;AACjH,8CAA8C,UAAU,+CAA+C,EAAE,EAAE;AAC3G,0CAA0C,QAAQ,sEAAO,4BAA4B,EAAE;AACvF,4CAA4C,mCAAmC,EAAE;AACjF,sCAAsC,oCAAoC,EAAE;AAC5E;AACA,mFAAmF,yEAAY;AAC/F,aAAa;AACb;AACA,yEAAyE,yEAAY;AACrF,aAAa;AACb,uDAAuD,mDAAmD,EAAE;AAC5G,+CAA+C,mDAAmD,EAAE;AACpG,0DAA0D,yDAAyD,EAAE;AACrH;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,+DAAmB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,qEAAY;AACO;AACrB,qC;;;;;;;;;;;;AC/GA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,qC;;;;;;;;;;;;AC/CA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACC;AACT;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD;AACA;AACA;AACA;AACA,wBAAwB;AACxB;AACA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;AACA;AACA;AACA,+CAA+C,2BAA2B;AAC1E,gDAAgD,4BAA4B;AAC5E,2CAA2C,4BAA4B;AACvE,0CAA0C,2BAA2B;AACrE,4CAA4C,uBAAuB;AACnE;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,qDAAqD,aAAa,EAAE;AACpE,kDAAkD,UAAU,4DAA4D,EAAE,EAAE;AAC5H,kDAAkD,aAAa,EAAE;AACjE,mEAAmE,kBAAkB,EAAE;AACvF,2DAA2D,kBAAkB,EAAE;AAC/E,sDAAsD,kBAAkB,EAAE;AAC1E,kDAAkD,UAAU,aAAa,EAAE,EAAE;AAC7E,8CAA8C,aAAa,EAAE;AAC7D,gDAAgD,aAAa,EAAE;AAC/D,0CAA0C,aAAa,EAAE;AACzD,iEAAiE,kBAAkB,EAAE;AACrF,yDAAyD,kBAAkB,EAAE;AAC7E,oDAAoD,kBAAkB,EAAE;AACxE,0CAA0C,kBAAkB,EAAE;AAC9D,gDAAgD,kBAAkB,EAAE;AACpE;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6HAA6H,mDAAmD,EAAE;AAClL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wDAAwD,yCAAyC,EAAE;AACnG;AACA;AACA;AACA;AACA;AACA,yBAAyB,sEAAwB;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,EAAE,kDAAO;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,mDAAmD,EAAE;AACrF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,8CAAgB,GAAG;AACvC;AACA,+CAA+C,0CAA0C,EAAE;AAC3F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACgB;AAC/B;AACe,kFAAmB,EAAC;AACnC,sC;;;;;;;;;;;;AC5cA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AACf;AACY;AACA;AACC;AAC7B,iC;;;;;;;;;;;;AC3BA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,kCAAkC,sBAAsB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,gC;;;;;;;;;;;;AC1EA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACc;AACtE;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,mBAAmB,kFAAsC;AACzD;AACA;AACA,CAAC,CAAC,qEAAY;AAC0B;AACxC,qC;;;;;;;;;;;;ACtDA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AAC/B,qC;;;;;;;;;;;;AC7BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACR;AAClD;AACA,IAAI,+CAAiB;AACrB;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,0CAA0C;AAC1D;AACA;AACA;AACA,yCAAyC,kBAAkB,EAAE;AAC7D;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACmC;AAClD;AACe,qGAAsC,EAAC;AACtD,sC;;;;;;;;;;;;ACjEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACC;AAC0E;AACvG,iC;;;;;;;;;;;;ACzBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACJ;AACD;AACmB;AACN;AACQ;AACjB;AACW;AACY;AACU;AACtC;AACI;AACY;AACU;AACxB;AACpD;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,4CAA4C,YAAY,oEAAS,iBAAiB,GAAG;AAC5H,2CAA2C,oCAAoC,YAAY,6EAAa,KAAK,GAAG;AAChH,2CAA2C,oCAAoC,YAAY,8EAAsB,KAAK,GAAG;AACzH,iDAAiD,0CAA0C,YAAY,yFAA4B,KAAK,GAAG;AAC3I,qCAAqC,8BAA8B,YAAY,iEAAgB,KAAK,GAAG;AACvG,sCAAsC,+BAA+B,YAAY,mFAAgB,KAAK,GAAG;AACzG,wCAAwC,iCAAiC,YAAY,qFAAiB,KAAK,GAAG;AAC9G,+CAA+C,mDAAO;AACtD,oDAAoD,mDAAO;AAC3D;AACA,yDAAyD,mDAAO;AAChE;AACA,sDAAsD,mDAAO;AAC7D;AACA;AACA,gCAAgC,yFAAgC;AAChE;AACA,yFAAyF,sDAAU;AACnG;AACA;AACA;AACA,sCAAsC,qGAAsC;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,mDAAO;AAC9D;AACA,0CAA0C;AAC1C;AACA;AACA;AACA;AACA,kDAAkD,sDAAU;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,8CAAgB,GAAG;AACzC;AACA,mBAAmB,mEAAsB;AACzC;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,4CAA4C,kDAAkD,EAAE;AAChG,8EAA8E,uCAAuC,EAAE;AACvH,gFAAgF,yCAAyC,EAAE;AAC3H;AACA;AACA;AACA,kDAAkD,+BAA+B,EAAE;AACnF,0DAA0D,sBAAsB,EAAE;AAClF;AACA,8EAA8E,kDAAkD,EAAE;AAClI,8BAA8B;AAC9B;AACA;AACA,aAAa;AACb,6EAA6E,8BAA8B,EAAE;AAC7G;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,qBAAqB,EAAE;AAChE,oCAAoC,gDAAgD,EAAE;AACtF;AACA,uEAAuE,yEAAY;AACnF,aAAa;AACb;AACA,0EAA0E,yEAAY;AACtF,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,wDAAwD,EAAE;AAC1G,wCAAwC,mDAAmD,EAAE;AAC7F,mCAAmC,8BAA8B,EAAE;AACnE,gDAAgD,wDAAwD,EAAE;AAC1G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,uCAAuC,sDAAsD,EAAE;AAC/F,qCAAqC,gCAAgC,EAAE;AACvE,iDAAiD,2DAA2D,EAAE;AAC9G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,sDAAU;AACjE,uDAAuD,sDAAU;AACjE;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,8CAAgB,GAAG,EAAE,oEAAS,uBAAuB,+BAA+B,QAAQ,8DAAgB,0BAA0B,EAAE,2DAA2D,wDAAwD,yEAAY,IAAI,EAAE;AACnS,0EAA0E,yEAAY;AACtF,aAAa,EAAE;AACf;AACA,6CAA6C,+EAAmB;AAChE;AACA;AACA,CAAC,CAAC,qEAAY;AACU;AACxB,qC;;;;;;;;;;;;ACpcA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACuF;AACvF,qC;;;;;;;;;;;;AC9DA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACgD;AAC1G;AACA;AACA;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA,uCAAuC,oBAAoB;AAC3D,sCAAsC,8CAAgB,GAAG;AACzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,8BAA8B;AAC9E,+CAA+C,gCAAgC;AAC/E,gDAAgD,4BAA4B;AAC5E,mDAAmD,sCAAsC;AACzF,0DAA0D,2CAA2C;AACrG,6EAA6E,8DAA8D;AAC3I;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,mBAAmB,6DAAkB;AACrC,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,0BAA0B;AAC1C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,aAAa,EAAE;AACtD,kEAAkE,kBAAkB,EAAE;AACtF,oEAAoE,kBAAkB,EAAE;AACxF,8DAA8D,kBAAkB,EAAE;AAClF,gEAAgE,kBAAkB,EAAE;AACpF,uEAAuE,0CAA0C,kBAAkB,EAAE,EAAE,EAAE;AACzI,yEAAyE,kBAAkB,EAAE;AAC7F,6CAA6C,aAAa,EAAE;AAC5D,wCAAwC,cAAc,EAAE;AACxD,iDAAiD,kBAAkB,EAAE;AACrE,mDAAmD,kBAAkB,EAAE;AACvE,2DAA2D,kBAAkB,EAAE;AAC/E,yCAAyC,kBAAkB,EAAE;AAC7D,yCAAyC,kBAAkB,EAAE;AAC7D,uCAAuC,cAAc,EAAE;AACvD,4CAA4C,UAAU,EAAE;AACxD,yCAAyC,cAAc,EAAE;AACzD,2CAA2C,kBAAkB,EAAE;AAC/D,2CAA2C,kBAAkB,EAAE;AAC/D;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,oEAAyB;AACzC;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,qDAAU;AAC3D,uCAAuC,kDAAO,qBAAqB,kDAAO;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACmB;AAClC;AACe,qFAAsB,EAAC;AACtC,sC;;;;;;;;;;;;AC3cA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACQ;AAChE;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,4CAA4C,kDAAkD,EAAE;AAChG,6CAA6C,8CAA8C,EAAE;AAC7F,yCAAyC,0CAA0C,EAAE;AACrF;AACA;AACA,aAAa;AACb;AACA;AACA,mBAAmB,4EAAgC;AACnD;AACA;AACA,CAAC,CAAC,qEAAY;AACoB;AAClC,qC;;;;;;;;;;;;AC7DA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AAC/B,qC;;;;;;;;;;;;ACjCA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACR;AAClD;AACA,IAAI,+CAAiB;AACrB;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,oCAAoC;AACpD;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,cAAc,EAAE;AACvD,sCAAsC,kBAAkB,EAAE;AAC1D,yCAAyC,kBAAkB,EAAE;AAC7D,yCAAyC,kBAAkB,EAAE;AAC7D;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,qDAAU;AAC7C;AACA;AACA,sCAAsC,qDAAU;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,qDAAU;AAC7C;AACA;AACA,sCAAsC,qDAAU;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,kDAAO;AACxC;AACA;AACA;AACA;AACA;AACA,4DAA4D,qDAAU;AACtE,+DAA+D,qDAAU;AACzE;AACA;AACA,kCAAkC,kDAAO;AACzC;AACA;AACA,qCAAqC,kDAAO;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,kDAAO;AACrC;AACA;AACA,CAAC,CAAC,uEAAa;AAC6B;AAC5C;AACe,+FAAgC,EAAC;AAChD,sC;;;;;;;;;;;;AC7HA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACC;AACkE;AAC/F,iC;;;;;;;;;;;;ACzBA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACE;AAC1D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,uCAAuC,EAAE;AAC/E,6CAA6C,8CAA8C,EAAE;AAC7F,yCAAyC,0CAA0C,EAAE;AACrF;AACA;AACA,aAAa;AACb,qEAAqE,uCAAuC,EAAE;AAC9G,uEAAuE,yCAAyC,EAAE;AAClH,2CAA2C,mBAAmB,sEAA0B,uBAAuB,yCAAyC,EAAE;AAC1J;AACA;AACA,mBAAmB,sEAA0B;AAC7C;AACA;AACA,CAAC,CAAC,qEAAY;AACc;AAC5B,qC;;;;;;;;;;;;AC9DA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AAC/B,qC;;;;;;;;;;;;AC9BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACR;AAClD;AACA;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD;AACA,oDAAoD,qCAAqC;AACzF;AACA;AACA;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,8BAA8B;AAC9C;AACA;AACA;AACA;AACA,sCAAsC,aAAa,EAAE;AACrD,sCAAsC,kBAAkB,EAAE;AAC1D,yCAAyC,kBAAkB,EAAE;AAC7D,yCAAyC,kBAAkB,EAAE;AAC7D,yDAAyD,kBAAkB,EAAE;AAC7E,2DAA2D,kBAAkB,EAAE;AAC/E,+CAA+C,kBAAkB,EAAE;AACnE;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,kDAAO;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACuB;AACtC;AACe,yFAA0B,EAAC;AAC1C,sC;;;;;;;;;;;;AC/GA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACC;AACsD;AACnF,iC;;;;;;;;;;;;ACzBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACA;AACC;AACa;AACN;AACP;AAC7B,iC;;;;;;;;;;;;AC5BA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACD;AACL;AACe;AACA;AACF;AAC/D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,gCAAgC,QAAQ,oEAAS,cAAc,GAAG;AACzG,iDAAiD,kDAAO;AACxD;AACA,8DAA8D,kDAAO;AACrE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oDAAoD,qDAAU;AAC9D,oDAAoD,qDAAU;AAC9D;AACA;AACA;AACA;AACA;AACA,yDAAyD,6BAA6B,EAAE;AACxF;AACA;AACA;AACA;AACA,oDAAoD,qDAAU;AAC9D,oDAAoD,qDAAU;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,kDAAkD,EAAE;AAChG,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,kDAAkD,uDAAuD,EAAE;AAC3G,6CAA6C,iCAAiC,EAAE;AAChF,sDAAsD,mBAAmB,kDAAO,qBAAqB,EAAE,EAAE;AACzG;AACA;AACA;AACA;AACA,aAAa;AACb,8CAA8C,qCAAqC,kDAAO,8BAA8B,EAAE;AAC1H;AACA;AACA;AACA,0CAA0C,qDAAU;AACpD,6BAA6B,6EAA2B;AACxD;AACA,+CAA+C,qDAAU;AACzD,6BAA6B,6EAA2B;AACxD;AACA;AACA,6BAA6B,2EAAsB;AACnD;AACA;AACA;AACA;AACA,CAAC,CAAC,qEAAY;AACU;AACxB,qC;;;;;;;;;;;;AC3HA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACwC;AACxC,qC;;;;;;;;;;;;ACzCA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACS;AACsB;AAChE;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,qDAAU;AACpD;AACA;AACA;AACA;AACA;AACA,uCAAuC,qDAAU;AACjD;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,2EAAsB;AACe;AACvC;AACe,0FAA2B,EAAC;AAC3C,sC;;;;;;;;;;;;AC3DA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACC;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,0BAA0B;AAC1C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,cAAc,EAAE;AACvD,uCAAuC,kBAAkB,EAAE;AAC3D,iDAAiD,UAAU,EAAE;AAC7D,0DAA0D,kBAAkB,EAAE;AAC9E,iDAAiD,UAAU,EAAE;AAC7D,kDAAkD,UAAU,EAAE;AAC9D;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA,2EAA2E,GAAG;AAC9E;AACA,2EAA2E,GAAG;AAC9E;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACuB;AACtC;AACe,yFAA0B,EAAC;AAC1C,sC;;;;;;;;;;;;ACrFA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACA;AACC;AACM;AACA;AACG;AACtC,iC;;;;;;;;;;;;AC5BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACS;AACiB;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,mCAAmC,qDAAU;AAC7C;AACA;AACA,uDAAuD,qDAAU;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qDAAU;AAC5C;AACA;AACA;AACA,+BAA+B,qDAAU;AACzC;AACA;AACA;AACA,CAAC,CAAC,sEAA0B;AACW;AACvC;AACe,0FAA2B,EAAC;AAC3C,sC;;;;;;;;;;;;ACxGA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACM;AACoB;AAC3D;AACA;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,EAAE,kDAAO;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,EAAE,kDAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,kDAAO;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,sEAA0B;AACM;AAClC;AACe,qFAAsB,EAAC;AACtC,sC;;;;;;;;;;;ACvKA,mFAAa,GAAG,IAAsD,EAAE,mBAAmB,KAAK,UAAiO,CAAC,aAAa,0BAA0B,0BAA0B,gBAAgB,UAAU,UAAU,0CAA0C,gBAAgB,OAAC,OAAO,oBAAoB,8CAA8C,kCAAkC,YAAY,YAAY,mCAAmC,iBAAiB,gBAAgB,sBAAsB,oBAAoB,0CAA0C,YAAY,WAAW,YAAY,SAAS,GAAG;AAC5yB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,kCAAkC;AAClC;AACA;AACA;;AAEA;AACA,EAAE;AACF;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,gBAAgB,sBAAsB;AACtC;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,oBAAoB;AACtC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,CAAC,GAAG;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA,CAAC;;;;AAID,CAAC;;AAED,CAAC,EAAE,aAAa;AAChB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;;;AAIA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uBAAuB,sBAAsB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qCAAqC;;AAErC;AACA;AACA;;AAEA,2BAA2B;AAC3B;AACA;AACA;AACA,4BAA4B,UAAU;;AAEtC,CAAC,GAAG;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,cAAc,4BAA4B;AAC1C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,eAAe;AACrC;AACA;AACA;AACA,aAAa;AACb,qCAAqC,UAAU;AAC/C;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,kBAAkB,kBAAkB;AACpC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,qIAAqI;;AAEtI,CAAC,EAAE,oBAAoB;AACvB;;AAEA,gCAAgC,2CAA2C,gBAAgB,kBAAkB,OAAO,2BAA2B,wDAAwD,gCAAgC,uDAAuD,2DAA2D,EAAE,EAAE,yDAAyD,qEAAqE,6DAA6D,oBAAoB,GAAG,EAAE;;AAEjjB,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,mBAAmB;AACnB;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,OAAO;AACtD;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,iDAAiD,OAAO;AACxD;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,yBAAyB,4BAA4B;AACrD;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,4BAA4B;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,sCAAsC;;AAEtC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;A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","file":"bundle.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/dist/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from './foundation';\nvar MDCComponent = /** @class */ (function () {\n    function MDCComponent(root, foundation) {\n        var args = [];\n        for (var _i = 2; _i < arguments.length; _i++) {\n            args[_i - 2] = arguments[_i];\n        }\n        this.root_ = root;\n        this.initialize.apply(this, tslib_1.__spread(args));\n        // Note that we initialize foundation here and not within the constructor's default param so that\n        // this.root_ is defined and can be used within the foundation class.\n        this.foundation_ = foundation === undefined ? this.getDefaultFoundation() : foundation;\n        this.foundation_.init();\n        this.initialSyncWithDOM();\n    }\n    MDCComponent.attachTo = function (root) {\n        // Subclasses which extend MDCBase should provide an attachTo() method that takes a root element and\n        // returns an instantiated component with its root set to that element. Also note that in the cases of\n        // subclasses, an explicit foundation class will not have to be passed in; it will simply be initialized\n        // from getDefaultFoundation().\n        return new MDCComponent(root, new MDCFoundation({}));\n    };\n    /* istanbul ignore next: method param only exists for typing purposes; it does not need to be unit tested */\n    MDCComponent.prototype.initialize = function () {\n        var _args = [];\n        for (var _i = 0; _i < arguments.length; _i++) {\n            _args[_i] = arguments[_i];\n        }\n        // Subclasses can override this to do any additional setup work that would be considered part of a\n        // \"constructor\". Essentially, it is a hook into the parent constructor before the foundation is\n        // initialized. Any additional arguments besides root and foundation will be passed in here.\n    };\n    MDCComponent.prototype.getDefaultFoundation = function () {\n        // Subclasses must override this method to return a properly configured foundation class for the\n        // component.\n        throw new Error('Subclasses must override getDefaultFoundation to return a properly configured ' +\n            'foundation class');\n    };\n    MDCComponent.prototype.initialSyncWithDOM = function () {\n        // Subclasses should override this method if they need to perform work to synchronize with a host DOM\n        // object. An example of this would be a form control wrapper that needs to synchronize its internal state\n        // to some property or attribute of the host DOM. Please note: this is *not* the place to perform DOM\n        // reads/writes that would cause layout / paint, as this is called synchronously from within the constructor.\n    };\n    MDCComponent.prototype.destroy = function () {\n        // Subclasses may implement this method to release any resources / deregister any listeners they have\n        // attached. An example of this might be deregistering a resize event from the window object.\n        this.foundation_.destroy();\n    };\n    MDCComponent.prototype.listen = function (evtType, handler, options) {\n        this.root_.addEventListener(evtType, handler, options);\n    };\n    MDCComponent.prototype.unlisten = function (evtType, handler, options) {\n        this.root_.removeEventListener(evtType, handler, options);\n    };\n    /**\n     * Fires a cross-browser-compatible custom event from the component root of the given type, with the given data.\n     */\n    MDCComponent.prototype.emit = function (evtType, evtData, shouldBubble) {\n        if (shouldBubble === void 0) { shouldBubble = false; }\n        var evt;\n        if (typeof CustomEvent === 'function') {\n            evt = new CustomEvent(evtType, {\n                bubbles: shouldBubble,\n                detail: evtData,\n            });\n        }\n        else {\n            evt = document.createEvent('CustomEvent');\n            evt.initCustomEvent(evtType, shouldBubble, false, evtData);\n        }\n        this.root_.dispatchEvent(evt);\n    };\n    return MDCComponent;\n}());\nexport { MDCComponent };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCComponent;\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar MDCFoundation = /** @class */ (function () {\n    function MDCFoundation(adapter) {\n        if (adapter === void 0) { adapter = {}; }\n        this.adapter_ = adapter;\n    }\n    Object.defineProperty(MDCFoundation, \"cssClasses\", {\n        get: function () {\n            // Classes extending MDCFoundation should implement this method to return an object which exports every\n            // CSS class the foundation class needs as a property. e.g. {ACTIVE: 'mdc-component--active'}\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFoundation, \"strings\", {\n        get: function () {\n            // Classes extending MDCFoundation should implement this method to return an object which exports all\n            // semantic strings as constants. e.g. {ARIA_ROLE: 'tablist'}\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFoundation, \"numbers\", {\n        get: function () {\n            // Classes extending MDCFoundation should implement this method to return an object which exports all\n            // of its semantic numbers as constants. e.g. {ANIMATION_DELAY_MS: 350}\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFoundation, \"defaultAdapter\", {\n        get: function () {\n            // Classes extending MDCFoundation may choose to implement this getter in order to provide a convenient\n            // way of viewing the necessary methods of an adapter. In the future, this could also be used for adapter\n            // validation.\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCFoundation.prototype.init = function () {\n        // Subclasses should override this method to perform initialization routines (registering events, etc.)\n    };\n    MDCFoundation.prototype.destroy = function () {\n        // Subclasses should override this method to perform de-initialization routines (de-registering events, etc.)\n    };\n    return MDCFoundation;\n}());\nexport { MDCFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\n/**\n * Stores result from applyPassive to avoid redundant processing to detect\n * passive event listener support.\n */\nvar supportsPassive_;\n/**\n * Determine whether the current browser supports passive event listeners, and\n * if so, use them.\n */\nexport function applyPassive(globalObj, forceRefresh) {\n    if (globalObj === void 0) { globalObj = window; }\n    if (forceRefresh === void 0) { forceRefresh = false; }\n    if (supportsPassive_ === undefined || forceRefresh) {\n        var isSupported_1 = false;\n        try {\n            globalObj.document.addEventListener('test', function () { return undefined; }, {\n                get passive() {\n                    isSupported_1 = true;\n                    return isSupported_1;\n                },\n            });\n        }\n        catch (e) {\n        } // tslint:disable-line:no-empty cannot throw error due to tests. tslint also disables console.log.\n        supportsPassive_ = isSupported_1;\n    }\n    return supportsPassive_ ? { passive: true } : false;\n}\n//# sourceMappingURL=events.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\n/**\n * @fileoverview A \"ponyfill\" is a polyfill that doesn't modify the global prototype chain.\n * This makes ponyfills safer than traditional polyfills, especially for libraries like MDC.\n */\nexport function closest(element, selector) {\n    if (element.closest) {\n        return element.closest(selector);\n    }\n    var el = element;\n    while (el) {\n        if (matches(el, selector)) {\n            return el;\n        }\n        el = el.parentElement;\n    }\n    return null;\n}\nexport function matches(element, selector) {\n    var nativeMatches = element.matches\n        || element.webkitMatchesSelector\n        || element.msMatchesSelector;\n    return nativeMatches.call(element, selector);\n}\n//# sourceMappingURL=ponyfill.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCFloatingLabelFoundation } from './foundation';\nvar MDCFloatingLabel = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCFloatingLabel, _super);\n    function MDCFloatingLabel() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCFloatingLabel.attachTo = function (root) {\n        return new MDCFloatingLabel(root);\n    };\n    /**\n     * Styles the label to produce the label shake for errors.\n     * @param shouldShake If true, shakes the label by adding a CSS class; otherwise, stops shaking by removing the class.\n     */\n    MDCFloatingLabel.prototype.shake = function (shouldShake) {\n        this.foundation_.shake(shouldShake);\n    };\n    /**\n     * Styles the label to float/dock.\n     * @param shouldFloat If true, floats the label by adding a CSS class; otherwise, docks it by removing the class.\n     */\n    MDCFloatingLabel.prototype.float = function (shouldFloat) {\n        this.foundation_.float(shouldFloat);\n    };\n    MDCFloatingLabel.prototype.getWidth = function () {\n        return this.foundation_.getWidth();\n    };\n    MDCFloatingLabel.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            getWidth: function () { return _this.root_.scrollWidth; },\n            registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCFloatingLabelFoundation(adapter);\n    };\n    return MDCFloatingLabel;\n}(MDCComponent));\nexport { MDCFloatingLabel };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport var cssClasses = {\n    LABEL_FLOAT_ABOVE: 'mdc-floating-label--float-above',\n    LABEL_SHAKE: 'mdc-floating-label--shake',\n    ROOT: 'mdc-floating-label',\n};\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses } from './constants';\nvar MDCFloatingLabelFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCFloatingLabelFoundation, _super);\n    function MDCFloatingLabelFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCFloatingLabelFoundation.defaultAdapter, adapter)) || this;\n        _this.shakeAnimationEndHandler_ = function () { return _this.handleShakeAnimationEnd_(); };\n        return _this;\n    }\n    Object.defineProperty(MDCFloatingLabelFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFloatingLabelFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCFloatingLabelAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                getWidth: function () { return 0; },\n                registerInteractionHandler: function () { return undefined; },\n                deregisterInteractionHandler: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCFloatingLabelFoundation.prototype.init = function () {\n        this.adapter_.registerInteractionHandler('animationend', this.shakeAnimationEndHandler_);\n    };\n    MDCFloatingLabelFoundation.prototype.destroy = function () {\n        this.adapter_.deregisterInteractionHandler('animationend', this.shakeAnimationEndHandler_);\n    };\n    /**\n     * Returns the width of the label element.\n     */\n    MDCFloatingLabelFoundation.prototype.getWidth = function () {\n        return this.adapter_.getWidth();\n    };\n    /**\n     * Styles the label to produce a shake animation to indicate an error.\n     * @param shouldShake If true, adds the shake CSS class; otherwise, removes shake class.\n     */\n    MDCFloatingLabelFoundation.prototype.shake = function (shouldShake) {\n        var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE;\n        if (shouldShake) {\n            this.adapter_.addClass(LABEL_SHAKE);\n        }\n        else {\n            this.adapter_.removeClass(LABEL_SHAKE);\n        }\n    };\n    /**\n     * Styles the label to float or dock.\n     * @param shouldFloat If true, adds the float CSS class; otherwise, removes float and shake classes to dock the label.\n     */\n    MDCFloatingLabelFoundation.prototype.float = function (shouldFloat) {\n        var _a = MDCFloatingLabelFoundation.cssClasses, LABEL_FLOAT_ABOVE = _a.LABEL_FLOAT_ABOVE, LABEL_SHAKE = _a.LABEL_SHAKE;\n        if (shouldFloat) {\n            this.adapter_.addClass(LABEL_FLOAT_ABOVE);\n        }\n        else {\n            this.adapter_.removeClass(LABEL_FLOAT_ABOVE);\n            this.adapter_.removeClass(LABEL_SHAKE);\n        }\n    };\n    MDCFloatingLabelFoundation.prototype.handleShakeAnimationEnd_ = function () {\n        var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE;\n        this.adapter_.removeClass(LABEL_SHAKE);\n    };\n    return MDCFloatingLabelFoundation;\n}(MDCFoundation));\nexport { MDCFloatingLabelFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCFloatingLabelFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCLineRippleFoundation } from './foundation';\nvar MDCLineRipple = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCLineRipple, _super);\n    function MDCLineRipple() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCLineRipple.attachTo = function (root) {\n        return new MDCLineRipple(root);\n    };\n    /**\n     * Activates the line ripple\n     */\n    MDCLineRipple.prototype.activate = function () {\n        this.foundation_.activate();\n    };\n    /**\n     * Deactivates the line ripple\n     */\n    MDCLineRipple.prototype.deactivate = function () {\n        this.foundation_.deactivate();\n    };\n    /**\n     * Sets the transform origin given a user's click location.\n     * The `rippleCenter` is the x-coordinate of the middle of the ripple.\n     */\n    MDCLineRipple.prototype.setRippleCenter = function (xCoordinate) {\n        this.foundation_.setRippleCenter(xCoordinate);\n    };\n    MDCLineRipple.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            setStyle: function (propertyName, value) { return _this.root_.style.setProperty(propertyName, value); },\n            registerEventHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterEventHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCLineRippleFoundation(adapter);\n    };\n    return MDCLineRipple;\n}(MDCComponent));\nexport { MDCLineRipple };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    LINE_RIPPLE_ACTIVE: 'mdc-line-ripple--active',\n    LINE_RIPPLE_DEACTIVATING: 'mdc-line-ripple--deactivating',\n};\nexport { cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses } from './constants';\nvar MDCLineRippleFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCLineRippleFoundation, _super);\n    function MDCLineRippleFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCLineRippleFoundation.defaultAdapter, adapter)) || this;\n        _this.transitionEndHandler_ = function (evt) { return _this.handleTransitionEnd(evt); };\n        return _this;\n    }\n    Object.defineProperty(MDCLineRippleFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCLineRippleFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCLineRippleAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return false; },\n                setStyle: function () { return undefined; },\n                registerEventHandler: function () { return undefined; },\n                deregisterEventHandler: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCLineRippleFoundation.prototype.init = function () {\n        this.adapter_.registerEventHandler('transitionend', this.transitionEndHandler_);\n    };\n    MDCLineRippleFoundation.prototype.destroy = function () {\n        this.adapter_.deregisterEventHandler('transitionend', this.transitionEndHandler_);\n    };\n    MDCLineRippleFoundation.prototype.activate = function () {\n        this.adapter_.removeClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n        this.adapter_.addClass(cssClasses.LINE_RIPPLE_ACTIVE);\n    };\n    MDCLineRippleFoundation.prototype.setRippleCenter = function (xCoordinate) {\n        this.adapter_.setStyle('transform-origin', xCoordinate + \"px center\");\n    };\n    MDCLineRippleFoundation.prototype.deactivate = function () {\n        this.adapter_.addClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n    };\n    MDCLineRippleFoundation.prototype.handleTransitionEnd = function (evt) {\n        // Wait for the line ripple to be either transparent or opaque\n        // before emitting the animation end event\n        var isDeactivating = this.adapter_.hasClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n        if (evt.propertyName === 'opacity') {\n            if (isDeactivating) {\n                this.adapter_.removeClass(cssClasses.LINE_RIPPLE_ACTIVE);\n                this.adapter_.removeClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n            }\n        }\n    };\n    return MDCLineRippleFoundation;\n}(MDCFoundation));\nexport { MDCLineRippleFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCLineRippleFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCFloatingLabelFoundation } from '@material/floating-label/foundation';\nimport { cssClasses, strings } from './constants';\nimport { MDCNotchedOutlineFoundation } from './foundation';\nvar MDCNotchedOutline = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCNotchedOutline, _super);\n    function MDCNotchedOutline() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCNotchedOutline.attachTo = function (root) {\n        return new MDCNotchedOutline(root);\n    };\n    MDCNotchedOutline.prototype.initialSyncWithDOM = function () {\n        this.notchElement_ = this.root_.querySelector(strings.NOTCH_ELEMENT_SELECTOR);\n        var label = this.root_.querySelector('.' + MDCFloatingLabelFoundation.cssClasses.ROOT);\n        if (label) {\n            label.style.transitionDuration = '0s';\n            this.root_.classList.add(cssClasses.OUTLINE_UPGRADED);\n            requestAnimationFrame(function () {\n                label.style.transitionDuration = '';\n            });\n        }\n        else {\n            this.root_.classList.add(cssClasses.NO_LABEL);\n        }\n    };\n    /**\n     * Updates classes and styles to open the notch to the specified width.\n     * @param notchWidth The notch width in the outline.\n     */\n    MDCNotchedOutline.prototype.notch = function (notchWidth) {\n        this.foundation_.notch(notchWidth);\n    };\n    /**\n     * Updates classes and styles to close the notch.\n     */\n    MDCNotchedOutline.prototype.closeNotch = function () {\n        this.foundation_.closeNotch();\n    };\n    MDCNotchedOutline.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            setNotchWidthProperty: function (width) { return _this.notchElement_.style.setProperty('width', width + 'px'); },\n            removeNotchWidthProperty: function () { return _this.notchElement_.style.removeProperty('width'); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCNotchedOutlineFoundation(adapter);\n    };\n    return MDCNotchedOutline;\n}(MDCComponent));\nexport { MDCNotchedOutline };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar strings = {\n    NOTCH_ELEMENT_SELECTOR: '.mdc-notched-outline__notch',\n};\nvar numbers = {\n    // This should stay in sync with $mdc-notched-outline-padding * 2.\n    NOTCH_ELEMENT_PADDING: 8,\n};\nvar cssClasses = {\n    NO_LABEL: 'mdc-notched-outline--no-label',\n    OUTLINE_NOTCHED: 'mdc-notched-outline--notched',\n    OUTLINE_UPGRADED: 'mdc-notched-outline--upgraded',\n};\nexport { cssClasses, numbers, strings };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, numbers, strings } from './constants';\nvar MDCNotchedOutlineFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCNotchedOutlineFoundation, _super);\n    function MDCNotchedOutlineFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCNotchedOutlineFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCNotchedOutlineAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                setNotchWidthProperty: function () { return undefined; },\n                removeNotchWidthProperty: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /**\n     * Adds the outline notched selector and updates the notch width calculated based off of notchWidth.\n     */\n    MDCNotchedOutlineFoundation.prototype.notch = function (notchWidth) {\n        var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED;\n        if (notchWidth > 0) {\n            notchWidth += numbers.NOTCH_ELEMENT_PADDING; // Add padding from left/right.\n        }\n        this.adapter_.setNotchWidthProperty(notchWidth);\n        this.adapter_.addClass(OUTLINE_NOTCHED);\n    };\n    /**\n     * Removes notched outline selector to close the notch in the outline.\n     */\n    MDCNotchedOutlineFoundation.prototype.closeNotch = function () {\n        var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED;\n        this.adapter_.removeClass(OUTLINE_NOTCHED);\n        this.adapter_.removeNotchWidthProperty();\n    };\n    return MDCNotchedOutlineFoundation;\n}(MDCFoundation));\nexport { MDCNotchedOutlineFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCNotchedOutlineFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { applyPassive } from '@material/dom/events';\nimport { matches } from '@material/dom/ponyfill';\nimport { MDCRippleFoundation } from './foundation';\nimport * as util from './util';\nvar MDCRipple = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCRipple, _super);\n    function MDCRipple() {\n        var _this = _super !== null && _super.apply(this, arguments) || this;\n        _this.disabled = false;\n        return _this;\n    }\n    MDCRipple.attachTo = function (root, opts) {\n        if (opts === void 0) { opts = { isUnbounded: undefined }; }\n        var ripple = new MDCRipple(root);\n        // Only override unbounded behavior if option is explicitly specified\n        if (opts.isUnbounded !== undefined) {\n            ripple.unbounded = opts.isUnbounded;\n        }\n        return ripple;\n    };\n    MDCRipple.createAdapter = function (instance) {\n        return {\n            addClass: function (className) { return instance.root_.classList.add(className); },\n            browserSupportsCssVars: function () { return util.supportsCssVariables(window); },\n            computeBoundingRect: function () { return instance.root_.getBoundingClientRect(); },\n            containsEventTarget: function (target) { return instance.root_.contains(target); },\n            deregisterDocumentInteractionHandler: function (evtType, handler) {\n                return document.documentElement.removeEventListener(evtType, handler, applyPassive());\n            },\n            deregisterInteractionHandler: function (evtType, handler) {\n                return instance.root_.removeEventListener(evtType, handler, applyPassive());\n            },\n            deregisterResizeHandler: function (handler) { return window.removeEventListener('resize', handler); },\n            getWindowPageOffset: function () { return ({ x: window.pageXOffset, y: window.pageYOffset }); },\n            isSurfaceActive: function () { return matches(instance.root_, ':active'); },\n            isSurfaceDisabled: function () { return Boolean(instance.disabled); },\n            isUnbounded: function () { return Boolean(instance.unbounded); },\n            registerDocumentInteractionHandler: function (evtType, handler) {\n                return document.documentElement.addEventListener(evtType, handler, applyPassive());\n            },\n            registerInteractionHandler: function (evtType, handler) {\n                return instance.root_.addEventListener(evtType, handler, applyPassive());\n            },\n            registerResizeHandler: function (handler) { return window.addEventListener('resize', handler); },\n            removeClass: function (className) { return instance.root_.classList.remove(className); },\n            updateCssVariable: function (varName, value) { return instance.root_.style.setProperty(varName, value); },\n        };\n    };\n    Object.defineProperty(MDCRipple.prototype, \"unbounded\", {\n        get: function () {\n            return Boolean(this.unbounded_);\n        },\n        set: function (unbounded) {\n            this.unbounded_ = Boolean(unbounded);\n            this.setUnbounded_();\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCRipple.prototype.activate = function () {\n        this.foundation_.activate();\n    };\n    MDCRipple.prototype.deactivate = function () {\n        this.foundation_.deactivate();\n    };\n    MDCRipple.prototype.layout = function () {\n        this.foundation_.layout();\n    };\n    MDCRipple.prototype.getDefaultFoundation = function () {\n        return new MDCRippleFoundation(MDCRipple.createAdapter(this));\n    };\n    MDCRipple.prototype.initialSyncWithDOM = function () {\n        var root = this.root_;\n        this.unbounded = 'mdcRippleIsUnbounded' in root.dataset;\n    };\n    /**\n     * Closure Compiler throws an access control error when directly accessing a\n     * protected or private property inside a getter/setter, like unbounded above.\n     * By accessing the protected property inside a method, we solve that problem.\n     * That's why this function exists.\n     */\n    MDCRipple.prototype.setUnbounded_ = function () {\n        this.foundation_.setUnbounded(Boolean(this.unbounded_));\n    };\n    return MDCRipple;\n}(MDCComponent));\nexport { MDCRipple };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport var cssClasses = {\n    // Ripple is a special case where the \"root\" component is really a \"mixin\" of sorts,\n    // given that it's an 'upgrade' to an existing component. That being said it is the root\n    // CSS class that all other CSS classes derive from.\n    BG_FOCUSED: 'mdc-ripple-upgraded--background-focused',\n    FG_ACTIVATION: 'mdc-ripple-upgraded--foreground-activation',\n    FG_DEACTIVATION: 'mdc-ripple-upgraded--foreground-deactivation',\n    ROOT: 'mdc-ripple-upgraded',\n    UNBOUNDED: 'mdc-ripple-upgraded--unbounded',\n};\nexport var strings = {\n    VAR_FG_SCALE: '--mdc-ripple-fg-scale',\n    VAR_FG_SIZE: '--mdc-ripple-fg-size',\n    VAR_FG_TRANSLATE_END: '--mdc-ripple-fg-translate-end',\n    VAR_FG_TRANSLATE_START: '--mdc-ripple-fg-translate-start',\n    VAR_LEFT: '--mdc-ripple-left',\n    VAR_TOP: '--mdc-ripple-top',\n};\nexport var numbers = {\n    DEACTIVATION_TIMEOUT_MS: 225,\n    FG_DEACTIVATION_MS: 150,\n    INITIAL_ORIGIN_SCALE: 0.6,\n    PADDING: 10,\n    TAP_DELAY_MS: 300,\n};\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, numbers, strings } from './constants';\nimport { getNormalizedEventCoords } from './util';\n// Activation events registered on the root element of each instance for activation\nvar ACTIVATION_EVENT_TYPES = [\n    'touchstart', 'pointerdown', 'mousedown', 'keydown',\n];\n// Deactivation events registered on documentElement when a pointer-related down event occurs\nvar POINTER_DEACTIVATION_EVENT_TYPES = [\n    'touchend', 'pointerup', 'mouseup', 'contextmenu',\n];\n// simultaneous nested activations\nvar activatedTargets = [];\nvar MDCRippleFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCRippleFoundation, _super);\n    function MDCRippleFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCRippleFoundation.defaultAdapter, adapter)) || this;\n        _this.activationAnimationHasEnded_ = false;\n        _this.activationTimer_ = 0;\n        _this.fgDeactivationRemovalTimer_ = 0;\n        _this.fgScale_ = '0';\n        _this.frame_ = { width: 0, height: 0 };\n        _this.initialSize_ = 0;\n        _this.layoutFrame_ = 0;\n        _this.maxRadius_ = 0;\n        _this.unboundedCoords_ = { left: 0, top: 0 };\n        _this.activationState_ = _this.defaultActivationState_();\n        _this.activationTimerCallback_ = function () {\n            _this.activationAnimationHasEnded_ = true;\n            _this.runDeactivationUXLogicIfReady_();\n        };\n        _this.activateHandler_ = function (e) { return _this.activate_(e); };\n        _this.deactivateHandler_ = function () { return _this.deactivate_(); };\n        _this.focusHandler_ = function () { return _this.handleFocus(); };\n        _this.blurHandler_ = function () { return _this.handleBlur(); };\n        _this.resizeHandler_ = function () { return _this.layout(); };\n        return _this;\n    }\n    Object.defineProperty(MDCRippleFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCRippleFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCRippleFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCRippleFoundation, \"defaultAdapter\", {\n        get: function () {\n            return {\n                addClass: function () { return undefined; },\n                browserSupportsCssVars: function () { return true; },\n                computeBoundingRect: function () { return ({ top: 0, right: 0, bottom: 0, left: 0, width: 0, height: 0 }); },\n                containsEventTarget: function () { return true; },\n                deregisterDocumentInteractionHandler: function () { return undefined; },\n                deregisterInteractionHandler: function () { return undefined; },\n                deregisterResizeHandler: function () { return undefined; },\n                getWindowPageOffset: function () { return ({ x: 0, y: 0 }); },\n                isSurfaceActive: function () { return true; },\n                isSurfaceDisabled: function () { return true; },\n                isUnbounded: function () { return true; },\n                registerDocumentInteractionHandler: function () { return undefined; },\n                registerInteractionHandler: function () { return undefined; },\n                registerResizeHandler: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                updateCssVariable: function () { return undefined; },\n            };\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCRippleFoundation.prototype.init = function () {\n        var _this = this;\n        var supportsPressRipple = this.supportsPressRipple_();\n        this.registerRootHandlers_(supportsPressRipple);\n        if (supportsPressRipple) {\n            var _a = MDCRippleFoundation.cssClasses, ROOT_1 = _a.ROOT, UNBOUNDED_1 = _a.UNBOUNDED;\n            requestAnimationFrame(function () {\n                _this.adapter_.addClass(ROOT_1);\n                if (_this.adapter_.isUnbounded()) {\n                    _this.adapter_.addClass(UNBOUNDED_1);\n                    // Unbounded ripples need layout logic applied immediately to set coordinates for both shade and ripple\n                    _this.layoutInternal_();\n                }\n            });\n        }\n    };\n    MDCRippleFoundation.prototype.destroy = function () {\n        var _this = this;\n        if (this.supportsPressRipple_()) {\n            if (this.activationTimer_) {\n                clearTimeout(this.activationTimer_);\n                this.activationTimer_ = 0;\n                this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_ACTIVATION);\n            }\n            if (this.fgDeactivationRemovalTimer_) {\n                clearTimeout(this.fgDeactivationRemovalTimer_);\n                this.fgDeactivationRemovalTimer_ = 0;\n                this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_DEACTIVATION);\n            }\n            var _a = MDCRippleFoundation.cssClasses, ROOT_2 = _a.ROOT, UNBOUNDED_2 = _a.UNBOUNDED;\n            requestAnimationFrame(function () {\n                _this.adapter_.removeClass(ROOT_2);\n                _this.adapter_.removeClass(UNBOUNDED_2);\n                _this.removeCssVars_();\n            });\n        }\n        this.deregisterRootHandlers_();\n        this.deregisterDeactivationHandlers_();\n    };\n    /**\n     * @param evt Optional event containing position information.\n     */\n    MDCRippleFoundation.prototype.activate = function (evt) {\n        this.activate_(evt);\n    };\n    MDCRippleFoundation.prototype.deactivate = function () {\n        this.deactivate_();\n    };\n    MDCRippleFoundation.prototype.layout = function () {\n        var _this = this;\n        if (this.layoutFrame_) {\n            cancelAnimationFrame(this.layoutFrame_);\n        }\n        this.layoutFrame_ = requestAnimationFrame(function () {\n            _this.layoutInternal_();\n            _this.layoutFrame_ = 0;\n        });\n    };\n    MDCRippleFoundation.prototype.setUnbounded = function (unbounded) {\n        var UNBOUNDED = MDCRippleFoundation.cssClasses.UNBOUNDED;\n        if (unbounded) {\n            this.adapter_.addClass(UNBOUNDED);\n        }\n        else {\n            this.adapter_.removeClass(UNBOUNDED);\n        }\n    };\n    MDCRippleFoundation.prototype.handleFocus = function () {\n        var _this = this;\n        requestAnimationFrame(function () {\n            return _this.adapter_.addClass(MDCRippleFoundation.cssClasses.BG_FOCUSED);\n        });\n    };\n    MDCRippleFoundation.prototype.handleBlur = function () {\n        var _this = this;\n        requestAnimationFrame(function () {\n            return _this.adapter_.removeClass(MDCRippleFoundation.cssClasses.BG_FOCUSED);\n        });\n    };\n    /**\n     * We compute this property so that we are not querying information about the client\n     * until the point in time where the foundation requests it. This prevents scenarios where\n     * client-side feature-detection may happen too early, such as when components are rendered on the server\n     * and then initialized at mount time on the client.\n     */\n    MDCRippleFoundation.prototype.supportsPressRipple_ = function () {\n        return this.adapter_.browserSupportsCssVars();\n    };\n    MDCRippleFoundation.prototype.defaultActivationState_ = function () {\n        return {\n            activationEvent: undefined,\n            hasDeactivationUXRun: false,\n            isActivated: false,\n            isProgrammatic: false,\n            wasActivatedByPointer: false,\n            wasElementMadeActive: false,\n        };\n    };\n    /**\n     * supportsPressRipple Passed from init to save a redundant function call\n     */\n    MDCRippleFoundation.prototype.registerRootHandlers_ = function (supportsPressRipple) {\n        var _this = this;\n        if (supportsPressRipple) {\n            ACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n                _this.adapter_.registerInteractionHandler(evtType, _this.activateHandler_);\n            });\n            if (this.adapter_.isUnbounded()) {\n                this.adapter_.registerResizeHandler(this.resizeHandler_);\n            }\n        }\n        this.adapter_.registerInteractionHandler('focus', this.focusHandler_);\n        this.adapter_.registerInteractionHandler('blur', this.blurHandler_);\n    };\n    MDCRippleFoundation.prototype.registerDeactivationHandlers_ = function (evt) {\n        var _this = this;\n        if (evt.type === 'keydown') {\n            this.adapter_.registerInteractionHandler('keyup', this.deactivateHandler_);\n        }\n        else {\n            POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n                _this.adapter_.registerDocumentInteractionHandler(evtType, _this.deactivateHandler_);\n            });\n        }\n    };\n    MDCRippleFoundation.prototype.deregisterRootHandlers_ = function () {\n        var _this = this;\n        ACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n            _this.adapter_.deregisterInteractionHandler(evtType, _this.activateHandler_);\n        });\n        this.adapter_.deregisterInteractionHandler('focus', this.focusHandler_);\n        this.adapter_.deregisterInteractionHandler('blur', this.blurHandler_);\n        if (this.adapter_.isUnbounded()) {\n            this.adapter_.deregisterResizeHandler(this.resizeHandler_);\n        }\n    };\n    MDCRippleFoundation.prototype.deregisterDeactivationHandlers_ = function () {\n        var _this = this;\n        this.adapter_.deregisterInteractionHandler('keyup', this.deactivateHandler_);\n        POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n            _this.adapter_.deregisterDocumentInteractionHandler(evtType, _this.deactivateHandler_);\n        });\n    };\n    MDCRippleFoundation.prototype.removeCssVars_ = function () {\n        var _this = this;\n        var rippleStrings = MDCRippleFoundation.strings;\n        var keys = Object.keys(rippleStrings);\n        keys.forEach(function (key) {\n            if (key.indexOf('VAR_') === 0) {\n                _this.adapter_.updateCssVariable(rippleStrings[key], null);\n            }\n        });\n    };\n    MDCRippleFoundation.prototype.activate_ = function (evt) {\n        var _this = this;\n        if (this.adapter_.isSurfaceDisabled()) {\n            return;\n        }\n        var activationState = this.activationState_;\n        if (activationState.isActivated) {\n            return;\n        }\n        // Avoid reacting to follow-on events fired by touch device after an already-processed user interaction\n        var previousActivationEvent = this.previousActivationEvent_;\n        var isSameInteraction = previousActivationEvent && evt !== undefined && previousActivationEvent.type !== evt.type;\n        if (isSameInteraction) {\n            return;\n        }\n        activationState.isActivated = true;\n        activationState.isProgrammatic = evt === undefined;\n        activationState.activationEvent = evt;\n        activationState.wasActivatedByPointer = activationState.isProgrammatic ? false : evt !== undefined && (evt.type === 'mousedown' || evt.type === 'touchstart' || evt.type === 'pointerdown');\n        var hasActivatedChild = evt !== undefined && activatedTargets.length > 0 && activatedTargets.some(function (target) { return _this.adapter_.containsEventTarget(target); });\n        if (hasActivatedChild) {\n            // Immediately reset activation state, while preserving logic that prevents touch follow-on events\n            this.resetActivationState_();\n            return;\n        }\n        if (evt !== undefined) {\n            activatedTargets.push(evt.target);\n            this.registerDeactivationHandlers_(evt);\n        }\n        activationState.wasElementMadeActive = this.checkElementMadeActive_(evt);\n        if (activationState.wasElementMadeActive) {\n            this.animateActivation_();\n        }\n        requestAnimationFrame(function () {\n            // Reset array on next frame after the current event has had a chance to bubble to prevent ancestor ripples\n            activatedTargets = [];\n            if (!activationState.wasElementMadeActive\n                && evt !== undefined\n                && (evt.key === ' ' || evt.keyCode === 32)) {\n                // If space was pressed, try again within an rAF call to detect :active, because different UAs report\n                // active states inconsistently when they're called within event handling code:\n                // - https://bugs.chromium.org/p/chromium/issues/detail?id=635971\n                // - https://bugzilla.mozilla.org/show_bug.cgi?id=1293741\n                // We try first outside rAF to support Edge, which does not exhibit this problem, but will crash if a CSS\n                // variable is set within a rAF callback for a submit button interaction (#2241).\n                activationState.wasElementMadeActive = _this.checkElementMadeActive_(evt);\n                if (activationState.wasElementMadeActive) {\n                    _this.animateActivation_();\n                }\n            }\n            if (!activationState.wasElementMadeActive) {\n                // Reset activation state immediately if element was not made active.\n                _this.activationState_ = _this.defaultActivationState_();\n            }\n        });\n    };\n    MDCRippleFoundation.prototype.checkElementMadeActive_ = function (evt) {\n        return (evt !== undefined && evt.type === 'keydown') ? this.adapter_.isSurfaceActive() : true;\n    };\n    MDCRippleFoundation.prototype.animateActivation_ = function () {\n        var _this = this;\n        var _a = MDCRippleFoundation.strings, VAR_FG_TRANSLATE_START = _a.VAR_FG_TRANSLATE_START, VAR_FG_TRANSLATE_END = _a.VAR_FG_TRANSLATE_END;\n        var _b = MDCRippleFoundation.cssClasses, FG_DEACTIVATION = _b.FG_DEACTIVATION, FG_ACTIVATION = _b.FG_ACTIVATION;\n        var DEACTIVATION_TIMEOUT_MS = MDCRippleFoundation.numbers.DEACTIVATION_TIMEOUT_MS;\n        this.layoutInternal_();\n        var translateStart = '';\n        var translateEnd = '';\n        if (!this.adapter_.isUnbounded()) {\n            var _c = this.getFgTranslationCoordinates_(), startPoint = _c.startPoint, endPoint = _c.endPoint;\n            translateStart = startPoint.x + \"px, \" + startPoint.y + \"px\";\n            translateEnd = endPoint.x + \"px, \" + endPoint.y + \"px\";\n        }\n        this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_START, translateStart);\n        this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_END, translateEnd);\n        // Cancel any ongoing activation/deactivation animations\n        clearTimeout(this.activationTimer_);\n        clearTimeout(this.fgDeactivationRemovalTimer_);\n        this.rmBoundedActivationClasses_();\n        this.adapter_.removeClass(FG_DEACTIVATION);\n        // Force layout in order to re-trigger the animation.\n        this.adapter_.computeBoundingRect();\n        this.adapter_.addClass(FG_ACTIVATION);\n        this.activationTimer_ = setTimeout(function () { return _this.activationTimerCallback_(); }, DEACTIVATION_TIMEOUT_MS);\n    };\n    MDCRippleFoundation.prototype.getFgTranslationCoordinates_ = function () {\n        var _a = this.activationState_, activationEvent = _a.activationEvent, wasActivatedByPointer = _a.wasActivatedByPointer;\n        var startPoint;\n        if (wasActivatedByPointer) {\n            startPoint = getNormalizedEventCoords(activationEvent, this.adapter_.getWindowPageOffset(), this.adapter_.computeBoundingRect());\n        }\n        else {\n            startPoint = {\n                x: this.frame_.width / 2,\n                y: this.frame_.height / 2,\n            };\n        }\n        // Center the element around the start point.\n        startPoint = {\n            x: startPoint.x - (this.initialSize_ / 2),\n            y: startPoint.y - (this.initialSize_ / 2),\n        };\n        var endPoint = {\n            x: (this.frame_.width / 2) - (this.initialSize_ / 2),\n            y: (this.frame_.height / 2) - (this.initialSize_ / 2),\n        };\n        return { startPoint: startPoint, endPoint: endPoint };\n    };\n    MDCRippleFoundation.prototype.runDeactivationUXLogicIfReady_ = function () {\n        var _this = this;\n        // This method is called both when a pointing device is released, and when the activation animation ends.\n        // The deactivation animation should only run after both of those occur.\n        var FG_DEACTIVATION = MDCRippleFoundation.cssClasses.FG_DEACTIVATION;\n        var _a = this.activationState_, hasDeactivationUXRun = _a.hasDeactivationUXRun, isActivated = _a.isActivated;\n        var activationHasEnded = hasDeactivationUXRun || !isActivated;\n        if (activationHasEnded && this.activationAnimationHasEnded_) {\n            this.rmBoundedActivationClasses_();\n            this.adapter_.addClass(FG_DEACTIVATION);\n            this.fgDeactivationRemovalTimer_ = setTimeout(function () {\n                _this.adapter_.removeClass(FG_DEACTIVATION);\n            }, numbers.FG_DEACTIVATION_MS);\n        }\n    };\n    MDCRippleFoundation.prototype.rmBoundedActivationClasses_ = function () {\n        var FG_ACTIVATION = MDCRippleFoundation.cssClasses.FG_ACTIVATION;\n        this.adapter_.removeClass(FG_ACTIVATION);\n        this.activationAnimationHasEnded_ = false;\n        this.adapter_.computeBoundingRect();\n    };\n    MDCRippleFoundation.prototype.resetActivationState_ = function () {\n        var _this = this;\n        this.previousActivationEvent_ = this.activationState_.activationEvent;\n        this.activationState_ = this.defaultActivationState_();\n        // Touch devices may fire additional events for the same interaction within a short time.\n        // Store the previous event until it's safe to assume that subsequent events are for new interactions.\n        setTimeout(function () { return _this.previousActivationEvent_ = undefined; }, MDCRippleFoundation.numbers.TAP_DELAY_MS);\n    };\n    MDCRippleFoundation.prototype.deactivate_ = function () {\n        var _this = this;\n        var activationState = this.activationState_;\n        // This can happen in scenarios such as when you have a keyup event that blurs the element.\n        if (!activationState.isActivated) {\n            return;\n        }\n        var state = tslib_1.__assign({}, activationState);\n        if (activationState.isProgrammatic) {\n            requestAnimationFrame(function () { return _this.animateDeactivation_(state); });\n            this.resetActivationState_();\n        }\n        else {\n            this.deregisterDeactivationHandlers_();\n            requestAnimationFrame(function () {\n                _this.activationState_.hasDeactivationUXRun = true;\n                _this.animateDeactivation_(state);\n                _this.resetActivationState_();\n            });\n        }\n    };\n    MDCRippleFoundation.prototype.animateDeactivation_ = function (_a) {\n        var wasActivatedByPointer = _a.wasActivatedByPointer, wasElementMadeActive = _a.wasElementMadeActive;\n        if (wasActivatedByPointer || wasElementMadeActive) {\n            this.runDeactivationUXLogicIfReady_();\n        }\n    };\n    MDCRippleFoundation.prototype.layoutInternal_ = function () {\n        var _this = this;\n        this.frame_ = this.adapter_.computeBoundingRect();\n        var maxDim = Math.max(this.frame_.height, this.frame_.width);\n        // Surface diameter is treated differently for unbounded vs. bounded ripples.\n        // Unbounded ripple diameter is calculated smaller since the surface is expected to already be padded appropriately\n        // to extend the hitbox, and the ripple is expected to meet the edges of the padded hitbox (which is typically\n        // square). Bounded ripples, on the other hand, are fully expected to expand beyond the surface's longest diameter\n        // (calculated based on the diagonal plus a constant padding), and are clipped at the surface's border via\n        // `overflow: hidden`.\n        var getBoundedRadius = function () {\n            var hypotenuse = Math.sqrt(Math.pow(_this.frame_.width, 2) + Math.pow(_this.frame_.height, 2));\n            return hypotenuse + MDCRippleFoundation.numbers.PADDING;\n        };\n        this.maxRadius_ = this.adapter_.isUnbounded() ? maxDim : getBoundedRadius();\n        // Ripple is sized as a fraction of the largest dimension of the surface, then scales up using a CSS scale transform\n        this.initialSize_ = Math.floor(maxDim * MDCRippleFoundation.numbers.INITIAL_ORIGIN_SCALE);\n        this.fgScale_ = \"\" + this.maxRadius_ / this.initialSize_;\n        this.updateLayoutCssVars_();\n    };\n    MDCRippleFoundation.prototype.updateLayoutCssVars_ = function () {\n        var _a = MDCRippleFoundation.strings, VAR_FG_SIZE = _a.VAR_FG_SIZE, VAR_LEFT = _a.VAR_LEFT, VAR_TOP = _a.VAR_TOP, VAR_FG_SCALE = _a.VAR_FG_SCALE;\n        this.adapter_.updateCssVariable(VAR_FG_SIZE, this.initialSize_ + \"px\");\n        this.adapter_.updateCssVariable(VAR_FG_SCALE, this.fgScale_);\n        if (this.adapter_.isUnbounded()) {\n            this.unboundedCoords_ = {\n                left: Math.round((this.frame_.width / 2) - (this.initialSize_ / 2)),\n                top: Math.round((this.frame_.height / 2) - (this.initialSize_ / 2)),\n            };\n            this.adapter_.updateCssVariable(VAR_LEFT, this.unboundedCoords_.left + \"px\");\n            this.adapter_.updateCssVariable(VAR_TOP, this.unboundedCoords_.top + \"px\");\n        }\n    };\n    return MDCRippleFoundation;\n}(MDCFoundation));\nexport { MDCRippleFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCRippleFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as util from './util';\nexport { util };\nexport * from './component';\nexport * from './constants';\nexport * from './foundation';\n//# sourceMappingURL=index.js.map","/**\n * Stores result from supportsCssVariables to avoid redundant processing to\n * detect CSS custom variable support.\n */\nvar supportsCssVariables_;\nfunction detectEdgePseudoVarBug(windowObj) {\n    // Detect versions of Edge with buggy var() support\n    // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/11495448/\n    var document = windowObj.document;\n    var node = document.createElement('div');\n    node.className = 'mdc-ripple-surface--test-edge-var-bug';\n    // Append to head instead of body because this script might be invoked in the\n    // head, in which case the body doesn't exist yet. The probe works either way.\n    document.head.appendChild(node);\n    // The bug exists if ::before style ends up propagating to the parent element.\n    // Additionally, getComputedStyle returns null in iframes with display: \"none\" in Firefox,\n    // but Firefox is known to support CSS custom properties correctly.\n    // See: https://bugzilla.mozilla.org/show_bug.cgi?id=548397\n    var computedStyle = windowObj.getComputedStyle(node);\n    var hasPseudoVarBug = computedStyle !== null && computedStyle.borderTopStyle === 'solid';\n    if (node.parentNode) {\n        node.parentNode.removeChild(node);\n    }\n    return hasPseudoVarBug;\n}\nexport function supportsCssVariables(windowObj, forceRefresh) {\n    if (forceRefresh === void 0) { forceRefresh = false; }\n    var CSS = windowObj.CSS;\n    var supportsCssVars = supportsCssVariables_;\n    if (typeof supportsCssVariables_ === 'boolean' && !forceRefresh) {\n        return supportsCssVariables_;\n    }\n    var supportsFunctionPresent = CSS && typeof CSS.supports === 'function';\n    if (!supportsFunctionPresent) {\n        return false;\n    }\n    var explicitlySupportsCssVars = CSS.supports('--css-vars', 'yes');\n    // See: https://bugs.webkit.org/show_bug.cgi?id=154669\n    // See: README section on Safari\n    var weAreFeatureDetectingSafari10plus = (CSS.supports('(--css-vars: yes)') &&\n        CSS.supports('color', '#00000000'));\n    if (explicitlySupportsCssVars || weAreFeatureDetectingSafari10plus) {\n        supportsCssVars = !detectEdgePseudoVarBug(windowObj);\n    }\n    else {\n        supportsCssVars = false;\n    }\n    if (!forceRefresh) {\n        supportsCssVariables_ = supportsCssVars;\n    }\n    return supportsCssVars;\n}\nexport function getNormalizedEventCoords(evt, pageOffset, clientRect) {\n    if (!evt) {\n        return { x: 0, y: 0 };\n    }\n    var x = pageOffset.x, y = pageOffset.y;\n    var documentX = x + clientRect.left;\n    var documentY = y + clientRect.top;\n    var normalizedX;\n    var normalizedY;\n    // Determine touch point relative to the ripple container.\n    if (evt.type === 'touchstart') {\n        var touchEvent = evt;\n        normalizedX = touchEvent.changedTouches[0].pageX - documentX;\n        normalizedY = touchEvent.changedTouches[0].pageY - documentY;\n    }\n    else {\n        var mouseEvent = evt;\n        normalizedX = mouseEvent.pageX - documentX;\n        normalizedY = mouseEvent.pageY - documentY;\n    }\n    return { x: normalizedX, y: normalizedY };\n}\n//# sourceMappingURL=util.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCTextFieldCharacterCounterFoundation } from './foundation';\nvar MDCTextFieldCharacterCounter = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldCharacterCounter, _super);\n    function MDCTextFieldCharacterCounter() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextFieldCharacterCounter.attachTo = function (root) {\n        return new MDCTextFieldCharacterCounter(root);\n    };\n    Object.defineProperty(MDCTextFieldCharacterCounter.prototype, \"foundation\", {\n        get: function () {\n            return this.foundation_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldCharacterCounter.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        var adapter = {\n            setContent: function (content) {\n                _this.root_.textContent = content;\n            },\n        };\n        return new MDCTextFieldCharacterCounterFoundation(adapter);\n    };\n    return MDCTextFieldCharacterCounter;\n}(MDCComponent));\nexport { MDCTextFieldCharacterCounter };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    ROOT: 'mdc-text-field-character-counter',\n};\nvar strings = {\n    ROOT_SELECTOR: \".\" + cssClasses.ROOT,\n};\nexport { strings, cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, strings } from './constants';\nvar MDCTextFieldCharacterCounterFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldCharacterCounterFoundation, _super);\n    function MDCTextFieldCharacterCounterFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCTextFieldCharacterCounterFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCTextFieldCharacterCounterFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldCharacterCounterFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldCharacterCounterFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldCharacterCounterAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            return {\n                setContent: function () { return undefined; },\n            };\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldCharacterCounterFoundation.prototype.setCounterValue = function (currentLength, maxLength) {\n        currentLength = Math.min(currentLength, maxLength);\n        this.adapter_.setContent(currentLength + \" / \" + maxLength);\n    };\n    return MDCTextFieldCharacterCounterFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldCharacterCounterFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldCharacterCounterFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './foundation';\nexport { cssClasses as characterCountCssClasses, strings as characterCountStrings } from './constants';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { applyPassive } from '@material/dom/events';\nimport * as ponyfill from '@material/dom/ponyfill';\nimport { MDCFloatingLabel } from '@material/floating-label/component';\nimport { MDCLineRipple } from '@material/line-ripple/component';\nimport { MDCNotchedOutline } from '@material/notched-outline/component';\nimport { MDCRipple } from '@material/ripple/component';\nimport { MDCRippleFoundation } from '@material/ripple/foundation';\nimport { MDCTextFieldCharacterCounter, } from './character-counter/component';\nimport { MDCTextFieldCharacterCounterFoundation } from './character-counter/foundation';\nimport { cssClasses, strings } from './constants';\nimport { MDCTextFieldFoundation } from './foundation';\nimport { MDCTextFieldHelperText, } from './helper-text/component';\nimport { MDCTextFieldHelperTextFoundation } from './helper-text/foundation';\nimport { MDCTextFieldIcon } from './icon/component';\nvar MDCTextField = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextField, _super);\n    function MDCTextField() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextField.attachTo = function (root) {\n        return new MDCTextField(root);\n    };\n    MDCTextField.prototype.initialize = function (rippleFactory, lineRippleFactory, helperTextFactory, characterCounterFactory, iconFactory, labelFactory, outlineFactory) {\n        if (rippleFactory === void 0) { rippleFactory = function (el, foundation) { return new MDCRipple(el, foundation); }; }\n        if (lineRippleFactory === void 0) { lineRippleFactory = function (el) { return new MDCLineRipple(el); }; }\n        if (helperTextFactory === void 0) { helperTextFactory = function (el) { return new MDCTextFieldHelperText(el); }; }\n        if (characterCounterFactory === void 0) { characterCounterFactory = function (el) { return new MDCTextFieldCharacterCounter(el); }; }\n        if (iconFactory === void 0) { iconFactory = function (el) { return new MDCTextFieldIcon(el); }; }\n        if (labelFactory === void 0) { labelFactory = function (el) { return new MDCFloatingLabel(el); }; }\n        if (outlineFactory === void 0) { outlineFactory = function (el) { return new MDCNotchedOutline(el); }; }\n        this.input_ = this.root_.querySelector(strings.INPUT_SELECTOR);\n        var labelElement = this.root_.querySelector(strings.LABEL_SELECTOR);\n        this.label_ = labelElement ? labelFactory(labelElement) : null;\n        var lineRippleElement = this.root_.querySelector(strings.LINE_RIPPLE_SELECTOR);\n        this.lineRipple_ = lineRippleElement ? lineRippleFactory(lineRippleElement) : null;\n        var outlineElement = this.root_.querySelector(strings.OUTLINE_SELECTOR);\n        this.outline_ = outlineElement ? outlineFactory(outlineElement) : null;\n        // Helper text\n        var helperTextStrings = MDCTextFieldHelperTextFoundation.strings;\n        var nextElementSibling = this.root_.nextElementSibling;\n        var hasHelperLine = (nextElementSibling && nextElementSibling.classList.contains(cssClasses.HELPER_LINE));\n        var helperTextEl = hasHelperLine && nextElementSibling && nextElementSibling.querySelector(helperTextStrings.ROOT_SELECTOR);\n        this.helperText_ = helperTextEl ? helperTextFactory(helperTextEl) : null;\n        // Character counter\n        var characterCounterStrings = MDCTextFieldCharacterCounterFoundation.strings;\n        var characterCounterEl = this.root_.querySelector(characterCounterStrings.ROOT_SELECTOR);\n        // If character counter is not found in root element search in sibling element.\n        if (!characterCounterEl && hasHelperLine && nextElementSibling) {\n            characterCounterEl = nextElementSibling.querySelector(characterCounterStrings.ROOT_SELECTOR);\n        }\n        this.characterCounter_ = characterCounterEl ? characterCounterFactory(characterCounterEl) : null;\n        this.leadingIcon_ = null;\n        this.trailingIcon_ = null;\n        var iconElements = this.root_.querySelectorAll(strings.ICON_SELECTOR);\n        if (iconElements.length > 0) {\n            if (iconElements.length > 1) { // Has both icons.\n                this.leadingIcon_ = iconFactory(iconElements[0]);\n                this.trailingIcon_ = iconFactory(iconElements[1]);\n            }\n            else {\n                if (this.root_.classList.contains(cssClasses.WITH_LEADING_ICON)) {\n                    this.leadingIcon_ = iconFactory(iconElements[0]);\n                }\n                else {\n                    this.trailingIcon_ = iconFactory(iconElements[0]);\n                }\n            }\n        }\n        this.ripple = this.createRipple_(rippleFactory);\n    };\n    MDCTextField.prototype.destroy = function () {\n        if (this.ripple) {\n            this.ripple.destroy();\n        }\n        if (this.lineRipple_) {\n            this.lineRipple_.destroy();\n        }\n        if (this.helperText_) {\n            this.helperText_.destroy();\n        }\n        if (this.characterCounter_) {\n            this.characterCounter_.destroy();\n        }\n        if (this.leadingIcon_) {\n            this.leadingIcon_.destroy();\n        }\n        if (this.trailingIcon_) {\n            this.trailingIcon_.destroy();\n        }\n        if (this.label_) {\n            this.label_.destroy();\n        }\n        if (this.outline_) {\n            this.outline_.destroy();\n        }\n        _super.prototype.destroy.call(this);\n    };\n    /**\n     * Initializes the Text Field's internal state based on the environment's\n     * state.\n     */\n    MDCTextField.prototype.initialSyncWithDOM = function () {\n        this.disabled = this.input_.disabled;\n    };\n    Object.defineProperty(MDCTextField.prototype, \"value\", {\n        get: function () {\n            return this.foundation_.getValue();\n        },\n        /**\n         * @param value The value to set on the input.\n         */\n        set: function (value) {\n            this.foundation_.setValue(value);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"disabled\", {\n        get: function () {\n            return this.foundation_.isDisabled();\n        },\n        /**\n         * @param disabled Sets the Text Field disabled or enabled.\n         */\n        set: function (disabled) {\n            this.foundation_.setDisabled(disabled);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"valid\", {\n        get: function () {\n            return this.foundation_.isValid();\n        },\n        /**\n         * @param valid Sets the Text Field valid or invalid.\n         */\n        set: function (valid) {\n            this.foundation_.setValid(valid);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"required\", {\n        get: function () {\n            return this.input_.required;\n        },\n        /**\n         * @param required Sets the Text Field to required.\n         */\n        set: function (required) {\n            this.input_.required = required;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"pattern\", {\n        get: function () {\n            return this.input_.pattern;\n        },\n        /**\n         * @param pattern Sets the input element's validation pattern.\n         */\n        set: function (pattern) {\n            this.input_.pattern = pattern;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"minLength\", {\n        get: function () {\n            return this.input_.minLength;\n        },\n        /**\n         * @param minLength Sets the input element's minLength.\n         */\n        set: function (minLength) {\n            this.input_.minLength = minLength;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"maxLength\", {\n        get: function () {\n            return this.input_.maxLength;\n        },\n        /**\n         * @param maxLength Sets the input element's maxLength.\n         */\n        set: function (maxLength) {\n            // Chrome throws exception if maxLength is set to a value less than zero\n            if (maxLength < 0) {\n                this.input_.removeAttribute('maxLength');\n            }\n            else {\n                this.input_.maxLength = maxLength;\n            }\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"min\", {\n        get: function () {\n            return this.input_.min;\n        },\n        /**\n         * @param min Sets the input element's min.\n         */\n        set: function (min) {\n            this.input_.min = min;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"max\", {\n        get: function () {\n            return this.input_.max;\n        },\n        /**\n         * @param max Sets the input element's max.\n         */\n        set: function (max) {\n            this.input_.max = max;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"step\", {\n        get: function () {\n            return this.input_.step;\n        },\n        /**\n         * @param step Sets the input element's step.\n         */\n        set: function (step) {\n            this.input_.step = step;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"helperTextContent\", {\n        /**\n         * Sets the helper text element content.\n         */\n        set: function (content) {\n            this.foundation_.setHelperTextContent(content);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"leadingIconAriaLabel\", {\n        /**\n         * Sets the aria label of the leading icon.\n         */\n        set: function (label) {\n            this.foundation_.setLeadingIconAriaLabel(label);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"leadingIconContent\", {\n        /**\n         * Sets the text content of the leading icon.\n         */\n        set: function (content) {\n            this.foundation_.setLeadingIconContent(content);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"trailingIconAriaLabel\", {\n        /**\n         * Sets the aria label of the trailing icon.\n         */\n        set: function (label) {\n            this.foundation_.setTrailingIconAriaLabel(label);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"trailingIconContent\", {\n        /**\n         * Sets the text content of the trailing icon.\n         */\n        set: function (content) {\n            this.foundation_.setTrailingIconContent(content);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"useNativeValidation\", {\n        /**\n         * Enables or disables the use of native validation. Use this for custom validation.\n         * @param useNativeValidation Set this to false to ignore native input validation.\n         */\n        set: function (useNativeValidation) {\n            this.foundation_.setUseNativeValidation(useNativeValidation);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /**\n     * Focuses the input element.\n     */\n    MDCTextField.prototype.focus = function () {\n        this.input_.focus();\n    };\n    /**\n     * Recomputes the outline SVG path for the outline element.\n     */\n    MDCTextField.prototype.layout = function () {\n        var openNotch = this.foundation_.shouldFloat;\n        this.foundation_.notchOutline(openNotch);\n    };\n    MDCTextField.prototype.getDefaultFoundation = function () {\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = tslib_1.__assign({}, this.getRootAdapterMethods_(), this.getInputAdapterMethods_(), this.getLabelAdapterMethods_(), this.getLineRippleAdapterMethods_(), this.getOutlineAdapterMethods_());\n        // tslint:enable:object-literal-sort-keys\n        return new MDCTextFieldFoundation(adapter, this.getFoundationMap_());\n    };\n    MDCTextField.prototype.getRootAdapterMethods_ = function () {\n        var _this = this;\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        return {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            registerTextFieldInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterTextFieldInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n            registerValidationAttributeChangeHandler: function (handler) {\n                var getAttributesList = function (mutationsList) {\n                    return mutationsList\n                        .map(function (mutation) { return mutation.attributeName; })\n                        .filter(function (attributeName) { return attributeName; });\n                };\n                var observer = new MutationObserver(function (mutationsList) { return handler(getAttributesList(mutationsList)); });\n                var config = { attributes: true };\n                observer.observe(_this.input_, config);\n                return observer;\n            },\n            deregisterValidationAttributeChangeHandler: function (observer) { return observer.disconnect(); },\n        };\n        // tslint:enable:object-literal-sort-keys\n    };\n    MDCTextField.prototype.getInputAdapterMethods_ = function () {\n        var _this = this;\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        return {\n            getNativeInput: function () { return _this.input_; },\n            isFocused: function () { return document.activeElement === _this.input_; },\n            registerInputInteractionHandler: function (evtType, handler) {\n                return _this.input_.addEventListener(evtType, handler, applyPassive());\n            },\n            deregisterInputInteractionHandler: function (evtType, handler) {\n                return _this.input_.removeEventListener(evtType, handler, applyPassive());\n            },\n        };\n        // tslint:enable:object-literal-sort-keys\n    };\n    MDCTextField.prototype.getLabelAdapterMethods_ = function () {\n        var _this = this;\n        return {\n            floatLabel: function (shouldFloat) { return _this.label_ && _this.label_.float(shouldFloat); },\n            getLabelWidth: function () { return _this.label_ ? _this.label_.getWidth() : 0; },\n            hasLabel: function () { return Boolean(_this.label_); },\n            shakeLabel: function (shouldShake) { return _this.label_ && _this.label_.shake(shouldShake); },\n        };\n    };\n    MDCTextField.prototype.getLineRippleAdapterMethods_ = function () {\n        var _this = this;\n        return {\n            activateLineRipple: function () {\n                if (_this.lineRipple_) {\n                    _this.lineRipple_.activate();\n                }\n            },\n            deactivateLineRipple: function () {\n                if (_this.lineRipple_) {\n                    _this.lineRipple_.deactivate();\n                }\n            },\n            setLineRippleTransformOrigin: function (normalizedX) {\n                if (_this.lineRipple_) {\n                    _this.lineRipple_.setRippleCenter(normalizedX);\n                }\n            },\n        };\n    };\n    MDCTextField.prototype.getOutlineAdapterMethods_ = function () {\n        var _this = this;\n        return {\n            closeOutline: function () { return _this.outline_ && _this.outline_.closeNotch(); },\n            hasOutline: function () { return Boolean(_this.outline_); },\n            notchOutline: function (labelWidth) { return _this.outline_ && _this.outline_.notch(labelWidth); },\n        };\n    };\n    /**\n     * @return A map of all subcomponents to subfoundations.\n     */\n    MDCTextField.prototype.getFoundationMap_ = function () {\n        return {\n            characterCounter: this.characterCounter_ ? this.characterCounter_.foundation : undefined,\n            helperText: this.helperText_ ? this.helperText_.foundation : undefined,\n            leadingIcon: this.leadingIcon_ ? this.leadingIcon_.foundation : undefined,\n            trailingIcon: this.trailingIcon_ ? this.trailingIcon_.foundation : undefined,\n        };\n    };\n    MDCTextField.prototype.createRipple_ = function (rippleFactory) {\n        var _this = this;\n        var isTextArea = this.root_.classList.contains(cssClasses.TEXTAREA);\n        var isOutlined = this.root_.classList.contains(cssClasses.OUTLINED);\n        if (isTextArea || isOutlined) {\n            return null;\n        }\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = tslib_1.__assign({}, MDCRipple.createAdapter(this), { isSurfaceActive: function () { return ponyfill.matches(_this.input_, ':active'); }, registerInteractionHandler: function (evtType, handler) { return _this.input_.addEventListener(evtType, handler, applyPassive()); }, deregisterInteractionHandler: function (evtType, handler) {\n                return _this.input_.removeEventListener(evtType, handler, applyPassive());\n            } });\n        // tslint:enable:object-literal-sort-keys\n        return rippleFactory(this.root_, new MDCRippleFoundation(adapter));\n    };\n    return MDCTextField;\n}(MDCComponent));\nexport { MDCTextField };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar strings = {\n    ARIA_CONTROLS: 'aria-controls',\n    ICON_SELECTOR: '.mdc-text-field__icon',\n    INPUT_SELECTOR: '.mdc-text-field__input',\n    LABEL_SELECTOR: '.mdc-floating-label',\n    LINE_RIPPLE_SELECTOR: '.mdc-line-ripple',\n    OUTLINE_SELECTOR: '.mdc-notched-outline',\n};\nvar cssClasses = {\n    DENSE: 'mdc-text-field--dense',\n    DISABLED: 'mdc-text-field--disabled',\n    FOCUSED: 'mdc-text-field--focused',\n    FULLWIDTH: 'mdc-text-field--fullwidth',\n    HELPER_LINE: 'mdc-text-field-helper-line',\n    INVALID: 'mdc-text-field--invalid',\n    NO_LABEL: 'mdc-text-field--no-label',\n    OUTLINED: 'mdc-text-field--outlined',\n    ROOT: 'mdc-text-field',\n    TEXTAREA: 'mdc-text-field--textarea',\n    WITH_LEADING_ICON: 'mdc-text-field--with-leading-icon',\n    WITH_TRAILING_ICON: 'mdc-text-field--with-trailing-icon',\n};\nvar numbers = {\n    DENSE_LABEL_SCALE: 0.923,\n    LABEL_SCALE: 0.75,\n};\n/**\n * Whitelist based off of https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/HTML5/Constraint_validation\n * under the \"Validation-related attributes\" section.\n */\nvar VALIDATION_ATTR_WHITELIST = [\n    'pattern', 'min', 'max', 'required', 'step', 'minlength', 'maxlength',\n];\n/**\n * Label should always float for these types as they show some UI even if value is empty.\n */\nvar ALWAYS_FLOAT_TYPES = [\n    'color', 'date', 'datetime-local', 'month', 'range', 'time', 'week',\n];\nexport { cssClasses, strings, numbers, VALIDATION_ATTR_WHITELIST, ALWAYS_FLOAT_TYPES };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { ALWAYS_FLOAT_TYPES, cssClasses, numbers, strings, VALIDATION_ATTR_WHITELIST } from './constants';\nvar POINTERDOWN_EVENTS = ['mousedown', 'touchstart'];\nvar INTERACTION_EVENTS = ['click', 'keydown'];\nvar MDCTextFieldFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldFoundation, _super);\n    /**\n     * @param adapter\n     * @param foundationMap Map from subcomponent names to their subfoundations.\n     */\n    function MDCTextFieldFoundation(adapter, foundationMap) {\n        if (foundationMap === void 0) { foundationMap = {}; }\n        var _this = _super.call(this, tslib_1.__assign({}, MDCTextFieldFoundation.defaultAdapter, adapter)) || this;\n        _this.isFocused_ = false;\n        _this.receivedUserInput_ = false;\n        _this.isValid_ = true;\n        _this.useNativeValidation_ = true;\n        _this.helperText_ = foundationMap.helperText;\n        _this.characterCounter_ = foundationMap.characterCounter;\n        _this.leadingIcon_ = foundationMap.leadingIcon;\n        _this.trailingIcon_ = foundationMap.trailingIcon;\n        _this.inputFocusHandler_ = function () { return _this.activateFocus(); };\n        _this.inputBlurHandler_ = function () { return _this.deactivateFocus(); };\n        _this.inputInputHandler_ = function () { return _this.handleInput(); };\n        _this.setPointerXOffset_ = function (evt) { return _this.setTransformOrigin(evt); };\n        _this.textFieldInteractionHandler_ = function () { return _this.handleTextFieldInteraction(); };\n        _this.validationAttributeChangeHandler_ = function (attributesList) { return _this.handleValidationAttributeChange(attributesList); };\n        return _this;\n    }\n    Object.defineProperty(MDCTextFieldFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation.prototype, \"shouldAlwaysFloat_\", {\n        get: function () {\n            var type = this.getNativeInput_().type;\n            return ALWAYS_FLOAT_TYPES.indexOf(type) >= 0;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation.prototype, \"shouldFloat\", {\n        get: function () {\n            return this.shouldAlwaysFloat_ || this.isFocused_ || Boolean(this.getValue()) || this.isBadInput_();\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation.prototype, \"shouldShake\", {\n        get: function () {\n            return !this.isFocused_ && !this.isValid() && Boolean(this.getValue());\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return true; },\n                registerTextFieldInteractionHandler: function () { return undefined; },\n                deregisterTextFieldInteractionHandler: function () { return undefined; },\n                registerInputInteractionHandler: function () { return undefined; },\n                deregisterInputInteractionHandler: function () { return undefined; },\n                registerValidationAttributeChangeHandler: function () { return new MutationObserver(function () { return undefined; }); },\n                deregisterValidationAttributeChangeHandler: function () { return undefined; },\n                getNativeInput: function () { return null; },\n                isFocused: function () { return false; },\n                activateLineRipple: function () { return undefined; },\n                deactivateLineRipple: function () { return undefined; },\n                setLineRippleTransformOrigin: function () { return undefined; },\n                shakeLabel: function () { return undefined; },\n                floatLabel: function () { return undefined; },\n                hasLabel: function () { return false; },\n                getLabelWidth: function () { return 0; },\n                hasOutline: function () { return false; },\n                notchOutline: function () { return undefined; },\n                closeOutline: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldFoundation.prototype.init = function () {\n        var _this = this;\n        if (this.adapter_.isFocused()) {\n            this.inputFocusHandler_();\n        }\n        else if (this.adapter_.hasLabel() && this.shouldFloat) {\n            this.notchOutline(true);\n            this.adapter_.floatLabel(true);\n        }\n        this.adapter_.registerInputInteractionHandler('focus', this.inputFocusHandler_);\n        this.adapter_.registerInputInteractionHandler('blur', this.inputBlurHandler_);\n        this.adapter_.registerInputInteractionHandler('input', this.inputInputHandler_);\n        POINTERDOWN_EVENTS.forEach(function (evtType) {\n            _this.adapter_.registerInputInteractionHandler(evtType, _this.setPointerXOffset_);\n        });\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.registerTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_);\n        });\n        this.validationObserver_ =\n            this.adapter_.registerValidationAttributeChangeHandler(this.validationAttributeChangeHandler_);\n        this.setCharacterCounter_(this.getValue().length);\n    };\n    MDCTextFieldFoundation.prototype.destroy = function () {\n        var _this = this;\n        this.adapter_.deregisterInputInteractionHandler('focus', this.inputFocusHandler_);\n        this.adapter_.deregisterInputInteractionHandler('blur', this.inputBlurHandler_);\n        this.adapter_.deregisterInputInteractionHandler('input', this.inputInputHandler_);\n        POINTERDOWN_EVENTS.forEach(function (evtType) {\n            _this.adapter_.deregisterInputInteractionHandler(evtType, _this.setPointerXOffset_);\n        });\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.deregisterTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_);\n        });\n        this.adapter_.deregisterValidationAttributeChangeHandler(this.validationObserver_);\n    };\n    /**\n     * Handles user interactions with the Text Field.\n     */\n    MDCTextFieldFoundation.prototype.handleTextFieldInteraction = function () {\n        var nativeInput = this.adapter_.getNativeInput();\n        if (nativeInput && nativeInput.disabled) {\n            return;\n        }\n        this.receivedUserInput_ = true;\n    };\n    /**\n     * Handles validation attribute changes\n     */\n    MDCTextFieldFoundation.prototype.handleValidationAttributeChange = function (attributesList) {\n        var _this = this;\n        attributesList.some(function (attributeName) {\n            if (VALIDATION_ATTR_WHITELIST.indexOf(attributeName) > -1) {\n                _this.styleValidity_(true);\n                return true;\n            }\n            return false;\n        });\n        if (attributesList.indexOf('maxlength') > -1) {\n            this.setCharacterCounter_(this.getValue().length);\n        }\n    };\n    /**\n     * Opens/closes the notched outline.\n     */\n    MDCTextFieldFoundation.prototype.notchOutline = function (openNotch) {\n        if (!this.adapter_.hasOutline()) {\n            return;\n        }\n        if (openNotch) {\n            var isDense = this.adapter_.hasClass(cssClasses.DENSE);\n            var labelScale = isDense ? numbers.DENSE_LABEL_SCALE : numbers.LABEL_SCALE;\n            var labelWidth = this.adapter_.getLabelWidth() * labelScale;\n            this.adapter_.notchOutline(labelWidth);\n        }\n        else {\n            this.adapter_.closeOutline();\n        }\n    };\n    /**\n     * Activates the text field focus state.\n     */\n    MDCTextFieldFoundation.prototype.activateFocus = function () {\n        this.isFocused_ = true;\n        this.styleFocused_(this.isFocused_);\n        this.adapter_.activateLineRipple();\n        if (this.adapter_.hasLabel()) {\n            this.notchOutline(this.shouldFloat);\n            this.adapter_.floatLabel(this.shouldFloat);\n            this.adapter_.shakeLabel(this.shouldShake);\n        }\n        if (this.helperText_) {\n            this.helperText_.showToScreenReader();\n        }\n    };\n    /**\n     * Sets the line ripple's transform origin, so that the line ripple activate\n     * animation will animate out from the user's click location.\n     */\n    MDCTextFieldFoundation.prototype.setTransformOrigin = function (evt) {\n        var touches = evt.touches;\n        var targetEvent = touches ? touches[0] : evt;\n        var targetClientRect = targetEvent.target.getBoundingClientRect();\n        var normalizedX = targetEvent.clientX - targetClientRect.left;\n        this.adapter_.setLineRippleTransformOrigin(normalizedX);\n    };\n    /**\n     * Handles input change of text input and text area.\n     */\n    MDCTextFieldFoundation.prototype.handleInput = function () {\n        this.autoCompleteFocus();\n        this.setCharacterCounter_(this.getValue().length);\n    };\n    /**\n     * Activates the Text Field's focus state in cases when the input value\n     * changes without user input (e.g. programmatically).\n     */\n    MDCTextFieldFoundation.prototype.autoCompleteFocus = function () {\n        if (!this.receivedUserInput_) {\n            this.activateFocus();\n        }\n    };\n    /**\n     * Deactivates the Text Field's focus state.\n     */\n    MDCTextFieldFoundation.prototype.deactivateFocus = function () {\n        this.isFocused_ = false;\n        this.adapter_.deactivateLineRipple();\n        var isValid = this.isValid();\n        this.styleValidity_(isValid);\n        this.styleFocused_(this.isFocused_);\n        if (this.adapter_.hasLabel()) {\n            this.notchOutline(this.shouldFloat);\n            this.adapter_.floatLabel(this.shouldFloat);\n            this.adapter_.shakeLabel(this.shouldShake);\n        }\n        if (!this.shouldFloat) {\n            this.receivedUserInput_ = false;\n        }\n    };\n    MDCTextFieldFoundation.prototype.getValue = function () {\n        return this.getNativeInput_().value;\n    };\n    /**\n     * @param value The value to set on the input Element.\n     */\n    MDCTextFieldFoundation.prototype.setValue = function (value) {\n        // Prevent Safari from moving the caret to the end of the input when the value has not changed.\n        if (this.getValue() !== value) {\n            this.getNativeInput_().value = value;\n        }\n        this.setCharacterCounter_(value.length);\n        var isValid = this.isValid();\n        this.styleValidity_(isValid);\n        if (this.adapter_.hasLabel()) {\n            this.notchOutline(this.shouldFloat);\n            this.adapter_.floatLabel(this.shouldFloat);\n            this.adapter_.shakeLabel(this.shouldShake);\n        }\n    };\n    /**\n     * @return The custom validity state, if set; otherwise, the result of a native validity check.\n     */\n    MDCTextFieldFoundation.prototype.isValid = function () {\n        return this.useNativeValidation_\n            ? this.isNativeInputValid_() : this.isValid_;\n    };\n    /**\n     * @param isValid Sets the custom validity state of the Text Field.\n     */\n    MDCTextFieldFoundation.prototype.setValid = function (isValid) {\n        this.isValid_ = isValid;\n        this.styleValidity_(isValid);\n        var shouldShake = !isValid && !this.isFocused_;\n        if (this.adapter_.hasLabel()) {\n            this.adapter_.shakeLabel(shouldShake);\n        }\n    };\n    /**\n     * Enables or disables the use of native validation. Use this for custom validation.\n     * @param useNativeValidation Set this to false to ignore native input validation.\n     */\n    MDCTextFieldFoundation.prototype.setUseNativeValidation = function (useNativeValidation) {\n        this.useNativeValidation_ = useNativeValidation;\n    };\n    MDCTextFieldFoundation.prototype.isDisabled = function () {\n        return this.getNativeInput_().disabled;\n    };\n    /**\n     * @param disabled Sets the text-field disabled or enabled.\n     */\n    MDCTextFieldFoundation.prototype.setDisabled = function (disabled) {\n        this.getNativeInput_().disabled = disabled;\n        this.styleDisabled_(disabled);\n    };\n    /**\n     * @param content Sets the content of the helper text.\n     */\n    MDCTextFieldFoundation.prototype.setHelperTextContent = function (content) {\n        if (this.helperText_) {\n            this.helperText_.setContent(content);\n        }\n    };\n    /**\n     * Sets the aria label of the leading icon.\n     */\n    MDCTextFieldFoundation.prototype.setLeadingIconAriaLabel = function (label) {\n        if (this.leadingIcon_) {\n            this.leadingIcon_.setAriaLabel(label);\n        }\n    };\n    /**\n     * Sets the text content of the leading icon.\n     */\n    MDCTextFieldFoundation.prototype.setLeadingIconContent = function (content) {\n        if (this.leadingIcon_) {\n            this.leadingIcon_.setContent(content);\n        }\n    };\n    /**\n     * Sets the aria label of the trailing icon.\n     */\n    MDCTextFieldFoundation.prototype.setTrailingIconAriaLabel = function (label) {\n        if (this.trailingIcon_) {\n            this.trailingIcon_.setAriaLabel(label);\n        }\n    };\n    /**\n     * Sets the text content of the trailing icon.\n     */\n    MDCTextFieldFoundation.prototype.setTrailingIconContent = function (content) {\n        if (this.trailingIcon_) {\n            this.trailingIcon_.setContent(content);\n        }\n    };\n    /**\n     * Sets character counter values that shows characters used and the total character limit.\n     */\n    MDCTextFieldFoundation.prototype.setCharacterCounter_ = function (currentLength) {\n        if (!this.characterCounter_) {\n            return;\n        }\n        var maxLength = this.getNativeInput_().maxLength;\n        if (maxLength === -1) {\n            throw new Error('MDCTextFieldFoundation: Expected maxlength html property on text input or textarea.');\n        }\n        this.characterCounter_.setCounterValue(currentLength, maxLength);\n    };\n    /**\n     * @return True if the Text Field input fails in converting the user-supplied value.\n     */\n    MDCTextFieldFoundation.prototype.isBadInput_ = function () {\n        // The badInput property is not supported in IE 11 💩.\n        return this.getNativeInput_().validity.badInput || false;\n    };\n    /**\n     * @return The result of native validity checking (ValidityState.valid).\n     */\n    MDCTextFieldFoundation.prototype.isNativeInputValid_ = function () {\n        return this.getNativeInput_().validity.valid;\n    };\n    /**\n     * Styles the component based on the validity state.\n     */\n    MDCTextFieldFoundation.prototype.styleValidity_ = function (isValid) {\n        var INVALID = MDCTextFieldFoundation.cssClasses.INVALID;\n        if (isValid) {\n            this.adapter_.removeClass(INVALID);\n        }\n        else {\n            this.adapter_.addClass(INVALID);\n        }\n        if (this.helperText_) {\n            this.helperText_.setValidity(isValid);\n        }\n    };\n    /**\n     * Styles the component based on the focused state.\n     */\n    MDCTextFieldFoundation.prototype.styleFocused_ = function (isFocused) {\n        var FOCUSED = MDCTextFieldFoundation.cssClasses.FOCUSED;\n        if (isFocused) {\n            this.adapter_.addClass(FOCUSED);\n        }\n        else {\n            this.adapter_.removeClass(FOCUSED);\n        }\n    };\n    /**\n     * Styles the component based on the disabled state.\n     */\n    MDCTextFieldFoundation.prototype.styleDisabled_ = function (isDisabled) {\n        var _a = MDCTextFieldFoundation.cssClasses, DISABLED = _a.DISABLED, INVALID = _a.INVALID;\n        if (isDisabled) {\n            this.adapter_.addClass(DISABLED);\n            this.adapter_.removeClass(INVALID);\n        }\n        else {\n            this.adapter_.removeClass(DISABLED);\n        }\n        if (this.leadingIcon_) {\n            this.leadingIcon_.setDisabled(isDisabled);\n        }\n        if (this.trailingIcon_) {\n            this.trailingIcon_.setDisabled(isDisabled);\n        }\n    };\n    /**\n     * @return The native text input element from the host environment, or an object with the same shape for unit tests.\n     */\n    MDCTextFieldFoundation.prototype.getNativeInput_ = function () {\n        // this.adapter_ may be undefined in foundation unit tests. This happens when testdouble is creating a mock object\n        // and invokes the shouldShake/shouldFloat getters (which in turn call getValue(), which calls this method) before\n        // init() has been called from the MDCTextField constructor. To work around that issue, we return a dummy object.\n        var nativeInput = this.adapter_ ? this.adapter_.getNativeInput() : null;\n        return nativeInput || {\n            disabled: false,\n            maxLength: -1,\n            type: 'input',\n            validity: {\n                badInput: false,\n                valid: true,\n            },\n            value: '',\n        };\n    };\n    return MDCTextFieldFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCTextFieldHelperTextFoundation } from './foundation';\nvar MDCTextFieldHelperText = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldHelperText, _super);\n    function MDCTextFieldHelperText() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextFieldHelperText.attachTo = function (root) {\n        return new MDCTextFieldHelperText(root);\n    };\n    Object.defineProperty(MDCTextFieldHelperText.prototype, \"foundation\", {\n        get: function () {\n            return this.foundation_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldHelperText.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); },\n            removeAttr: function (attr) { return _this.root_.removeAttribute(attr); },\n            setContent: function (content) {\n                _this.root_.textContent = content;\n            },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCTextFieldHelperTextFoundation(adapter);\n    };\n    return MDCTextFieldHelperText;\n}(MDCComponent));\nexport { MDCTextFieldHelperText };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    HELPER_TEXT_PERSISTENT: 'mdc-text-field-helper-text--persistent',\n    HELPER_TEXT_VALIDATION_MSG: 'mdc-text-field-helper-text--validation-msg',\n    ROOT: 'mdc-text-field-helper-text',\n};\nvar strings = {\n    ARIA_HIDDEN: 'aria-hidden',\n    ROLE: 'role',\n    ROOT_SELECTOR: \".\" + cssClasses.ROOT,\n};\nexport { strings, cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, strings } from './constants';\nvar MDCTextFieldHelperTextFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldHelperTextFoundation, _super);\n    function MDCTextFieldHelperTextFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCTextFieldHelperTextFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCTextFieldHelperTextFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldHelperTextFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldHelperTextFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldHelperTextAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return false; },\n                setAttr: function () { return undefined; },\n                removeAttr: function () { return undefined; },\n                setContent: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /**\n     * Sets the content of the helper text field.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setContent = function (content) {\n        this.adapter_.setContent(content);\n    };\n    /**\n     * @param isPersistent Sets the persistency of the helper text.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setPersistent = function (isPersistent) {\n        if (isPersistent) {\n            this.adapter_.addClass(cssClasses.HELPER_TEXT_PERSISTENT);\n        }\n        else {\n            this.adapter_.removeClass(cssClasses.HELPER_TEXT_PERSISTENT);\n        }\n    };\n    /**\n     * @param isValidation True to make the helper text act as an error validation message.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setValidation = function (isValidation) {\n        if (isValidation) {\n            this.adapter_.addClass(cssClasses.HELPER_TEXT_VALIDATION_MSG);\n        }\n        else {\n            this.adapter_.removeClass(cssClasses.HELPER_TEXT_VALIDATION_MSG);\n        }\n    };\n    /**\n     * Makes the helper text visible to the screen reader.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.showToScreenReader = function () {\n        this.adapter_.removeAttr(strings.ARIA_HIDDEN);\n    };\n    /**\n     * Sets the validity of the helper text based on the input validity.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setValidity = function (inputIsValid) {\n        var helperTextIsPersistent = this.adapter_.hasClass(cssClasses.HELPER_TEXT_PERSISTENT);\n        var helperTextIsValidationMsg = this.adapter_.hasClass(cssClasses.HELPER_TEXT_VALIDATION_MSG);\n        var validationMsgNeedsDisplay = helperTextIsValidationMsg && !inputIsValid;\n        if (validationMsgNeedsDisplay) {\n            this.adapter_.setAttr(strings.ROLE, 'alert');\n        }\n        else {\n            this.adapter_.removeAttr(strings.ROLE);\n        }\n        if (!helperTextIsPersistent && !validationMsgNeedsDisplay) {\n            this.hide_();\n        }\n    };\n    /**\n     * Hides the help text from screen readers.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.hide_ = function () {\n        this.adapter_.setAttr(strings.ARIA_HIDDEN, 'true');\n    };\n    return MDCTextFieldHelperTextFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldHelperTextFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldHelperTextFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './foundation';\nexport { cssClasses as helperTextCssClasses, strings as helperTextStrings } from './constants';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCTextFieldIconFoundation } from './foundation';\nvar MDCTextFieldIcon = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldIcon, _super);\n    function MDCTextFieldIcon() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextFieldIcon.attachTo = function (root) {\n        return new MDCTextFieldIcon(root);\n    };\n    Object.defineProperty(MDCTextFieldIcon.prototype, \"foundation\", {\n        get: function () {\n            return this.foundation_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldIcon.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            getAttr: function (attr) { return _this.root_.getAttribute(attr); },\n            setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); },\n            removeAttr: function (attr) { return _this.root_.removeAttribute(attr); },\n            setContent: function (content) {\n                _this.root_.textContent = content;\n            },\n            registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n            notifyIconAction: function () { return _this.emit(MDCTextFieldIconFoundation.strings.ICON_EVENT, {} /* evtData */, true /* shouldBubble */); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCTextFieldIconFoundation(adapter);\n    };\n    return MDCTextFieldIcon;\n}(MDCComponent));\nexport { MDCTextFieldIcon };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar strings = {\n    ICON_EVENT: 'MDCTextField:icon',\n    ICON_ROLE: 'button',\n};\nvar cssClasses = {\n    ROOT: 'mdc-text-field__icon',\n};\nexport { strings, cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, strings } from './constants';\nvar INTERACTION_EVENTS = ['click', 'keydown'];\nvar MDCTextFieldIconFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldIconFoundation, _super);\n    function MDCTextFieldIconFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCTextFieldIconFoundation.defaultAdapter, adapter)) || this;\n        _this.savedTabIndex_ = null;\n        _this.interactionHandler_ = function (evt) { return _this.handleInteraction(evt); };\n        return _this;\n    }\n    Object.defineProperty(MDCTextFieldIconFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldIconFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldIconFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldIconAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                getAttr: function () { return null; },\n                setAttr: function () { return undefined; },\n                removeAttr: function () { return undefined; },\n                setContent: function () { return undefined; },\n                registerInteractionHandler: function () { return undefined; },\n                deregisterInteractionHandler: function () { return undefined; },\n                notifyIconAction: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldIconFoundation.prototype.init = function () {\n        var _this = this;\n        this.savedTabIndex_ = this.adapter_.getAttr('tabindex');\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.registerInteractionHandler(evtType, _this.interactionHandler_);\n        });\n    };\n    MDCTextFieldIconFoundation.prototype.destroy = function () {\n        var _this = this;\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.deregisterInteractionHandler(evtType, _this.interactionHandler_);\n        });\n    };\n    MDCTextFieldIconFoundation.prototype.setDisabled = function (disabled) {\n        if (!this.savedTabIndex_) {\n            return;\n        }\n        if (disabled) {\n            this.adapter_.setAttr('tabindex', '-1');\n            this.adapter_.removeAttr('role');\n        }\n        else {\n            this.adapter_.setAttr('tabindex', this.savedTabIndex_);\n            this.adapter_.setAttr('role', strings.ICON_ROLE);\n        }\n    };\n    MDCTextFieldIconFoundation.prototype.setAriaLabel = function (label) {\n        this.adapter_.setAttr('aria-label', label);\n    };\n    MDCTextFieldIconFoundation.prototype.setContent = function (content) {\n        this.adapter_.setContent(content);\n    };\n    MDCTextFieldIconFoundation.prototype.handleInteraction = function (evt) {\n        var isEnterKey = evt.key === 'Enter' || evt.keyCode === 13;\n        if (evt.type === 'click' || isEnterKey) {\n            this.adapter_.notifyIconAction();\n        }\n    };\n    return MDCTextFieldIconFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldIconFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldIconFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './foundation';\nexport { cssClasses as iconCssClasses, strings as iconStrings } from './constants';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './constants';\nexport * from './foundation';\nexport * from './character-counter/index';\nexport * from './helper-text/index';\nexport * from './icon/index';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCRipple } from '@material/ripple/component';\nimport { cssClasses, strings } from './constants';\nimport { MDCFixedTopAppBarFoundation } from './fixed/foundation';\nimport { MDCShortTopAppBarFoundation } from './short/foundation';\nimport { MDCTopAppBarFoundation } from './standard/foundation';\nvar MDCTopAppBar = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTopAppBar, _super);\n    function MDCTopAppBar() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTopAppBar.attachTo = function (root) {\n        return new MDCTopAppBar(root);\n    };\n    MDCTopAppBar.prototype.initialize = function (rippleFactory) {\n        if (rippleFactory === void 0) { rippleFactory = function (el) { return MDCRipple.attachTo(el); }; }\n        this.navIcon_ = this.root_.querySelector(strings.NAVIGATION_ICON_SELECTOR);\n        // Get all icons in the toolbar and instantiate the ripples\n        var icons = [].slice.call(this.root_.querySelectorAll(strings.ACTION_ITEM_SELECTOR));\n        if (this.navIcon_) {\n            icons.push(this.navIcon_);\n        }\n        this.iconRipples_ = icons.map(function (icon) {\n            var ripple = rippleFactory(icon);\n            ripple.unbounded = true;\n            return ripple;\n        });\n        this.scrollTarget_ = window;\n    };\n    MDCTopAppBar.prototype.initialSyncWithDOM = function () {\n        this.handleNavigationClick_ = this.foundation_.handleNavigationClick.bind(this.foundation_);\n        this.handleWindowResize_ = this.foundation_.handleWindowResize.bind(this.foundation_);\n        this.handleTargetScroll_ = this.foundation_.handleTargetScroll.bind(this.foundation_);\n        this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_);\n        if (this.navIcon_) {\n            this.navIcon_.addEventListener('click', this.handleNavigationClick_);\n        }\n        var isFixed = this.root_.classList.contains(cssClasses.FIXED_CLASS);\n        var isShort = this.root_.classList.contains(cssClasses.SHORT_CLASS);\n        if (!isShort && !isFixed) {\n            window.addEventListener('resize', this.handleWindowResize_);\n        }\n    };\n    MDCTopAppBar.prototype.destroy = function () {\n        this.iconRipples_.forEach(function (iconRipple) { return iconRipple.destroy(); });\n        this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_);\n        if (this.navIcon_) {\n            this.navIcon_.removeEventListener('click', this.handleNavigationClick_);\n        }\n        var isFixed = this.root_.classList.contains(cssClasses.FIXED_CLASS);\n        var isShort = this.root_.classList.contains(cssClasses.SHORT_CLASS);\n        if (!isShort && !isFixed) {\n            window.removeEventListener('resize', this.handleWindowResize_);\n        }\n        _super.prototype.destroy.call(this);\n    };\n    MDCTopAppBar.prototype.setScrollTarget = function (target) {\n        // Remove scroll handler from the previous scroll target\n        this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_);\n        this.scrollTarget_ = target;\n        // Initialize scroll handler on the new scroll target\n        this.handleTargetScroll_ =\n            this.foundation_.handleTargetScroll.bind(this.foundation_);\n        this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_);\n    };\n    MDCTopAppBar.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            setStyle: function (property, value) { return _this.root_.style.setProperty(property, value); },\n            getTopAppBarHeight: function () { return _this.root_.clientHeight; },\n            notifyNavigationIconClicked: function () { return _this.emit(strings.NAVIGATION_EVENT, {}); },\n            getViewportScrollY: function () {\n                var win = _this.scrollTarget_;\n                var el = _this.scrollTarget_;\n                return win.pageYOffset !== undefined ? win.pageYOffset : el.scrollTop;\n            },\n            getTotalActionItems: function () { return _this.root_.querySelectorAll(strings.ACTION_ITEM_SELECTOR).length; },\n        };\n        // tslint:enable:object-literal-sort-keys\n        var foundation;\n        if (this.root_.classList.contains(cssClasses.SHORT_CLASS)) {\n            foundation = new MDCShortTopAppBarFoundation(adapter);\n        }\n        else if (this.root_.classList.contains(cssClasses.FIXED_CLASS)) {\n            foundation = new MDCFixedTopAppBarFoundation(adapter);\n        }\n        else {\n            foundation = new MDCTopAppBarFoundation(adapter);\n        }\n        return foundation;\n    };\n    return MDCTopAppBar;\n}(MDCComponent));\nexport { MDCTopAppBar };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    FIXED_CLASS: 'mdc-top-app-bar--fixed',\n    FIXED_SCROLLED_CLASS: 'mdc-top-app-bar--fixed-scrolled',\n    SHORT_CLASS: 'mdc-top-app-bar--short',\n    SHORT_COLLAPSED_CLASS: 'mdc-top-app-bar--short-collapsed',\n    SHORT_HAS_ACTION_ITEM_CLASS: 'mdc-top-app-bar--short-has-action-item',\n};\nvar numbers = {\n    DEBOUNCE_THROTTLE_RESIZE_TIME_MS: 100,\n    MAX_TOP_APP_BAR_HEIGHT: 128,\n};\nvar strings = {\n    ACTION_ITEM_SELECTOR: '.mdc-top-app-bar__action-item',\n    NAVIGATION_EVENT: 'MDCTopAppBar:nav',\n    NAVIGATION_ICON_SELECTOR: '.mdc-top-app-bar__navigation-icon',\n    ROOT_SELECTOR: '.mdc-top-app-bar',\n    TITLE_SELECTOR: '.mdc-top-app-bar__title',\n};\nexport { cssClasses, numbers, strings };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { cssClasses } from '../constants';\nimport { MDCTopAppBarFoundation } from '../standard/foundation';\nvar MDCFixedTopAppBarFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCFixedTopAppBarFoundation, _super);\n    function MDCFixedTopAppBarFoundation() {\n        var _this = _super !== null && _super.apply(this, arguments) || this;\n        /**\n         * State variable for the previous scroll iteration top app bar state\n         */\n        _this.wasScrolled_ = false;\n        return _this;\n    }\n    /**\n     * Scroll handler for applying/removing the modifier class on the fixed top app bar.\n     * @override\n     */\n    MDCFixedTopAppBarFoundation.prototype.handleTargetScroll = function () {\n        var currentScroll = this.adapter_.getViewportScrollY();\n        if (currentScroll <= 0) {\n            if (this.wasScrolled_) {\n                this.adapter_.removeClass(cssClasses.FIXED_SCROLLED_CLASS);\n                this.wasScrolled_ = false;\n            }\n        }\n        else {\n            if (!this.wasScrolled_) {\n                this.adapter_.addClass(cssClasses.FIXED_SCROLLED_CLASS);\n                this.wasScrolled_ = true;\n            }\n        }\n    };\n    return MDCFixedTopAppBarFoundation;\n}(MDCTopAppBarFoundation));\nexport { MDCFixedTopAppBarFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCFixedTopAppBarFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, numbers, strings } from './constants';\nvar MDCTopAppBarBaseFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTopAppBarBaseFoundation, _super);\n    /* istanbul ignore next: optional argument is not a branch statement */\n    function MDCTopAppBarBaseFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCTopAppBarBaseFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTopAppBarAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return false; },\n                setStyle: function () { return undefined; },\n                getTopAppBarHeight: function () { return 0; },\n                notifyNavigationIconClicked: function () { return undefined; },\n                getViewportScrollY: function () { return 0; },\n                getTotalActionItems: function () { return 0; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /** Other variants of TopAppBar foundation overrides this method */\n    MDCTopAppBarBaseFoundation.prototype.handleTargetScroll = function () { }; // tslint:disable-line:no-empty\n    /** Other variants of TopAppBar foundation overrides this method */\n    MDCTopAppBarBaseFoundation.prototype.handleWindowResize = function () { }; // tslint:disable-line:no-empty\n    MDCTopAppBarBaseFoundation.prototype.handleNavigationClick = function () {\n        this.adapter_.notifyNavigationIconClicked();\n    };\n    return MDCTopAppBarBaseFoundation;\n}(MDCFoundation));\nexport { MDCTopAppBarBaseFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTopAppBarBaseFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './constants';\nexport * from './foundation';\nexport * from './fixed/foundation';\nexport * from './short/foundation';\nexport * from './standard/foundation';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { cssClasses } from '../constants';\nimport { MDCTopAppBarBaseFoundation } from '../foundation';\nvar MDCShortTopAppBarFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCShortTopAppBarFoundation, _super);\n    /* istanbul ignore next: optional argument is not a branch statement */\n    function MDCShortTopAppBarFoundation(adapter) {\n        var _this = _super.call(this, adapter) || this;\n        _this.isCollapsed_ = false;\n        _this.isAlwaysCollapsed_ = false;\n        return _this;\n    }\n    Object.defineProperty(MDCShortTopAppBarFoundation.prototype, \"isCollapsed\", {\n        // Public visibility for backward compatibility.\n        get: function () {\n            return this.isCollapsed_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCShortTopAppBarFoundation.prototype.init = function () {\n        _super.prototype.init.call(this);\n        if (this.adapter_.getTotalActionItems() > 0) {\n            this.adapter_.addClass(cssClasses.SHORT_HAS_ACTION_ITEM_CLASS);\n        }\n        // If initialized with SHORT_COLLAPSED_CLASS, the bar should always be collapsed\n        this.setAlwaysCollapsed(this.adapter_.hasClass(cssClasses.SHORT_COLLAPSED_CLASS));\n    };\n    /**\n     * Set if the short top app bar should always be collapsed.\n     *\n     * @param value When `true`, bar will always be collapsed. When `false`, bar may collapse or expand based on scroll.\n     */\n    MDCShortTopAppBarFoundation.prototype.setAlwaysCollapsed = function (value) {\n        this.isAlwaysCollapsed_ = !!value;\n        if (this.isAlwaysCollapsed_) {\n            this.collapse_();\n        }\n        else {\n            // let maybeCollapseBar_ determine if the bar should be collapsed\n            this.maybeCollapseBar_();\n        }\n    };\n    MDCShortTopAppBarFoundation.prototype.getAlwaysCollapsed = function () {\n        return this.isAlwaysCollapsed_;\n    };\n    /**\n     * Scroll handler for applying/removing the collapsed modifier class on the short top app bar.\n     * @override\n     */\n    MDCShortTopAppBarFoundation.prototype.handleTargetScroll = function () {\n        this.maybeCollapseBar_();\n    };\n    MDCShortTopAppBarFoundation.prototype.maybeCollapseBar_ = function () {\n        if (this.isAlwaysCollapsed_) {\n            return;\n        }\n        var currentScroll = this.adapter_.getViewportScrollY();\n        if (currentScroll <= 0) {\n            if (this.isCollapsed_) {\n                this.uncollapse_();\n            }\n        }\n        else {\n            if (!this.isCollapsed_) {\n                this.collapse_();\n            }\n        }\n    };\n    MDCShortTopAppBarFoundation.prototype.uncollapse_ = function () {\n        this.adapter_.removeClass(cssClasses.SHORT_COLLAPSED_CLASS);\n        this.isCollapsed_ = false;\n    };\n    MDCShortTopAppBarFoundation.prototype.collapse_ = function () {\n        this.adapter_.addClass(cssClasses.SHORT_COLLAPSED_CLASS);\n        this.isCollapsed_ = true;\n    };\n    return MDCShortTopAppBarFoundation;\n}(MDCTopAppBarBaseFoundation));\nexport { MDCShortTopAppBarFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCShortTopAppBarFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { numbers } from '../constants';\nimport { MDCTopAppBarBaseFoundation } from '../foundation';\nvar INITIAL_VALUE = 0;\nvar MDCTopAppBarFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTopAppBarFoundation, _super);\n    /* istanbul ignore next: optional argument is not a branch statement */\n    function MDCTopAppBarFoundation(adapter) {\n        var _this = _super.call(this, adapter) || this;\n        /**\n         * Indicates if the top app bar was docked in the previous scroll handler iteration.\n         */\n        _this.wasDocked_ = true;\n        /**\n         * Indicates if the top app bar is docked in the fully shown position.\n         */\n        _this.isDockedShowing_ = true;\n        /**\n         * Variable for current scroll position of the top app bar\n         */\n        _this.currentAppBarOffsetTop_ = 0;\n        /**\n         * Used to prevent the top app bar from being scrolled out of view during resize events\n         */\n        _this.isCurrentlyBeingResized_ = false;\n        /**\n         * The timeout that's used to throttle the resize events\n         */\n        _this.resizeThrottleId_ = INITIAL_VALUE;\n        /**\n         * The timeout that's used to debounce toggling the isCurrentlyBeingResized_ variable after a resize\n         */\n        _this.resizeDebounceId_ = INITIAL_VALUE;\n        _this.lastScrollPosition_ = _this.adapter_.getViewportScrollY();\n        _this.topAppBarHeight_ = _this.adapter_.getTopAppBarHeight();\n        return _this;\n    }\n    MDCTopAppBarFoundation.prototype.destroy = function () {\n        _super.prototype.destroy.call(this);\n        this.adapter_.setStyle('top', '');\n    };\n    /**\n     * Scroll handler for the default scroll behavior of the top app bar.\n     * @override\n     */\n    MDCTopAppBarFoundation.prototype.handleTargetScroll = function () {\n        var currentScrollPosition = Math.max(this.adapter_.getViewportScrollY(), 0);\n        var diff = currentScrollPosition - this.lastScrollPosition_;\n        this.lastScrollPosition_ = currentScrollPosition;\n        // If the window is being resized the lastScrollPosition_ needs to be updated but the\n        // current scroll of the top app bar should stay in the same position.\n        if (!this.isCurrentlyBeingResized_) {\n            this.currentAppBarOffsetTop_ -= diff;\n            if (this.currentAppBarOffsetTop_ > 0) {\n                this.currentAppBarOffsetTop_ = 0;\n            }\n            else if (Math.abs(this.currentAppBarOffsetTop_) > this.topAppBarHeight_) {\n                this.currentAppBarOffsetTop_ = -this.topAppBarHeight_;\n            }\n            this.moveTopAppBar_();\n        }\n    };\n    /**\n     * Top app bar resize handler that throttle/debounce functions that execute updates.\n     * @override\n     */\n    MDCTopAppBarFoundation.prototype.handleWindowResize = function () {\n        var _this = this;\n        // Throttle resize events 10 p/s\n        if (!this.resizeThrottleId_) {\n            this.resizeThrottleId_ = setTimeout(function () {\n                _this.resizeThrottleId_ = INITIAL_VALUE;\n                _this.throttledResizeHandler_();\n            }, numbers.DEBOUNCE_THROTTLE_RESIZE_TIME_MS);\n        }\n        this.isCurrentlyBeingResized_ = true;\n        if (this.resizeDebounceId_) {\n            clearTimeout(this.resizeDebounceId_);\n        }\n        this.resizeDebounceId_ = setTimeout(function () {\n            _this.handleTargetScroll();\n            _this.isCurrentlyBeingResized_ = false;\n            _this.resizeDebounceId_ = INITIAL_VALUE;\n        }, numbers.DEBOUNCE_THROTTLE_RESIZE_TIME_MS);\n    };\n    /**\n     * Function to determine if the DOM needs to update.\n     */\n    MDCTopAppBarFoundation.prototype.checkForUpdate_ = function () {\n        var offscreenBoundaryTop = -this.topAppBarHeight_;\n        var hasAnyPixelsOffscreen = this.currentAppBarOffsetTop_ < 0;\n        var hasAnyPixelsOnscreen = this.currentAppBarOffsetTop_ > offscreenBoundaryTop;\n        var partiallyShowing = hasAnyPixelsOffscreen && hasAnyPixelsOnscreen;\n        // If it's partially showing, it can't be docked.\n        if (partiallyShowing) {\n            this.wasDocked_ = false;\n        }\n        else {\n            // Not previously docked and not partially showing, it's now docked.\n            if (!this.wasDocked_) {\n                this.wasDocked_ = true;\n                return true;\n            }\n            else if (this.isDockedShowing_ !== hasAnyPixelsOnscreen) {\n                this.isDockedShowing_ = hasAnyPixelsOnscreen;\n                return true;\n            }\n        }\n        return partiallyShowing;\n    };\n    /**\n     * Function to move the top app bar if needed.\n     */\n    MDCTopAppBarFoundation.prototype.moveTopAppBar_ = function () {\n        if (this.checkForUpdate_()) {\n            // Once the top app bar is fully hidden we use the max potential top app bar height as our offset\n            // so the top app bar doesn't show if the window resizes and the new height > the old height.\n            var offset = this.currentAppBarOffsetTop_;\n            if (Math.abs(offset) >= this.topAppBarHeight_) {\n                offset = -numbers.MAX_TOP_APP_BAR_HEIGHT;\n            }\n            this.adapter_.setStyle('top', offset + 'px');\n        }\n    };\n    /**\n     * Throttled function that updates the top app bar scrolled values if the\n     * top app bar height changes.\n     */\n    MDCTopAppBarFoundation.prototype.throttledResizeHandler_ = function () {\n        var currentHeight = this.adapter_.getTopAppBarHeight();\n        if (this.topAppBarHeight_ !== currentHeight) {\n            this.wasDocked_ = false;\n            // Since the top app bar has a different height depending on the screen width, this\n            // will ensure that the top app bar remains in the correct location if\n            // completely hidden and a resize makes the top app bar a different height.\n            this.currentAppBarOffsetTop_ -= this.topAppBarHeight_ - currentHeight;\n            this.topAppBarHeight_ = currentHeight;\n        }\n        this.handleTargetScroll();\n    };\n    return MDCTopAppBarFoundation;\n}(MDCTopAppBarBaseFoundation));\nexport { MDCTopAppBarFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTopAppBarFoundation;\n//# sourceMappingURL=foundation.js.map","(function(f){if(typeof exports===\"object\"&&typeof module!==\"undefined\"){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.Parallax = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){\n/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n\n},{}],2:[function(require,module,exports){\n(function (process){\n// Generated by CoffeeScript 1.12.2\n(function() {\n  var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - nodeLoadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    moduleLoadTime = getNanoSeconds();\n    upTime = process.uptime() * 1e9;\n    nodeLoadTime = moduleLoadTime - upTime;\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n\n\n\n}).call(this,require('_process'))\n\n},{\"_process\":3}],3:[function(require,module,exports){\n// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n},{}],4:[function(require,module,exports){\n(function (global){\nvar now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"performance-now\":2}],5:[function(require,module,exports){\n'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n* Parallax.js\n* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org\n* @description Creates a parallax effect between an array of layers,\n*              driving the motion from the gyroscope output of a smartdevice.\n*              If no gyroscope is available, the cursor position is used.\n*/\n\nvar rqAnFr = require('raf');\nvar objectAssign = require('object-assign');\n\nvar helpers = {\n  propertyCache: {},\n  vendors: [null, ['-webkit-', 'webkit'], ['-moz-', 'Moz'], ['-o-', 'O'], ['-ms-', 'ms']],\n\n  clamp: function clamp(value, min, max) {\n    return min < max ? value < min ? min : value > max ? max : value : value < max ? max : value > min ? min : value;\n  },\n  data: function data(element, name) {\n    return helpers.deserialize(element.getAttribute('data-' + name));\n  },\n  deserialize: function deserialize(value) {\n    if (value === 'true') {\n      return true;\n    } else if (value === 'false') {\n      return false;\n    } else if (value === 'null') {\n      return null;\n    } else if (!isNaN(parseFloat(value)) && isFinite(value)) {\n      return parseFloat(value);\n    } else {\n      return value;\n    }\n  },\n  camelCase: function camelCase(value) {\n    return value.replace(/-+(.)?/g, function (match, character) {\n      return character ? character.toUpperCase() : '';\n    });\n  },\n  accelerate: function accelerate(element) {\n    helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)');\n    helpers.css(element, 'transform-style', 'preserve-3d');\n    helpers.css(element, 'backface-visibility', 'hidden');\n  },\n  transformSupport: function transformSupport(value) {\n    var element = document.createElement('div'),\n        propertySupport = false,\n        propertyValue = null,\n        featureSupport = false,\n        cssProperty = null,\n        jsProperty = null;\n    for (var i = 0, l = helpers.vendors.length; i < l; i++) {\n      if (helpers.vendors[i] !== null) {\n        cssProperty = helpers.vendors[i][0] + 'transform';\n        jsProperty = helpers.vendors[i][1] + 'Transform';\n      } else {\n        cssProperty = 'transform';\n        jsProperty = 'transform';\n      }\n      if (element.style[jsProperty] !== undefined) {\n        propertySupport = true;\n        break;\n      }\n    }\n    switch (value) {\n      case '2D':\n        featureSupport = propertySupport;\n        break;\n      case '3D':\n        if (propertySupport) {\n          var body = document.body || document.createElement('body'),\n              documentElement = document.documentElement,\n              documentOverflow = documentElement.style.overflow,\n              isCreatedBody = false;\n\n          if (!document.body) {\n            isCreatedBody = true;\n            documentElement.style.overflow = 'hidden';\n            documentElement.appendChild(body);\n            body.style.overflow = 'hidden';\n            body.style.background = '';\n          }\n\n          body.appendChild(element);\n          element.style[jsProperty] = 'translate3d(1px,1px,1px)';\n          propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty);\n          featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none';\n          documentElement.style.overflow = documentOverflow;\n          body.removeChild(element);\n\n          if (isCreatedBody) {\n            body.removeAttribute('style');\n            body.parentNode.removeChild(body);\n          }\n        }\n        break;\n    }\n    return featureSupport;\n  },\n  css: function css(element, property, value) {\n    var jsProperty = helpers.propertyCache[property];\n    if (!jsProperty) {\n      for (var i = 0, l = helpers.vendors.length; i < l; i++) {\n        if (helpers.vendors[i] !== null) {\n          jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property);\n        } else {\n          jsProperty = property;\n        }\n        if (element.style[jsProperty] !== undefined) {\n          helpers.propertyCache[property] = jsProperty;\n          break;\n        }\n      }\n    }\n    element.style[jsProperty] = value;\n  }\n};\n\nvar MAGIC_NUMBER = 30,\n    DEFAULTS = {\n  relativeInput: false,\n  clipRelativeInput: false,\n  inputElement: null,\n  hoverOnly: false,\n  calibrationThreshold: 100,\n  calibrationDelay: 500,\n  supportDelay: 500,\n  calibrateX: false,\n  calibrateY: true,\n  invertX: true,\n  invertY: true,\n  limitX: false,\n  limitY: false,\n  scalarX: 10.0,\n  scalarY: 10.0,\n  frictionX: 0.1,\n  frictionY: 0.1,\n  originX: 0.5,\n  originY: 0.5,\n  pointerEvents: false,\n  precision: 1,\n  onReady: null,\n  selector: null\n};\n\nvar Parallax = function () {\n  function Parallax(element, options) {\n    _classCallCheck(this, Parallax);\n\n    this.element = element;\n\n    var data = {\n      calibrateX: helpers.data(this.element, 'calibrate-x'),\n      calibrateY: helpers.data(this.element, 'calibrate-y'),\n      invertX: helpers.data(this.element, 'invert-x'),\n      invertY: helpers.data(this.element, 'invert-y'),\n      limitX: helpers.data(this.element, 'limit-x'),\n      limitY: helpers.data(this.element, 'limit-y'),\n      scalarX: helpers.data(this.element, 'scalar-x'),\n      scalarY: helpers.data(this.element, 'scalar-y'),\n      frictionX: helpers.data(this.element, 'friction-x'),\n      frictionY: helpers.data(this.element, 'friction-y'),\n      originX: helpers.data(this.element, 'origin-x'),\n      originY: helpers.data(this.element, 'origin-y'),\n      pointerEvents: helpers.data(this.element, 'pointer-events'),\n      precision: helpers.data(this.element, 'precision'),\n      relativeInput: helpers.data(this.element, 'relative-input'),\n      clipRelativeInput: helpers.data(this.element, 'clip-relative-input'),\n      hoverOnly: helpers.data(this.element, 'hover-only'),\n      inputElement: document.querySelector(helpers.data(this.element, 'input-element')),\n      selector: helpers.data(this.element, 'selector')\n    };\n\n    for (var key in data) {\n      if (data[key] === null) {\n        delete data[key];\n      }\n    }\n\n    objectAssign(this, DEFAULTS, data, options);\n\n    if (!this.inputElement) {\n      this.inputElement = this.element;\n    }\n\n    this.calibrationTimer = null;\n    this.calibrationFlag = true;\n    this.enabled = false;\n    this.depthsX = [];\n    this.depthsY = [];\n    this.raf = null;\n\n    this.bounds = null;\n    this.elementPositionX = 0;\n    this.elementPositionY = 0;\n    this.elementWidth = 0;\n    this.elementHeight = 0;\n\n    this.elementCenterX = 0;\n    this.elementCenterY = 0;\n\n    this.elementRangeX = 0;\n    this.elementRangeY = 0;\n\n    this.calibrationX = 0;\n    this.calibrationY = 0;\n\n    this.inputX = 0;\n    this.inputY = 0;\n\n    this.motionX = 0;\n    this.motionY = 0;\n\n    this.velocityX = 0;\n    this.velocityY = 0;\n\n    this.onMouseMove = this.onMouseMove.bind(this);\n    this.onDeviceOrientation = this.onDeviceOrientation.bind(this);\n    this.onDeviceMotion = this.onDeviceMotion.bind(this);\n    this.onOrientationTimer = this.onOrientationTimer.bind(this);\n    this.onMotionTimer = this.onMotionTimer.bind(this);\n    this.onCalibrationTimer = this.onCalibrationTimer.bind(this);\n    this.onAnimationFrame = this.onAnimationFrame.bind(this);\n    this.onWindowResize = this.onWindowResize.bind(this);\n\n    this.windowWidth = null;\n    this.windowHeight = null;\n    this.windowCenterX = null;\n    this.windowCenterY = null;\n    this.windowRadiusX = null;\n    this.windowRadiusY = null;\n    this.portrait = false;\n    this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i);\n    this.motionSupport = !!window.DeviceMotionEvent && !this.desktop;\n    this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop;\n    this.orientationStatus = 0;\n    this.motionStatus = 0;\n\n    this.initialise();\n  }\n\n  _createClass(Parallax, [{\n    key: 'initialise',\n    value: function initialise() {\n      if (this.transform2DSupport === undefined) {\n        this.transform2DSupport = helpers.transformSupport('2D');\n        this.transform3DSupport = helpers.transformSupport('3D');\n      }\n\n      // Configure Context Styles\n      if (this.transform3DSupport) {\n        helpers.accelerate(this.element);\n      }\n\n      var style = window.getComputedStyle(this.element);\n      if (style.getPropertyValue('position') === 'static') {\n        this.element.style.position = 'relative';\n      }\n\n      // Pointer events\n      if (!this.pointerEvents) {\n        this.element.style.pointerEvents = 'none';\n      }\n\n      // Setup\n      this.updateLayers();\n      this.updateDimensions();\n      this.enable();\n      this.queueCalibration(this.calibrationDelay);\n    }\n  }, {\n    key: 'doReadyCallback',\n    value: function doReadyCallback() {\n      if (this.onReady) {\n        this.onReady();\n      }\n    }\n  }, {\n    key: 'updateLayers',\n    value: function updateLayers() {\n      if (this.selector) {\n        this.layers = this.element.querySelectorAll(this.selector);\n      } else {\n        this.layers = this.element.children;\n      }\n\n      if (!this.layers.length) {\n        console.warn('ParallaxJS: Your scene does not have any layers.');\n      }\n\n      this.depthsX = [];\n      this.depthsY = [];\n\n      for (var index = 0; index < this.layers.length; index++) {\n        var layer = this.layers[index];\n\n        if (this.transform3DSupport) {\n          helpers.accelerate(layer);\n        }\n\n        layer.style.position = index ? 'absolute' : 'relative';\n        layer.style.display = 'block';\n        layer.style.left = 0;\n        layer.style.top = 0;\n\n        var depth = helpers.data(layer, 'depth') || 0;\n        this.depthsX.push(helpers.data(layer, 'depth-x') || depth);\n        this.depthsY.push(helpers.data(layer, 'depth-y') || depth);\n      }\n    }\n  }, {\n    key: 'updateDimensions',\n    value: function updateDimensions() {\n      this.windowWidth = window.innerWidth;\n      this.windowHeight = window.innerHeight;\n      this.windowCenterX = this.windowWidth * this.originX;\n      this.windowCenterY = this.windowHeight * this.originY;\n      this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX);\n      this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY);\n    }\n  }, {\n    key: 'updateBounds',\n    value: function updateBounds() {\n      this.bounds = this.inputElement.getBoundingClientRect();\n      this.elementPositionX = this.bounds.left;\n      this.elementPositionY = this.bounds.top;\n      this.elementWidth = this.bounds.width;\n      this.elementHeight = this.bounds.height;\n      this.elementCenterX = this.elementWidth * this.originX;\n      this.elementCenterY = this.elementHeight * this.originY;\n      this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX);\n      this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY);\n    }\n  }, {\n    key: 'queueCalibration',\n    value: function queueCalibration(delay) {\n      clearTimeout(this.calibrationTimer);\n      this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay);\n    }\n  }, {\n    key: 'enable',\n    value: function enable() {\n      if (this.enabled) {\n        return;\n      }\n      this.enabled = true;\n\n      if (this.orientationSupport) {\n        this.portrait = false;\n        window.addEventListener('deviceorientation', this.onDeviceOrientation);\n        this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay);\n      } else if (this.motionSupport) {\n        this.portrait = false;\n        window.addEventListener('devicemotion', this.onDeviceMotion);\n        this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay);\n      } else {\n        this.calibrationX = 0;\n        this.calibrationY = 0;\n        this.portrait = false;\n        window.addEventListener('mousemove', this.onMouseMove);\n        this.doReadyCallback();\n      }\n\n      window.addEventListener('resize', this.onWindowResize);\n      this.raf = rqAnFr(this.onAnimationFrame);\n    }\n  }, {\n    key: 'disable',\n    value: function disable() {\n      if (!this.enabled) {\n        return;\n      }\n      this.enabled = false;\n\n      if (this.orientationSupport) {\n        window.removeEventListener('deviceorientation', this.onDeviceOrientation);\n      } else if (this.motionSupport) {\n        window.removeEventListener('devicemotion', this.onDeviceMotion);\n      } else {\n        window.removeEventListener('mousemove', this.onMouseMove);\n      }\n\n      window.removeEventListener('resize', this.onWindowResize);\n      rqAnFr.cancel(this.raf);\n    }\n  }, {\n    key: 'calibrate',\n    value: function calibrate(x, y) {\n      this.calibrateX = x === undefined ? this.calibrateX : x;\n      this.calibrateY = y === undefined ? this.calibrateY : y;\n    }\n  }, {\n    key: 'invert',\n    value: function invert(x, y) {\n      this.invertX = x === undefined ? this.invertX : x;\n      this.invertY = y === undefined ? this.invertY : y;\n    }\n  }, {\n    key: 'friction',\n    value: function friction(x, y) {\n      this.frictionX = x === undefined ? this.frictionX : x;\n      this.frictionY = y === undefined ? this.frictionY : y;\n    }\n  }, {\n    key: 'scalar',\n    value: function scalar(x, y) {\n      this.scalarX = x === undefined ? this.scalarX : x;\n      this.scalarY = y === undefined ? this.scalarY : y;\n    }\n  }, {\n    key: 'limit',\n    value: function limit(x, y) {\n      this.limitX = x === undefined ? this.limitX : x;\n      this.limitY = y === undefined ? this.limitY : y;\n    }\n  }, {\n    key: 'origin',\n    value: function origin(x, y) {\n      this.originX = x === undefined ? this.originX : x;\n      this.originY = y === undefined ? this.originY : y;\n    }\n  }, {\n    key: 'setInputElement',\n    value: function setInputElement(element) {\n      this.inputElement = element;\n      this.updateDimensions();\n    }\n  }, {\n    key: 'setPosition',\n    value: function setPosition(element, x, y) {\n      x = x.toFixed(this.precision) + 'px';\n      y = y.toFixed(this.precision) + 'px';\n      if (this.transform3DSupport) {\n        helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)');\n      } else if (this.transform2DSupport) {\n        helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')');\n      } else {\n        element.style.left = x;\n        element.style.top = y;\n      }\n    }\n  }, {\n    key: 'onOrientationTimer',\n    value: function onOrientationTimer() {\n      if (this.orientationSupport && this.orientationStatus === 0) {\n        this.disable();\n        this.orientationSupport = false;\n        this.enable();\n      } else {\n        this.doReadyCallback();\n      }\n    }\n  }, {\n    key: 'onMotionTimer',\n    value: function onMotionTimer() {\n      if (this.motionSupport && this.motionStatus === 0) {\n        this.disable();\n        this.motionSupport = false;\n        this.enable();\n      } else {\n        this.doReadyCallback();\n      }\n    }\n  }, {\n    key: 'onCalibrationTimer',\n    value: function onCalibrationTimer() {\n      this.calibrationFlag = true;\n    }\n  }, {\n    key: 'onWindowResize',\n    value: function onWindowResize() {\n      this.updateDimensions();\n    }\n  }, {\n    key: 'onAnimationFrame',\n    value: function onAnimationFrame() {\n      this.updateBounds();\n      var calibratedInputX = this.inputX - this.calibrationX,\n          calibratedInputY = this.inputY - this.calibrationY;\n      if (Math.abs(calibratedInputX) > this.calibrationThreshold || Math.abs(calibratedInputY) > this.calibrationThreshold) {\n        this.queueCalibration(0);\n      }\n      if (this.portrait) {\n        this.motionX = this.calibrateX ? calibratedInputY : this.inputY;\n        this.motionY = this.calibrateY ? calibratedInputX : this.inputX;\n      } else {\n        this.motionX = this.calibrateX ? calibratedInputX : this.inputX;\n        this.motionY = this.calibrateY ? calibratedInputY : this.inputY;\n      }\n      this.motionX *= this.elementWidth * (this.scalarX / 100);\n      this.motionY *= this.elementHeight * (this.scalarY / 100);\n      if (!isNaN(parseFloat(this.limitX))) {\n        this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX);\n      }\n      if (!isNaN(parseFloat(this.limitY))) {\n        this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY);\n      }\n      this.velocityX += (this.motionX - this.velocityX) * this.frictionX;\n      this.velocityY += (this.motionY - this.velocityY) * this.frictionY;\n      for (var index = 0; index < this.layers.length; index++) {\n        var layer = this.layers[index],\n            depthX = this.depthsX[index],\n            depthY = this.depthsY[index],\n            xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)),\n            yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1));\n        this.setPosition(layer, xOffset, yOffset);\n      }\n      this.raf = rqAnFr(this.onAnimationFrame);\n    }\n  }, {\n    key: 'rotate',\n    value: function rotate(beta, gamma) {\n      // Extract Rotation\n      var x = (beta || 0) / MAGIC_NUMBER,\n          //  -90 :: 90\n      y = (gamma || 0) / MAGIC_NUMBER; // -180 :: 180\n\n      // Detect Orientation Change\n      var portrait = this.windowHeight > this.windowWidth;\n      if (this.portrait !== portrait) {\n        this.portrait = portrait;\n        this.calibrationFlag = true;\n      }\n\n      if (this.calibrationFlag) {\n        this.calibrationFlag = false;\n        this.calibrationX = x;\n        this.calibrationY = y;\n      }\n\n      this.inputX = x;\n      this.inputY = y;\n    }\n  }, {\n    key: 'onDeviceOrientation',\n    value: function onDeviceOrientation(event) {\n      var beta = event.beta;\n      var gamma = event.gamma;\n      if (beta !== null && gamma !== null) {\n        this.orientationStatus = 1;\n        this.rotate(beta, gamma);\n      }\n    }\n  }, {\n    key: 'onDeviceMotion',\n    value: function onDeviceMotion(event) {\n      var beta = event.rotationRate.beta;\n      var gamma = event.rotationRate.gamma;\n      if (beta !== null && gamma !== null) {\n        this.motionStatus = 1;\n        this.rotate(beta, gamma);\n      }\n    }\n  }, {\n    key: 'onMouseMove',\n    value: function onMouseMove(event) {\n      var clientX = event.clientX,\n          clientY = event.clientY;\n\n      // reset input to center if hoverOnly is set and we're not hovering the element\n      if (this.hoverOnly && (clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth || clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight)) {\n        this.inputX = 0;\n        this.inputY = 0;\n        return;\n      }\n\n      if (this.relativeInput) {\n        // Clip mouse coordinates inside element bounds.\n        if (this.clipRelativeInput) {\n          clientX = Math.max(clientX, this.elementPositionX);\n          clientX = Math.min(clientX, this.elementPositionX + this.elementWidth);\n          clientY = Math.max(clientY, this.elementPositionY);\n          clientY = Math.min(clientY, this.elementPositionY + this.elementHeight);\n        }\n        // Calculate input relative to the element.\n        if (this.elementRangeX && this.elementRangeY) {\n          this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX;\n          this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY;\n        }\n      } else {\n        // Calculate input relative to the window.\n        if (this.windowRadiusX && this.windowRadiusY) {\n          this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX;\n          this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY;\n        }\n      }\n    }\n  }, {\n    key: 'destroy',\n    value: function destroy() {\n      this.disable();\n\n      clearTimeout(this.calibrationTimer);\n      clearTimeout(this.detectionTimer);\n\n      this.element.removeAttribute('style');\n      for (var index = 0; index < this.layers.length; index++) {\n        this.layers[index].removeAttribute('style');\n      }\n\n      delete this.element;\n      delete this.layers;\n    }\n  }, {\n    key: 'version',\n    value: function version() {\n      return '3.1.0';\n    }\n  }]);\n\n  return Parallax;\n}();\n\nmodule.exports = Parallax;\n\n},{\"object-assign\":1,\"raf\":4}]},{},[5])(5)\n});\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/object-assign/index.js","node_modules/performance-now/lib/performance-now.js","node_modules/process/browser.js","node_modules/raf/index.js","src/parallax.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACxLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACxEA;;;;;;;;AAQA,IAAM,SAAS,QAAQ,KAAR,CAAf;AACA,IAAM,eAAe,QAAQ,eAAR,CAArB;;AAEA,IAAM,UAAU;AACd,iBAAe,EADD;AAEd,WAAS,CAAC,IAAD,EAAO,CAAC,UAAD,EAAY,QAAZ,CAAP,EAA8B,CAAC,OAAD,EAAS,KAAT,CAA9B,EAA+C,CAAC,KAAD,EAAO,GAAP,CAA/C,EAA4D,CAAC,MAAD,EAAQ,IAAR,CAA5D,CAFK;;AAId,OAJc,iBAIR,KAJQ,EAID,GAJC,EAII,GAJJ,EAIS;AACrB,WAAO,MAAM,GAAN,GACF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,KADtC,GAEF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,K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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated by CoffeeScript 1.12.2\n(function() {\n  var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - nodeLoadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    moduleLoadTime = getNanoSeconds();\n    upTime = process.uptime() * 1e9;\n    nodeLoadTime = moduleLoadTime - upTime;\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n\n//# sourceMappingURL=performance-now.js.map\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","var now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n","/**\n* Parallax.js\n* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org\n* @description Creates a parallax effect between an array of layers,\n*              driving the motion from the gyroscope output of a smartdevice.\n*              If no gyroscope is available, the cursor position is used.\n*/\n\nconst rqAnFr = require('raf')\nconst objectAssign = require('object-assign')\n\nconst helpers = {\n  propertyCache: {},\n  vendors: [null, ['-webkit-','webkit'], ['-moz-','Moz'], ['-o-','O'], ['-ms-','ms']],\n\n  clamp(value, min, max) {\n    return min < max\n      ? (value < min ? min : value > max ? max : value)\n      : (value < max ? max : value > min ? min : value)\n  },\n\n  data(element, name) {\n    return helpers.deserialize(element.getAttribute('data-'+name))\n  },\n\n  deserialize(value) {\n    if (value === 'true') {\n      return true\n    } else if (value === 'false') {\n      return false\n    } else if (value === 'null') {\n      return null\n    } else if (!isNaN(parseFloat(value)) && isFinite(value)) {\n      return parseFloat(value)\n    } else {\n      return value\n    }\n  },\n\n  camelCase(value) {\n    return value.replace(/-+(.)?/g, (match, character) => {\n      return character ? character.toUpperCase() : ''\n    })\n  },\n\n  accelerate(element) {\n    helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)')\n    helpers.css(element, 'transform-style', 'preserve-3d')\n    helpers.css(element, 'backface-visibility', 'hidden')\n  },\n\n  transformSupport(value) {\n    let element = document.createElement('div'),\n        propertySupport = false,\n        propertyValue = null,\n        featureSupport = false,\n        cssProperty = null,\n        jsProperty = null\n    for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n      if (helpers.vendors[i] !== null) {\n        cssProperty = helpers.vendors[i][0] + 'transform'\n        jsProperty = helpers.vendors[i][1] + 'Transform'\n      } else {\n        cssProperty = 'transform'\n        jsProperty = 'transform'\n      }\n      if (element.style[jsProperty] !== undefined) {\n        propertySupport = true\n        break\n      }\n    }\n    switch(value) {\n      case '2D':\n        featureSupport = propertySupport\n        break\n      case '3D':\n        if (propertySupport) {\n          let body = document.body || document.createElement('body'),\n              documentElement = document.documentElement,\n              documentOverflow = documentElement.style.overflow,\n              isCreatedBody = false\n\n          if (!document.body) {\n            isCreatedBody = true\n            documentElement.style.overflow = 'hidden'\n            documentElement.appendChild(body)\n            body.style.overflow = 'hidden'\n            body.style.background = ''\n          }\n\n          body.appendChild(element)\n          element.style[jsProperty] = 'translate3d(1px,1px,1px)'\n          propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty)\n          featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none'\n          documentElement.style.overflow = documentOverflow\n          body.removeChild(element)\n\n          if ( isCreatedBody ) {\n            body.removeAttribute('style')\n            body.parentNode.removeChild(body)\n          }\n        }\n        break\n    }\n    return featureSupport\n  },\n\n  css(element, property, value) {\n    let jsProperty = helpers.propertyCache[property]\n    if (!jsProperty) {\n      for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n        if (helpers.vendors[i] !== null) {\n          jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property)\n        } else {\n          jsProperty = property\n        }\n        if (element.style[jsProperty] !== undefined) {\n          helpers.propertyCache[property] = jsProperty\n          break\n        }\n      }\n    }\n    element.style[jsProperty] = value\n  }\n\n}\n\nconst MAGIC_NUMBER = 30,\n      DEFAULTS = {\n        relativeInput: false,\n        clipRelativeInput: false,\n        inputElement: null,\n        hoverOnly: false,\n        calibrationThreshold: 100,\n        calibrationDelay: 500,\n        supportDelay: 500,\n        calibrateX: false,\n        calibrateY: true,\n        invertX: true,\n        invertY: true,\n        limitX: false,\n        limitY: false,\n        scalarX: 10.0,\n        scalarY: 10.0,\n        frictionX: 0.1,\n        frictionY: 0.1,\n        originX: 0.5,\n        originY: 0.5,\n        pointerEvents: false,\n        precision: 1,\n        onReady: null,\n        selector: null\n      }\n\nclass Parallax {\n  constructor(element, options) {\n\n    this.element = element\n\n    const data = {\n      calibrateX: helpers.data(this.element, 'calibrate-x'),\n      calibrateY: helpers.data(this.element, 'calibrate-y'),\n      invertX: helpers.data(this.element, 'invert-x'),\n      invertY: helpers.data(this.element, 'invert-y'),\n      limitX: helpers.data(this.element, 'limit-x'),\n      limitY: helpers.data(this.element, 'limit-y'),\n      scalarX: helpers.data(this.element, 'scalar-x'),\n      scalarY: helpers.data(this.element, 'scalar-y'),\n      frictionX: helpers.data(this.element, 'friction-x'),\n      frictionY: helpers.data(this.element, 'friction-y'),\n      originX: helpers.data(this.element, 'origin-x'),\n      originY: helpers.data(this.element, 'origin-y'),\n      pointerEvents: helpers.data(this.element, 'pointer-events'),\n      precision: helpers.data(this.element, 'precision'),\n      relativeInput: helpers.data(this.element, 'relative-input'),\n      clipRelativeInput: helpers.data(this.element, 'clip-relative-input'),\n      hoverOnly: helpers.data(this.element, 'hover-only'),\n      inputElement: document.querySelector(helpers.data(this.element, 'input-element')),\n      selector: helpers.data(this.element, 'selector')\n    }\n\n    for (let key in data) {\n      if (data[key] === null) {\n        delete data[key]\n      }\n    }\n\n    objectAssign(this, DEFAULTS, data, options)\n\n    if(!this.inputElement) {\n      this.inputElement = this.element\n    }\n\n    this.calibrationTimer = null\n    this.calibrationFlag = true\n    this.enabled = false\n    this.depthsX = []\n    this.depthsY = []\n    this.raf = null\n\n    this.bounds = null\n    this.elementPositionX = 0\n    this.elementPositionY = 0\n    this.elementWidth = 0\n    this.elementHeight = 0\n\n    this.elementCenterX = 0\n    this.elementCenterY = 0\n\n    this.elementRangeX = 0\n    this.elementRangeY = 0\n\n    this.calibrationX = 0\n    this.calibrationY = 0\n\n    this.inputX = 0\n    this.inputY = 0\n\n    this.motionX = 0\n    this.motionY = 0\n\n    this.velocityX = 0\n    this.velocityY = 0\n\n    this.onMouseMove = this.onMouseMove.bind(this)\n    this.onDeviceOrientation = this.onDeviceOrientation.bind(this)\n    this.onDeviceMotion = this.onDeviceMotion.bind(this)\n    this.onOrientationTimer = this.onOrientationTimer.bind(this)\n    this.onMotionTimer = this.onMotionTimer.bind(this)\n    this.onCalibrationTimer = this.onCalibrationTimer.bind(this)\n    this.onAnimationFrame = this.onAnimationFrame.bind(this)\n    this.onWindowResize = this.onWindowResize.bind(this)\n\n    this.windowWidth = null\n    this.windowHeight = null\n    this.windowCenterX = null\n    this.windowCenterY = null\n    this.windowRadiusX = null\n    this.windowRadiusY = null\n    this.portrait = false\n    this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i)\n    this.motionSupport = !!window.DeviceMotionEvent && !this.desktop\n    this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop\n    this.orientationStatus = 0\n    this.motionStatus = 0\n\n    this.initialise()\n  }\n\n  initialise() {\n    if (this.transform2DSupport === undefined) {\n      this.transform2DSupport = helpers.transformSupport('2D')\n      this.transform3DSupport = helpers.transformSupport('3D')\n    }\n\n    // Configure Context Styles\n    if (this.transform3DSupport) {\n      helpers.accelerate(this.element)\n    }\n\n    let style = window.getComputedStyle(this.element)\n    if (style.getPropertyValue('position') === 'static') {\n      this.element.style.position = 'relative'\n    }\n\n    // Pointer events\n    if(!this.pointerEvents) {\n      this.element.style.pointerEvents = 'none'\n    }\n\n    // Setup\n    this.updateLayers()\n    this.updateDimensions()\n    this.enable()\n    this.queueCalibration(this.calibrationDelay)\n  }\n\n  doReadyCallback() {\n    if(this.onReady) {\n      this.onReady()\n    }\n  }\n\n  updateLayers() {\n    if(this.selector) {\n      this.layers = this.element.querySelectorAll(this.selector)\n    } else {\n      this.layers = this.element.children\n    }\n\n    if(!this.layers.length) {\n      console.warn('ParallaxJS: Your scene does not have any layers.')\n    }\n\n    this.depthsX = []\n    this.depthsY = []\n\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index]\n\n      if (this.transform3DSupport) {\n        helpers.accelerate(layer)\n      }\n\n      layer.style.position = index ? 'absolute' : 'relative'\n      layer.style.display = 'block'\n      layer.style.left = 0\n      layer.style.top = 0\n\n      let depth = helpers.data(layer, 'depth') || 0\n      this.depthsX.push(helpers.data(layer, 'depth-x') || depth)\n      this.depthsY.push(helpers.data(layer, 'depth-y') || depth)\n    }\n  }\n\n  updateDimensions() {\n    this.windowWidth = window.innerWidth\n    this.windowHeight = window.innerHeight\n    this.windowCenterX = this.windowWidth * this.originX\n    this.windowCenterY = this.windowHeight * this.originY\n    this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX)\n    this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY)\n  }\n\n  updateBounds() {\n    this.bounds = this.inputElement.getBoundingClientRect()\n    this.elementPositionX = this.bounds.left\n    this.elementPositionY = this.bounds.top\n    this.elementWidth = this.bounds.width\n    this.elementHeight = this.bounds.height\n    this.elementCenterX = this.elementWidth * this.originX\n    this.elementCenterY = this.elementHeight * this.originY\n    this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX)\n    this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY)\n  }\n\n  queueCalibration(delay) {\n    clearTimeout(this.calibrationTimer)\n    this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay)\n  }\n\n  enable() {\n    if (this.enabled) {\n      return\n    }\n    this.enabled = true\n\n    if (this.orientationSupport) {\n      this.portrait = false\n      window.addEventListener('deviceorientation', this.onDeviceOrientation)\n      this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay)\n    } else if (this.motionSupport) {\n      this.portrait = false\n      window.addEventListener('devicemotion', this.onDeviceMotion)\n      this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay)\n    } else {\n      this.calibrationX = 0\n      this.calibrationY = 0\n      this.portrait = false\n      window.addEventListener('mousemove', this.onMouseMove)\n      this.doReadyCallback()\n    }\n\n    window.addEventListener('resize', this.onWindowResize)\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  disable() {\n    if (!this.enabled) {\n      return\n    }\n    this.enabled = false\n\n    if (this.orientationSupport) {\n      window.removeEventListener('deviceorientation', this.onDeviceOrientation)\n    } else if (this.motionSupport) {\n      window.removeEventListener('devicemotion', this.onDeviceMotion)\n    } else {\n      window.removeEventListener('mousemove', this.onMouseMove)\n    }\n\n    window.removeEventListener('resize', this.onWindowResize)\n    rqAnFr.cancel(this.raf)\n  }\n\n  calibrate(x, y) {\n    this.calibrateX = x === undefined ? this.calibrateX : x\n    this.calibrateY = y === undefined ? this.calibrateY : y\n  }\n\n  invert(x, y) {\n    this.invertX = x === undefined ? this.invertX : x\n    this.invertY = y === undefined ? this.invertY : y\n  }\n\n  friction(x, y) {\n    this.frictionX = x === undefined ? this.frictionX : x\n    this.frictionY = y === undefined ? this.frictionY : y\n  }\n\n  scalar(x, y) {\n    this.scalarX = x === undefined ? this.scalarX : x\n    this.scalarY = y === undefined ? this.scalarY : y\n  }\n\n  limit(x, y) {\n    this.limitX = x === undefined ? this.limitX : x\n    this.limitY = y === undefined ? this.limitY : y\n  }\n\n  origin(x, y) {\n    this.originX = x === undefined ? this.originX : x\n    this.originY = y === undefined ? this.originY : y\n  }\n\n  setInputElement(element) {\n    this.inputElement = element\n    this.updateDimensions()\n  }\n\n  setPosition(element, x, y) {\n    x = x.toFixed(this.precision) + 'px'\n    y = y.toFixed(this.precision) + 'px'\n    if (this.transform3DSupport) {\n      helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)')\n    } else if (this.transform2DSupport) {\n      helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')')\n    } else {\n      element.style.left = x\n      element.style.top = y\n    }\n  }\n\n  onOrientationTimer() {\n    if (this.orientationSupport && this.orientationStatus === 0) {\n      this.disable()\n      this.orientationSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onMotionTimer() {\n    if (this.motionSupport && this.motionStatus === 0) {\n      this.disable()\n      this.motionSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onCalibrationTimer() {\n    this.calibrationFlag = true\n  }\n\n  onWindowResize() {\n    this.updateDimensions()\n  }\n\n  onAnimationFrame() {\n    this.updateBounds()\n    let calibratedInputX = this.inputX - this.calibrationX,\n        calibratedInputY = this.inputY - this.calibrationY\n    if ((Math.abs(calibratedInputX) > this.calibrationThreshold) || (Math.abs(calibratedInputY) > this.calibrationThreshold)) {\n      this.queueCalibration(0)\n    }\n    if (this.portrait) {\n      this.motionX = this.calibrateX ? calibratedInputY : this.inputY\n      this.motionY = this.calibrateY ? calibratedInputX : this.inputX\n    } else {\n      this.motionX = this.calibrateX ? calibratedInputX : this.inputX\n      this.motionY = this.calibrateY ? calibratedInputY : this.inputY\n    }\n    this.motionX *= this.elementWidth * (this.scalarX / 100)\n    this.motionY *= this.elementHeight * (this.scalarY / 100)\n    if (!isNaN(parseFloat(this.limitX))) {\n      this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX)\n    }\n    if (!isNaN(parseFloat(this.limitY))) {\n      this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY)\n    }\n    this.velocityX += (this.motionX - this.velocityX) * this.frictionX\n    this.velocityY += (this.motionY - this.velocityY) * this.frictionY\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index],\n          depthX = this.depthsX[index],\n          depthY = this.depthsY[index],\n          xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)),\n          yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1))\n      this.setPosition(layer, xOffset, yOffset)\n    }\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  rotate(beta, gamma){\n    // Extract Rotation\n    let x = (beta || 0) / MAGIC_NUMBER, //  -90 :: 90\n        y = (gamma || 0) / MAGIC_NUMBER // -180 :: 180\n\n    // Detect Orientation Change\n    let portrait = this.windowHeight > this.windowWidth\n    if (this.portrait !== portrait) {\n      this.portrait = portrait\n      this.calibrationFlag = true\n    }\n\n    if (this.calibrationFlag) {\n      this.calibrationFlag = false\n      this.calibrationX = x\n      this.calibrationY = y\n    }\n\n    this.inputX = x\n    this.inputY = y\n  }\n\n  onDeviceOrientation(event) {\n    let beta = event.beta\n    let gamma = event.gamma\n    if (beta !== null && gamma !== null) {\n      this.orientationStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onDeviceMotion(event) {\n    let beta = event.rotationRate.beta\n    let gamma = event.rotationRate.gamma\n    if (beta !== null && gamma !== null) {\n      this.motionStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onMouseMove(event) {\n    let clientX = event.clientX,\n        clientY = event.clientY\n\n    // reset input to center if hoverOnly is set and we're not hovering the element\n    if(this.hoverOnly &&\n      ((clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth) ||\n      (clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight))) {\n        this.inputX = 0\n        this.inputY = 0\n        return\n      }\n\n    if (this.relativeInput) {\n      // Clip mouse coordinates inside element bounds.\n      if (this.clipRelativeInput) {\n        clientX = Math.max(clientX, this.elementPositionX)\n        clientX = Math.min(clientX, this.elementPositionX + this.elementWidth)\n        clientY = Math.max(clientY, this.elementPositionY)\n        clientY = Math.min(clientY, this.elementPositionY + this.elementHeight)\n      }\n      // Calculate input relative to the element.\n      if(this.elementRangeX && this.elementRangeY) {\n        this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX\n        this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY\n      }\n    } else {\n      // Calculate input relative to the window.\n      if(this.windowRadiusX && this.windowRadiusY) {\n        this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX\n        this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY\n      }\n    }\n  }\n\n  destroy() {\n    this.disable()\n\n    clearTimeout(this.calibrationTimer)\n    clearTimeout(this.detectionTimer)\n\n    this.element.removeAttribute('style')\n    for (let index = 0; index < this.layers.length; index++) {\n      this.layers[index].removeAttribute('style')\n    }\n\n    delete this.element\n    delete this.layers\n  }\n\n  version() {\n    return '3.1.0'\n  }\n\n}\n\nmodule.exports = Parallax\n"]}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\r\n    if (m) return m.call(o);\r\n    return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n};\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","module.exports = __webpack_public_path__ + \"bundle.css\";","/**\r\n * Copyright 2019 Mashiro\r\n * @description material-components initial configuration\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\n\r\nimport { MDCRipple } from '@material/ripple';\r\nimport { MDCTextField } from '@material/textfield';\r\nimport { MDCTopAppBar } from '@material/top-app-bar';\r\n\r\nconst Conf = [\r\n    ['.mdc-top-app-bar', MDCTopAppBar],\r\n    ['.mdc-text-field', MDCTextField],\r\n    [\r\n        [\r\n            '.mdc-button',\r\n            '.primary-action',\r\n        ],\r\n        MDCRipple\r\n    ],\r\n]\r\n\r\nexport default Conf","/**\r\n * Copyright 2019 Mashiro\r\n * @description material-components initial handler\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\nimport mdcConf from \"./mdcConf\"\r\n\r\nconst Conf = mdcConf\r\n\r\n/** \r\n * Initial [material-components-web](https://github.com/material-components/material-components-web/) \r\n * through configuration in `mdcConf.ts``.\r\n * See <https://git.io/JegHJ>\r\n */\r\nexport default function () {\r\n    let components = []\r\n    for (const i of Conf) {\r\n        if (typeof (i[0]) == 'string') {\r\n            const component = i[0]\r\n            const constructor = i[1]\r\n            components.map.call(document.querySelectorAll(component), function (e: any) {\r\n                return new constructor(e)\r\n            })\r\n        } else if (typeof (i[0]) == 'object') {\r\n            const component = i[0].join(',')\r\n            const constructor = i[1]\r\n            components.map.call(document.querySelectorAll(component), function (e: any) {\r\n                return new constructor(e)\r\n            })\r\n        }\r\n    }\r\n}","/**\r\n * Copyright 2019 Mashiro\r\n * @description Main\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\n\r\nimport coverImgIni from \"./modules/coverImgInit\"\r\nimport headerBarScrollHandler from \"./modules/headerBarScrollHandler\"\r\nimport mdcInit from \"./components/mdcInit\"\r\n\r\n\r\nwindow.onscroll = function () {\r\n  headerBarScrollHandler()\r\n}\r\n\r\nwindow.onload = function () {\r\n  coverImgIni()\r\n  mdcInit()\r\n\r\n}","/**\r\n * Copyright 2019 Mashiro\r\n * @description Sakura theme module\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\n\r\nimport Parallax from 'parallax-js'\r\n\r\n/**\r\n * Initial index cover image and image box.\r\n * Include Parallax box initial and `#cover-img-container` size initial.\r\n */\r\nexport default function () {\r\n    let coverImgContainer = <HTMLElement>document.querySelector(\"#cover-img-container\")\r\n    coverImgContainer.style.height = `${window.innerHeight}px`\r\n    let headerTopAfter = <HTMLElement>document.querySelector(\"#header-top-after\")\r\n    headerTopAfter.style.height = `${window.innerHeight}px`\r\n\r\n    interface LooseObject {\r\n        [key: string]: any\r\n    }\r\n\r\n    /**\r\n     * cover: `img#cover-img`\r\n     */\r\n    let coverImg: LooseObject = {}\r\n    /**\r\n     * mark: `figure#cover-img-container`\r\n     */\r\n    let coverBox: LooseObject = {}\r\n    /**\r\n     * layer: `div#img-view`\r\n     */\r\n    let coverView: LooseObject = {}\r\n\r\n    coverImg.e = <HTMLImageElement>document.querySelector(\"#cover-img\")\r\n    coverImg.w = <number>coverImg.e.naturalWidth\r\n    coverImg.h = <number>coverImg.e.naturalHeight\r\n\r\n    coverBox.e = <HTMLImageElement>document.querySelector(\"#cover-img-container\")\r\n    coverBox.w = <number>coverBox.e.offsetWidth\r\n    coverBox.h = <number>coverBox.e.offsetHeight\r\n\r\n    coverView.e = <HTMLImageElement>document.querySelector(\"#img-view\")\r\n\r\n    coverBox.e.style.height = `${window.innerHeight}px`\r\n\r\n    coverBox.f = (coverBox.w >= 1000 || coverBox.h >= 1000) ? 1000 : 500\r\n    if (coverBox.w >= coverBox.h) {\r\n        coverBox.i = coverBox.w / coverBox.f * 50;\r\n        coverBox.y = coverBox.i;\r\n        coverBox.x = coverBox.i * coverBox.w / coverBox.h;\r\n    } else {\r\n        coverBox.i = coverBox.h / coverBox.f * 50;\r\n        coverBox.x = coverBox.i;\r\n        coverBox.y = coverBox.i * coverBox.h / coverBox.w;\r\n    }\r\n\r\n    coverView.e.style.cssText = `\r\n        width: ${coverBox.w + coverBox.x}px; \r\n        height: ${coverBox.h + coverBox.y}px; \r\n        margin-left: ${-0.5 * coverBox.x}px; \r\n        margin-top: ${-0.5 * coverBox.y}px`\r\n\r\n    coverImg.e.style.cssText = `\r\n        width: ${coverView.w + coverView.x}px;\r\n        height: ${coverView.h + coverView.y}px`\r\n\r\n    if (!coverImg.w) {\r\n        coverImg.w = coverImg.e.offsetWidth\r\n        coverImg.h = coverImg.e.offsetHeight;\r\n    }\r\n\r\n    coverImg._w = coverImg.e.parentElement.offsetWidth\r\n    coverImg._h = coverImg.e.parentElement.offsetHeight\r\n    coverImg.ratio = coverImg.h / coverImg.w\r\n\r\n    if (coverImg._h / coverImg._w > coverImg.ratio) {\r\n        coverImg.e.style.height = coverImg._h + 'px';\r\n        coverImg.e.style.width = coverImg._h / coverImg.ratio + 'px';\r\n    } else {\r\n        coverImg.e.style.width = coverImg._w + 'px';\r\n        coverImg.e.style.height = coverImg._w * coverImg.ratio + 'px';\r\n    }\r\n\r\n    coverImg.e.style.left = (coverImg._w - parseInt(coverImg.e.style.width)) / 2 + 'px';\r\n    coverImg.e.style.top = (coverImg._h - parseInt(coverImg.e.style.height)) / 2 + 'px';\r\n\r\n    let scene = document.querySelector('#cover-img-container')\r\n    let parallaxInstance = new Parallax(scene);\r\n}","/**\r\n * @description Sakura theme module\r\n * @author Mashiro\r\n * @since 19/10/31\r\n * @license MIT\r\n */\r\n\r\nimport scrollDirection from \"./scrollDirection\"\r\n\r\n/**\r\n * Site top bar handler when page scroll\r\n */\r\nexport default function () {\r\n    let ele: HTMLElement = document.querySelector(\"#nav-header\")\r\n    if (scrollDirection('y') == 'down') {\r\n        ele.style.top = `-120px`\r\n    }\r\n    else if (scrollDirection('y') == 'up') {\r\n        ele.style.top = `0px`\r\n    }\r\n}","/**\r\n * @description Sakura theme module\r\n * @author Mashiro\r\n * @since 19/10/31\r\n * @license MIT\r\n */\r\n\r\nlet scrollAction: {\r\n    x: number,\r\n    y: number,\r\n    d: string\r\n} = {\r\n    x: undefined,\r\n    y: undefined,\r\n    d: undefined\r\n}\r\n\r\n/**\r\n * Detect window scroll direction\r\n * @param  {string}  direction  option: `Y`/`y` - horizontal; `X`/`x` - vertical\r\n * @return {string}             return window scroll direction\r\n */\r\nexport default function (direction: string) {\r\n    if (scrollAction.x == undefined) {\r\n        scrollAction.x = window.pageXOffset\r\n        scrollAction.y = window.pageYOffset\r\n    }\r\n    let diffX = scrollAction.x - window.pageXOffset\r\n    let diffY = scrollAction.y - window.pageYOffset\r\n    if (direction == 'x' || direction == 'X' ) {\r\n        if (diffX < 0) {\r\n            scrollAction.d = 'right'\r\n        } else if (diffX > 0) {\r\n            scrollAction.d = 'left'\r\n        }\r\n    } else {\r\n        if (diffY < 0) {\r\n            scrollAction.d = 'down'\r\n        } else if (diffY > 0) {\r\n            scrollAction.d = 'up'\r\n        }\r\n    }\r\n    scrollAction.x = window.pageXOffset\r\n    scrollAction.y = window.pageYOffset\r\n    return scrollAction.d\r\n}"],"sourceRoot":""} \ No newline at end of file diff --git a/docs/dist/bundle.css b/docs/dist/bundle.css new file mode 100644 index 0000000..caf5bd0 --- /dev/null +++ b/docs/dist/bundle.css @@ -0,0 +1,3009 @@ +/* + * MDC varibles + * must before import + */ +/* font color */ +/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */ +/* Document + ========================================================================== */ +/** + * 1. Correct the line height in all browsers. + * 2. Prevent adjustments of font size after orientation changes in iOS. + */ +html { + line-height: 1.15; + /* 1 */ + -webkit-text-size-adjust: 100%; + /* 2 */ } + +/* Sections + ========================================================================== */ +/** + * Remove the margin in all browsers. + */ +body { + margin: 0; } + +/** + * Render the `main` element consistently in IE. + */ +main { + display: block; } + +/** + * Correct the font size and margin on `h1` elements within `section` and + * `article` contexts in Chrome, Firefox, and Safari. + */ +h1 { + font-size: 2em; + margin: 0.67em 0; } + +/* Grouping content + ========================================================================== */ +/** + * 1. Add the correct box sizing in Firefox. + * 2. Show the overflow in Edge and IE. + */ +hr { + box-sizing: content-box; + /* 1 */ + height: 0; + /* 1 */ + overflow: visible; + /* 2 */ } + +/** + * 1. Correct the inheritance and scaling of font size in all browsers. + * 2. Correct the odd `em` font sizing in all browsers. + */ +pre { + font-family: monospace, monospace; + /* 1 */ + font-size: 1em; + /* 2 */ } + +/* Text-level semantics + ========================================================================== */ +/** + * Remove the gray background on active links in IE 10. + */ +a { + background-color: transparent; } + +/** + * 1. Remove the bottom border in Chrome 57- + * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari. + */ +abbr[title] { + border-bottom: none; + /* 1 */ + text-decoration: underline; + /* 2 */ + -webkit-text-decoration: underline dotted; + text-decoration: underline dotted; + /* 2 */ } + +/** + * Add the correct font weight in Chrome, Edge, and Safari. + */ +b, +strong { + font-weight: bolder; } + +/** + * 1. Correct the inheritance and scaling of font size in all browsers. + * 2. Correct the odd `em` font sizing in all browsers. + */ +code, +kbd, +samp { + font-family: monospace, monospace; + /* 1 */ + font-size: 1em; + /* 2 */ } + +/** + * Add the correct font size in all browsers. + */ +small { + font-size: 80%; } + +/** + * Prevent `sub` and `sup` elements from affecting the line height in + * all browsers. + */ +sub, +sup { + font-size: 75%; + line-height: 0; + position: relative; + vertical-align: baseline; } + +sub { + bottom: -0.25em; } + +sup { + top: -0.5em; } + +/* Embedded content + ========================================================================== */ +/** + * Remove the border on images inside links in IE 10. + */ +img { + border-style: none; } + +/* Forms + ========================================================================== */ +/** + * 1. Change the font styles in all browsers. + * 2. Remove the margin in Firefox and Safari. + */ +button, +input, +optgroup, +select, +textarea { + font-family: inherit; + /* 1 */ + font-size: 100%; + /* 1 */ + line-height: 1.15; + /* 1 */ + margin: 0; + /* 2 */ } + +/** + * Show the overflow in IE. + * 1. Show the overflow in Edge. + */ +button, +input { + /* 1 */ + overflow: visible; } + +/** + * Remove the inheritance of text transform in Edge, Firefox, and IE. + * 1. Remove the inheritance of text transform in Firefox. + */ +button, +select { + /* 1 */ + text-transform: none; } + +/** + * Correct the inability to style clickable types in iOS and Safari. + */ +button, +[type="button"], +[type="reset"], +[type="submit"] { + -webkit-appearance: button; } + +/** + * Remove the inner border and padding in Firefox. + */ +button::-moz-focus-inner, +[type="button"]::-moz-focus-inner, +[type="reset"]::-moz-focus-inner, +[type="submit"]::-moz-focus-inner { + border-style: none; + padding: 0; } + +/** + * Restore the focus styles unset by the previous rule. + */ +button:-moz-focusring, +[type="button"]:-moz-focusring, +[type="reset"]:-moz-focusring, +[type="submit"]:-moz-focusring { + outline: 1px dotted ButtonText; } + +/** + * Correct the padding in Firefox. + */ +fieldset { + padding: 0.35em 0.75em 0.625em; } + +/** + * 1. Correct the text wrapping in Edge and IE. + * 2. Correct the color inheritance from `fieldset` elements in IE. + * 3. Remove the padding so developers are not caught out when they zero out + * `fieldset` elements in all browsers. + */ +legend { + box-sizing: border-box; + /* 1 */ + color: inherit; + /* 2 */ + display: table; + /* 1 */ + max-width: 100%; + /* 1 */ + padding: 0; + /* 3 */ + white-space: normal; + /* 1 */ } + +/** + * Add the correct vertical alignment in Chrome, Firefox, and Opera. + */ +progress { + vertical-align: baseline; } + +/** + * Remove the default vertical scrollbar in IE 10+. + */ +textarea { + overflow: auto; } + +/** + * 1. Add the correct box sizing in IE 10. + * 2. Remove the padding in IE 10. + */ +[type="checkbox"], +[type="radio"] { + box-sizing: border-box; + /* 1 */ + padding: 0; + /* 2 */ } + +/** + * Correct the cursor style of increment and decrement buttons in Chrome. + */ +[type="number"]::-webkit-inner-spin-button, +[type="number"]::-webkit-outer-spin-button { + height: auto; } + +/** + * 1. Correct the odd appearance in Chrome and Safari. + * 2. Correct the outline style in Safari. + */ +[type="search"] { + -webkit-appearance: textfield; + /* 1 */ + outline-offset: -2px; + /* 2 */ } + +/** + * Remove the inner padding in Chrome and Safari on macOS. + */ +[type="search"]::-webkit-search-decoration { + -webkit-appearance: none; } + +/** + * 1. Correct the inability to style clickable types in iOS and Safari. + * 2. Change font properties to `inherit` in Safari. + */ +::-webkit-file-upload-button { + -webkit-appearance: button; + /* 1 */ + font: inherit; + /* 2 */ } + +/* Interactive + ========================================================================== */ +/* + * Add the correct display in Edge, IE 10+, and Firefox. + */ +details { + display: block; } + +/* + * Add the correct display in all browsers. + */ +summary { + display: list-item; } + +/* Misc + ========================================================================== */ +/** + * Add the correct display in IE 10+. + */ +template { + display: none; } + +/** + * Add the correct display in IE 10. + */ +[hidden] { + display: none; } + +.mdc-floating-label { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.75rem; + font-weight: 400; + letter-spacing: 0.00937em; + text-decoration: inherit; + text-transform: inherit; + position: absolute; + /* @noflip */ + left: 0; + /* @noflip */ + -webkit-transform-origin: left top; + transform-origin: left top; + -webkit-transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: color 150ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 150ms cubic-bezier(0.4, 0, 0.2, 1), color 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 150ms cubic-bezier(0.4, 0, 0.2, 1), color 150ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 150ms cubic-bezier(0.4, 0, 0.2, 1); + /* @alternate */ + line-height: 1.15rem; + text-align: left; + text-overflow: ellipsis; + white-space: nowrap; + cursor: text; + overflow: hidden; + will-change: transform; } + [dir="rtl"] .mdc-floating-label, .mdc-floating-label[dir="rtl"] { + /* @noflip */ + right: 0; + /* @noflip */ + left: auto; + /* @noflip */ + -webkit-transform-origin: right top; + transform-origin: right top; + /* @noflip */ + text-align: right; } + +.mdc-floating-label--float-above { + cursor: auto; } + +.mdc-floating-label--float-above { + -webkit-transform: translateY(-50%) scale(0.75); + transform: translateY(-50%) scale(0.75); } + +.mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-standard 250ms 1; + animation: mdc-floating-label-shake-float-above-standard 250ms 1; } + +@-webkit-keyframes mdc-floating-label-shake-float-above-standard { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-standard { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-50%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-50%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-50%) scale(0.75); } } + +.mdc-line-ripple { + position: absolute; + bottom: 0; + left: 0; + width: 100%; + height: 2px; + -webkit-transform: scaleX(0); + transform: scaleX(0); + -webkit-transition: opacity 180ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 180ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 180ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 180ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 180ms cubic-bezier(0.4, 0, 0.2, 1), opacity 180ms cubic-bezier(0.4, 0, 0.2, 1); + transition: transform 180ms cubic-bezier(0.4, 0, 0.2, 1), opacity 180ms cubic-bezier(0.4, 0, 0.2, 1), -webkit-transform 180ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + z-index: 2; } + +.mdc-line-ripple--active { + -webkit-transform: scaleX(1); + transform: scaleX(1); + opacity: 1; } + +.mdc-line-ripple--deactivating { + opacity: 0; } + +.mdc-notched-outline { + display: -webkit-box; + display: flex; + position: absolute; + right: 0; + left: 0; + box-sizing: border-box; + width: 100%; + max-width: 100%; + height: 100%; + /* @noflip */ + text-align: left; + pointer-events: none; } + [dir="rtl"] .mdc-notched-outline, .mdc-notched-outline[dir="rtl"] { + /* @noflip */ + text-align: right; } + .mdc-notched-outline__leading, .mdc-notched-outline__notch, .mdc-notched-outline__trailing { + box-sizing: border-box; + height: 100%; + -webkit-transition: border 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: border 150ms cubic-bezier(0.4, 0, 0.2, 1); + border-top: 1px solid; + border-bottom: 1px solid; + pointer-events: none; } + .mdc-notched-outline__leading { + /* @noflip */ + border-left: 1px solid; + /* @noflip */ + border-right: none; + width: 12px; } + [dir="rtl"] .mdc-notched-outline__leading, .mdc-notched-outline__leading[dir="rtl"] { + /* @noflip */ + border-left: none; + /* @noflip */ + border-right: 1px solid; } + .mdc-notched-outline__trailing { + /* @noflip */ + border-left: none; + /* @noflip */ + border-right: 1px solid; + -webkit-box-flex: 1; + flex-grow: 1; } + [dir="rtl"] .mdc-notched-outline__trailing, .mdc-notched-outline__trailing[dir="rtl"] { + /* @noflip */ + border-left: 1px solid; + /* @noflip */ + border-right: none; } + .mdc-notched-outline__notch { + -webkit-box-flex: 0; + flex: 0 0 auto; + width: auto; + max-width: calc(100% - 12px * 2); } + .mdc-notched-outline .mdc-floating-label { + display: inline-block; + position: relative; + top: 17px; + bottom: auto; + max-width: 100%; } + .mdc-notched-outline .mdc-floating-label--float-above { + text-overflow: clip; } + .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + max-width: calc(100% / .75); } + +.mdc-notched-outline--notched .mdc-notched-outline__notch { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 8px; + border-top: none; } + [dir="rtl"] .mdc-notched-outline--notched .mdc-notched-outline__notch, .mdc-notched-outline--notched .mdc-notched-outline__notch[dir="rtl"] { + /* @noflip */ + padding-left: 8px; + /* @noflip */ + padding-right: 0; } + +.mdc-notched-outline--no-label .mdc-notched-outline__notch { + padding: 0; } + +@-webkit-keyframes mdc-ripple-fg-radius-in { + from { + -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + -webkit-transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); + transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); } + to { + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } } + +@keyframes mdc-ripple-fg-radius-in { + from { + -webkit-animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + animation-timing-function: cubic-bezier(0.4, 0, 0.2, 1); + -webkit-transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); + transform: translate(var(--mdc-ripple-fg-translate-start, 0)) scale(1); } + to { + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } } + +@-webkit-keyframes mdc-ripple-fg-opacity-in { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: 0; } + to { + opacity: var(--mdc-ripple-fg-opacity, 0); } } + +@keyframes mdc-ripple-fg-opacity-in { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: 0; } + to { + opacity: var(--mdc-ripple-fg-opacity, 0); } } + +@-webkit-keyframes mdc-ripple-fg-opacity-out { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: var(--mdc-ripple-fg-opacity, 0); } + to { + opacity: 0; } } + +@keyframes mdc-ripple-fg-opacity-out { + from { + -webkit-animation-timing-function: linear; + animation-timing-function: linear; + opacity: var(--mdc-ripple-fg-opacity, 0); } + to { + opacity: 0; } } + +.mdc-ripple-surface--test-edge-var-bug { + --mdc-ripple-surface-test-edge-var: 1px solid #000; + visibility: hidden; } + .mdc-ripple-surface--test-edge-var-bug::before { + border: var(--mdc-ripple-surface-test-edge-var); } + +.mdc-text-field-helper-text { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.03333em; + text-decoration: inherit; + text-transform: inherit; + display: block; + margin-top: 0; + /* @alternate */ + line-height: normal; + margin: 0; + -webkit-transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + will-change: opacity; } + .mdc-text-field-helper-text::before { + display: inline-block; + width: 0; + height: 16px; + content: ""; + vertical-align: 0; } + +.mdc-text-field-helper-text--persistent { + -webkit-transition: none; + transition: none; + opacity: 1; + will-change: initial; } + +.mdc-text-field-character-counter { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.03333em; + text-decoration: inherit; + text-transform: inherit; + display: block; + margin-top: 0; + /* @alternate */ + line-height: normal; + /* @noflip */ + margin-left: auto; + /* @noflip */ + margin-right: 0; + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 0; + white-space: nowrap; } + .mdc-text-field-character-counter::before { + display: inline-block; + width: 0; + height: 16px; + content: ""; + vertical-align: 0; } + [dir="rtl"] .mdc-text-field-character-counter, .mdc-text-field-character-counter[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: auto; } + [dir="rtl"] .mdc-text-field-character-counter, .mdc-text-field-character-counter[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-leading-icon .mdc-text-field__icon, +.mdc-text-field--with-trailing-icon .mdc-text-field__icon { + position: absolute; + bottom: 16px; + cursor: pointer; } + +.mdc-text-field__icon:not([tabindex]), +.mdc-text-field__icon[tabindex="-1"] { + cursor: default; + pointer-events: none; } + +.mdc-text-field { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); + border-radius: 4px 4px 0 0; + display: -webkit-inline-box; + display: inline-flex; + position: relative; + box-sizing: border-box; + height: 56px; + overflow: hidden; + /* @alternate */ + will-change: opacity, transform, color; } + .mdc-text-field::before, .mdc-text-field::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-text-field::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-text-field.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-text-field.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-text-field.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-text-field.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-text-field.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-text-field::before, .mdc-text-field::after { + background-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field:hover::before { + opacity: 0.04; } + .mdc-text-field:not(.mdc-ripple-upgraded):focus::before, .mdc-text-field.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-text-field::before, .mdc-text-field::after { + top: calc(50% - 100%); + /* @noflip */ + left: calc(50% - 100%); + width: 200%; + height: 200%; } + .mdc-text-field.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-floating-label { + color: rgba(0, 0, 0, 0.6); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-text-field__input { + color: rgba(0, 0, 0, 0.87); } + .mdc-text-field .mdc-text-field__input { + caret-color: #fcb8ab; + /* @alternate */ + caret-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input { + border-bottom-color: rgba(0, 0, 0, 0.42); } + .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input:hover { + border-bottom-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field .mdc-line-ripple { + background-color: #fcb8ab; + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field:not(.mdc-text-field--disabled):not(.mdc-text-field--textarea) { + border-bottom-color: rgba(0, 0, 0, 0.12); } + .mdc-text-field:not(.mdc-text-field--disabled) + .mdc-text-field-helper-line .mdc-text-field-helper-text { + color: rgba(0, 0, 0, 0.6); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-text-field-character-counter, + .mdc-text-field:not(.mdc-text-field--disabled) + .mdc-text-field-helper-line .mdc-text-field-character-counter { + color: rgba(0, 0, 0, 0.6); } + .mdc-text-field:not(.mdc-text-field--disabled) .mdc-text-field__icon { + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field:not(.mdc-text-field--disabled) { + background-color: whitesmoke; } + .mdc-text-field .mdc-floating-label { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; + top: 18px; + pointer-events: none; } + [dir="rtl"] .mdc-text-field .mdc-floating-label, .mdc-text-field .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + .mdc-text-field--textarea .mdc-floating-label { + /* @noflip */ + left: 4px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--textarea .mdc-floating-label, .mdc-text-field--textarea .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 4px; } + .mdc-text-field--outlined .mdc-floating-label { + /* @noflip */ + left: 4px; + /* @noflip */ + right: initial; + top: 17px; } + [dir="rtl"] .mdc-text-field--outlined .mdc-floating-label, .mdc-text-field--outlined .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 4px; } + .mdc-text-field--outlined--with-leading-icon .mdc-floating-label { + /* @noflip */ + left: 36px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--outlined--with-leading-icon .mdc-floating-label, .mdc-text-field--outlined--with-leading-icon .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 36px; } + .mdc-text-field--outlined--with-leading-icon .mdc-floating-label--float-above { + /* @noflip */ + left: 40px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--outlined--with-leading-icon .mdc-floating-label--float-above, .mdc-text-field--outlined--with-leading-icon .mdc-floating-label--float-above[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 40px; } + +.mdc-text-field__input { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.75rem; + font-weight: 400; + letter-spacing: 0.00937em; + text-decoration: inherit; + text-transform: inherit; + align-self: flex-end; + box-sizing: border-box; + width: 100%; + height: 100%; + padding: 20px 16px 6px; + -webkit-transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 150ms cubic-bezier(0.4, 0, 0.2, 1); + border: none; + border-bottom: 1px solid; + border-radius: 0; + background: none; + -webkit-appearance: none; + -moz-appearance: none; + appearance: none; } + .mdc-text-field__input::-webkit-input-placeholder { + -webkit-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input::-moz-placeholder { + -moz-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input:-ms-input-placeholder { + -ms-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input::-ms-input-placeholder { + -ms-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input::placeholder { + -webkit-transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 67ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 0; + color: rgba(0, 0, 0, 0.54); } + .mdc-text-field__input:-ms-input-placeholder { + color: rgba(0, 0, 0, 0.54) !important; } + .mdc-text-field--fullwidth .mdc-text-field__input::-webkit-input-placeholder, .mdc-text-field--no-label .mdc-text-field__input::-webkit-input-placeholder, .mdc-text-field--focused .mdc-text-field__input::-webkit-input-placeholder { + -webkit-transition-delay: 40ms; + transition-delay: 40ms; + -webkit-transition-duration: 110ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input::-moz-placeholder, .mdc-text-field--no-label .mdc-text-field__input::-moz-placeholder, .mdc-text-field--focused .mdc-text-field__input::-moz-placeholder { + transition-delay: 40ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input:-ms-input-placeholder, .mdc-text-field--no-label .mdc-text-field__input:-ms-input-placeholder, .mdc-text-field--focused .mdc-text-field__input:-ms-input-placeholder { + transition-delay: 40ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input::-ms-input-placeholder, .mdc-text-field--no-label .mdc-text-field__input::-ms-input-placeholder, .mdc-text-field--focused .mdc-text-field__input::-ms-input-placeholder { + transition-delay: 40ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field--fullwidth .mdc-text-field__input::placeholder, + .mdc-text-field--no-label .mdc-text-field__input::placeholder, + .mdc-text-field--focused .mdc-text-field__input::placeholder { + -webkit-transition-delay: 40ms; + transition-delay: 40ms; + -webkit-transition-duration: 110ms; + transition-duration: 110ms; + opacity: 1; } + .mdc-text-field__input:focus { + outline: none; } + .mdc-text-field__input:invalid { + box-shadow: none; } + .mdc-text-field__input:-webkit-autofill { + z-index: auto !important; } + .mdc-text-field--no-label:not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input { + padding-top: 16px; + padding-bottom: 16px; } + +.mdc-text-field__input:-webkit-autofill + .mdc-floating-label { + -webkit-transform: translateY(-50%) scale(0.75); + transform: translateY(-50%) scale(0.75); + cursor: auto; } + +.mdc-text-field--outlined { + border: none; + overflow: visible; } + .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.38); } + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, + .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, + .mdc-text-field--outlined:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field--outlined .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; } + .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading { + /* @noflip */ + border-radius: 4px 0 0 4px; } + [dir="rtl"] .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading, .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__leading[dir="rtl"] { + /* @noflip */ + border-radius: 0 4px 4px 0; } + .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing { + /* @noflip */ + border-radius: 0 4px 4px 0; } + [dir="rtl"] .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing, .mdc-text-field--outlined .mdc-notched-outline .mdc-notched-outline__trailing[dir="rtl"] { + /* @noflip */ + border-radius: 4px 0 0 4px; } + .mdc-text-field--outlined .mdc-floating-label--float-above { + -webkit-transform: translateY(-144%) scale(1); + transform: translateY(-144%) scale(1); } + .mdc-text-field--outlined .mdc-floating-label--float-above { + font-size: 0.75rem; } + .mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-130%) scale(0.75); + transform: translateY(-130%) scale(0.75); } + .mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + .mdc-text-field--outlined::before, .mdc-text-field--outlined::after { + content: none; } + .mdc-text-field--outlined:not(.mdc-text-field--disabled) { + background-color: transparent; } + .mdc-text-field--outlined .mdc-text-field__input { + display: -webkit-box; + display: flex; + padding: 12px 16px 14px; + border: none !important; + background-color: transparent; + z-index: 1; } + .mdc-text-field--outlined .mdc-text-field__icon { + z-index: 2; } + +.mdc-text-field--outlined.mdc-text-field--focused .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--focused .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--focused .mdc-notched-outline__trailing { + border-width: 2px; } + +.mdc-text-field--outlined.mdc-text-field--disabled { + background-color: transparent; } + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-notched-outline__leading, + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-notched-outline__notch, + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.06); } + .mdc-text-field--outlined.mdc-text-field--disabled .mdc-text-field__input { + border-bottom: none; } + +.mdc-text-field--outlined.mdc-text-field--dense { + height: 48px; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + -webkit-transform: translateY(-134%) scale(1); + transform: translateY(-134%) scale(1); } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + font-size: 0.8rem; } + .mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-120%) scale(0.8); + transform: translateY(-120%) scale(0.8); } + .mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-dense 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-dense 250ms 1; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-text-field__input { + padding: 12px 12px 7px; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label { + top: 14px; } + .mdc-text-field--outlined.mdc-text-field--dense .mdc-text-field__icon { + top: 12px; } + +.mdc-text-field--with-leading-icon .mdc-text-field__icon { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon .mdc-text-field__icon, .mdc-text-field--with-leading-icon .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + +.mdc-text-field--with-leading-icon .mdc-text-field__input { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + [dir="rtl"] .mdc-text-field--with-leading-icon .mdc-text-field__input, .mdc-text-field--with-leading-icon .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + +.mdc-text-field--with-leading-icon .mdc-floating-label { + /* @noflip */ + left: 48px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon .mdc-floating-label, .mdc-text-field--with-leading-icon .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 48px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__icon { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__input { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above { + -webkit-transform: translateY(-144%) translateX(-32px) scale(1); + transform: translateY(-144%) translateX(-32px) scale(1); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-144%) translateX(32px) scale(1); + transform: translateY(-144%) translateX(32px) scale(1); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--float-above { + font-size: 0.75rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-130%) translateX(-32px) scale(0.75); + transform: translateY(-130%) translateX(-32px) scale(0.75); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"], [dir="rtl"] + .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-130%) translateX(32px) scale(0.75); + transform: translateY(-130%) translateX(32px) scale(0.75); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon 250ms 1; } + +[dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label--shake, .mdc-text-field--with-leading-icon.mdc-text-field--outlined[dir="rtl"] .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl 250ms 1; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label { + /* @noflip */ + left: 36px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label, .mdc-text-field--with-leading-icon.mdc-text-field--outlined .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 36px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + -webkit-transform: translateY(-134%) translateX(-21px) scale(1); + transform: translateY(-134%) translateX(-21px) scale(1); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-134%) translateX(21px) scale(1); + transform: translateY(-134%) translateX(21px) scale(1); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--float-above { + font-size: 0.8rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-120%) translateX(-21px) scale(0.8); + transform: translateY(-120%) translateX(-21px) scale(0.8); } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"], [dir="rtl"] + .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above[dir="rtl"] { + -webkit-transform: translateY(-120%) translateX(21px) scale(0.8); + transform: translateY(-120%) translateX(21px) scale(0.8); } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense.mdc-notched-outline--upgraded .mdc-floating-label--float-above, +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense 250ms 1; } + +[dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label--shake, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense[dir="rtl"] .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl 250ms 1; } + +.mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label { + /* @noflip */ + left: 32px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label, .mdc-text-field--with-leading-icon.mdc-text-field--outlined.mdc-text-field--dense .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 32px; } + +.mdc-text-field--with-trailing-icon .mdc-text-field__icon { + /* @noflip */ + left: initial; + /* @noflip */ + right: 12px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon .mdc-text-field__icon, .mdc-text-field--with-trailing-icon .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: 12px; + /* @noflip */ + right: initial; } + +.mdc-text-field--with-trailing-icon .mdc-text-field__input { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon .mdc-text-field__input, .mdc-text-field--with-trailing-icon .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__icon { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__icon, .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__input { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 48px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__input, .mdc-text-field--with-trailing-icon.mdc-text-field--outlined .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon { + /* @noflip */ + left: 16px; + /* @noflip */ + right: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: auto; + /* @noflip */ + right: 16px; } + .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon ~ .mdc-text-field__icon { + /* @noflip */ + right: 12px; + /* @noflip */ + left: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon ~ .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__icon ~ .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + right: auto; + /* @noflip */ + left: 12px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__input { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 48px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 48px; + /* @noflip */ + padding-right: 48px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon, +.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon { + bottom: 16px; + -webkit-transform: scale(0.8); + transform: scale(0.8); } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon { + /* @noflip */ + left: 12px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 12px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__input { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 16px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 44px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-floating-label { + /* @noflip */ + left: 44px; + /* @noflip */ + right: initial; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-floating-label, .mdc-text-field--with-leading-icon.mdc-text-field--dense .mdc-floating-label[dir="rtl"] { + /* @noflip */ + left: initial; + /* @noflip */ + right: 44px; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon { + /* @noflip */ + left: initial; + /* @noflip */ + right: 12px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon, .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: 12px; + /* @noflip */ + right: initial; } + +.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input { + /* @noflip */ + padding-left: 16px; + /* @noflip */ + padding-right: 44px; } + [dir="rtl"] .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input, .mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 16px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon { + /* @noflip */ + left: 12px; + /* @noflip */ + right: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + left: auto; + /* @noflip */ + right: 12px; } + .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon ~ .mdc-text-field__icon { + /* @noflip */ + right: 12px; + /* @noflip */ + left: auto; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon ~ .mdc-text-field__icon, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__icon ~ .mdc-text-field__icon[dir="rtl"] { + /* @noflip */ + right: auto; + /* @noflip */ + left: 12px; } + +.mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 44px; } + [dir="rtl"] .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input, .mdc-text-field--with-leading-icon.mdc-text-field--with-trailing-icon.mdc-text-field--dense .mdc-text-field__input[dir="rtl"] { + /* @noflip */ + padding-left: 44px; + /* @noflip */ + padding-right: 44px; } + +.mdc-text-field--dense .mdc-floating-label--float-above { + -webkit-transform: translateY(-70%) scale(0.8); + transform: translateY(-70%) scale(0.8); } + +.mdc-text-field--dense .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-dense 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-dense 250ms 1; } + +.mdc-text-field--dense .mdc-text-field__input { + padding: 12px 12px 0; } + +.mdc-text-field--dense .mdc-floating-label { + font-size: .813rem; } + .mdc-text-field--dense .mdc-floating-label--float-above { + font-size: .813rem; } + +.mdc-text-field__input:required ~ .mdc-floating-label::after, +.mdc-text-field__input:required ~ .mdc-notched-outline .mdc-floating-label::after { + margin-left: 1px; + content: "*"; } + +.mdc-text-field--textarea { + display: -webkit-inline-box; + display: inline-flex; + width: auto; + height: auto; + -webkit-transition: none; + transition: none; + overflow: visible; } + .mdc-text-field--textarea:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.38); } + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.87); } + .mdc-text-field--textarea:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, + .mdc-text-field--textarea:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, + .mdc-text-field--textarea:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + .mdc-text-field--textarea .mdc-floating-label--shake { + -webkit-animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; + animation: mdc-floating-label-shake-float-above-text-field-outlined 250ms 1; } + .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__leading { + /* @noflip */ + border-radius: 4px 0 0 4px; } + [dir="rtl"] .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__leading, .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__leading[dir="rtl"] { + /* @noflip */ + border-radius: 0 4px 4px 0; } + .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__trailing { + /* @noflip */ + border-radius: 0 4px 4px 0; } + [dir="rtl"] .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__trailing, .mdc-text-field--textarea .mdc-notched-outline .mdc-notched-outline__trailing[dir="rtl"] { + /* @noflip */ + border-radius: 4px 0 0 4px; } + .mdc-text-field--textarea::before, .mdc-text-field--textarea::after { + content: none; } + .mdc-text-field--textarea:not(.mdc-text-field--disabled) { + background-color: transparent; } + .mdc-text-field--textarea .mdc-floating-label--float-above { + -webkit-transform: translateY(-144%) scale(1); + transform: translateY(-144%) scale(1); } + .mdc-text-field--textarea .mdc-floating-label--float-above { + font-size: 0.75rem; } + .mdc-text-field--textarea.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--textarea .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + -webkit-transform: translateY(-130%) scale(0.75); + transform: translateY(-130%) scale(0.75); } + .mdc-text-field--textarea.mdc-notched-outline--upgraded .mdc-floating-label--float-above, + .mdc-text-field--textarea .mdc-notched-outline--upgraded .mdc-floating-label--float-above { + font-size: 1rem; } + .mdc-text-field--textarea .mdc-text-field-character-counter { + /* @noflip */ + left: initial; + /* @noflip */ + right: 16px; + position: absolute; + bottom: 13px; } + [dir="rtl"] .mdc-text-field--textarea .mdc-text-field-character-counter, .mdc-text-field--textarea .mdc-text-field-character-counter[dir="rtl"] { + /* @noflip */ + left: 16px; + /* @noflip */ + right: initial; } + .mdc-text-field--textarea .mdc-text-field__input { + align-self: auto; + box-sizing: border-box; + height: auto; + margin: 8px 1px 1px 0; + padding: 0 16px 16px; + border: none; } + .mdc-text-field--textarea .mdc-text-field-character-counter + .mdc-text-field__input { + margin-bottom: 28px; + padding-bottom: 0; } + .mdc-text-field--textarea .mdc-floating-label { + top: 17px; + bottom: auto; + width: auto; + pointer-events: none; } + .mdc-text-field--textarea.mdc-text-field--focused .mdc-notched-outline__leading, + .mdc-text-field--textarea.mdc-text-field--focused .mdc-notched-outline__notch, + .mdc-text-field--textarea.mdc-text-field--focused .mdc-notched-outline__trailing { + border-width: 2px; } + +.mdc-text-field--fullwidth { + width: 100%; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea) { + display: block; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea)::before, .mdc-text-field--fullwidth:not(.mdc-text-field--textarea)::after { + content: none; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea):not(.mdc-text-field--disabled) { + background-color: transparent; } + .mdc-text-field--fullwidth:not(.mdc-text-field--textarea) .mdc-text-field__input { + padding: 0; } + .mdc-text-field--fullwidth.mdc-text-field--textarea .mdc-text-field__input { + resize: vertical; } + +.mdc-text-field--fullwidth.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--textarea) { + border-bottom-color: #b00020; + /* @alternate */ + border-bottom-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field-helper-line { + display: -webkit-box; + display: flex; + -webkit-box-pack: justify; + justify-content: space-between; + box-sizing: border-box; } + .mdc-text-field--dense + .mdc-text-field-helper-line { + margin-bottom: 4px; } + .mdc-text-field + .mdc-text-field-helper-line { + padding-right: 16px; + padding-left: 16px; } + +.mdc-form-field > .mdc-text-field + label { + align-self: flex-start; } + +.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-floating-label { + color: rgba(252, 184, 171, 0.87); } + +.mdc-text-field--focused .mdc-text-field__input:required ~ .mdc-floating-label::after, +.mdc-text-field--focused .mdc-text-field__input:required ~ .mdc-notched-outline .mdc-floating-label::after { + color: rgba(252, 184, 171, 0.87); } + +.mdc-text-field--focused + .mdc-text-field-helper-line .mdc-text-field-helper-text:not(.mdc-text-field-helper-text--validation-msg) { + opacity: 1; } + +.mdc-text-field--textarea.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--focused:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input { + border-bottom-color: #b00020; + /* @alternate */ + border-bottom-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--outlined):not(.mdc-text-field--textarea) .mdc-text-field__input:hover { + border-bottom-color: #b00020; + /* @alternate */ + border-bottom-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-line-ripple { + background-color: #b00020; + /* @alternate */ + background-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-floating-label { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--invalid + .mdc-text-field-helper-line .mdc-text-field-helper-text--validation-msg { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid .mdc-text-field__input { + caret-color: #b00020; + /* @alternate */ + caret-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-text-field__input:required ~ .mdc-floating-label::after, +.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-text-field__input:required ~ .mdc-notched-outline .mdc-floating-label::after { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid.mdc-text-field--with-trailing-icon:not(.mdc-text-field--with-leading-icon):not(.mdc-text-field--disabled) .mdc-text-field__icon { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid.mdc-text-field--with-trailing-icon.mdc-text-field--with-leading-icon:not(.mdc-text-field--disabled) .mdc-text-field__icon ~ .mdc-text-field__icon { + color: #b00020; + /* @alternate */ + color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--invalid + .mdc-text-field-helper-line .mdc-text-field-helper-text--validation-msg { + opacity: 1; } + +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, +.mdc-text-field--textarea.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled) .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__input:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled):not(.mdc-text-field--focused) .mdc-text-field__icon:hover ~ .mdc-notched-outline .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__leading, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__notch, +.mdc-text-field--outlined.mdc-text-field--invalid:not(.mdc-text-field--disabled).mdc-text-field--focused .mdc-notched-outline__trailing { + border-color: #b00020; + /* @alternate */ + border-color: var(--mdc-theme-error, #b00020); } + +.mdc-text-field--disabled { + background-color: #fafafa; + border-bottom: none; + pointer-events: none; } + .mdc-text-field--disabled .mdc-text-field__input { + border-bottom-color: rgba(0, 0, 0, 0.06); } + .mdc-text-field--disabled .mdc-text-field__input { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled .mdc-floating-label { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled + .mdc-text-field-helper-line .mdc-text-field-helper-text { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled .mdc-text-field-character-counter, + .mdc-text-field--disabled + .mdc-text-field-helper-line .mdc-text-field-character-counter { + color: rgba(0, 0, 0, 0.37); } + .mdc-text-field--disabled .mdc-text-field__icon { + color: rgba(0, 0, 0, 0.3); } + .mdc-text-field--disabled:not(.mdc-text-field--textarea) { + border-bottom-color: rgba(0, 0, 0, 0.12); } + .mdc-text-field--disabled .mdc-floating-label { + cursor: default; } + +.mdc-text-field--textarea.mdc-text-field--disabled { + background-color: transparent; + /* @alternate */ + background-color: #f9f9f9; } + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-notched-outline__leading, + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-notched-outline__notch, + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-notched-outline__trailing { + border-color: rgba(0, 0, 0, 0.06); } + .mdc-text-field--textarea.mdc-text-field--disabled .mdc-text-field__input { + border-bottom: none; } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-70%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-70%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-70%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-dense { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 0%)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 0%)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 0%)) translateY(-120%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense { + 0% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense { + 0% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - 21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - 21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - 21px)) translateY(-120%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-rtl { + 0% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0)) translateY(-130%) scale(0.75); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl { + 0% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } } + +@keyframes mdc-floating-label-shake-float-above-text-field-outlined-leading-icon-dense-rtl { + 0% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(4% - -21px)) translateY(-120%) scale(0.8); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(-4% - -21px)) translateY(-120%) scale(0.8); } + 100% { + -webkit-transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); + transform: translateX(calc(0 - -21px)) translateY(-120%) scale(0.8); } } + +@-webkit-keyframes mdc-floating-label-shake-float-above-textarea { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +@keyframes mdc-floating-label-shake-float-above-textarea { + 0% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } + 33% { + -webkit-animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + animation-timing-function: cubic-bezier(0.5, 0, 0.70173, 0.49582); + -webkit-transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(4% - 0%)) translateY(-130%) scale(0.75); } + 66% { + -webkit-animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + animation-timing-function: cubic-bezier(0.30244, 0.38135, 0.55, 0.95635); + -webkit-transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(-4% - 0%)) translateY(-130%) scale(0.75); } + 100% { + -webkit-transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); + transform: translateX(calc(0 - 0%)) translateY(-130%) scale(0.75); } } + +/** + * Copyright 2019 Mashiro + * @description header + * @author Mashiro + * @license MIT + */ +.mdc-top-app-bar { + background-color: #fcb8ab; + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); + color: rgba(0, 0, 0, 0.87); + display: -webkit-box; + display: flex; + position: fixed; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-direction: column; + -webkit-box-pack: justify; + justify-content: space-between; + box-sizing: border-box; + width: 100%; + z-index: 4; } + .mdc-top-app-bar .mdc-top-app-bar__action-item, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon { + color: #442b2d; + /* @alternate */ + color: var(--mdc-theme-on-primary, #442b2d); } + .mdc-top-app-bar .mdc-top-app-bar__action-item::before, .mdc-top-app-bar .mdc-top-app-bar__action-item::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::after { + background-color: #442b2d; } + @supports not (-ms-ime-align: auto) { + .mdc-top-app-bar .mdc-top-app-bar__action-item::before, .mdc-top-app-bar .mdc-top-app-bar__action-item::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon::after { + /* @alternate */ + background-color: var(--mdc-theme-on-primary, #442b2d); } } + .mdc-top-app-bar .mdc-top-app-bar__action-item:hover::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:hover::before { + opacity: 0.04; } + .mdc-top-app-bar .mdc-top-app-bar__action-item:not(.mdc-ripple-upgraded):focus::before, .mdc-top-app-bar .mdc-top-app-bar__action-item.mdc-ripple-upgraded--background-focused::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:not(.mdc-ripple-upgraded):focus::before, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-top-app-bar .mdc-top-app-bar__action-item:not(.mdc-ripple-upgraded)::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-top-app-bar .mdc-top-app-bar__action-item:not(.mdc-ripple-upgraded):active::after, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-top-app-bar .mdc-top-app-bar__action-item.mdc-ripple-upgraded, + .mdc-top-app-bar .mdc-top-app-bar__navigation-icon.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + .mdc-top-app-bar__row { + display: -webkit-box; + display: flex; + position: relative; + box-sizing: border-box; + width: 100%; + height: 64px; } + .mdc-top-app-bar__section { + display: -webkit-inline-box; + display: inline-flex; + -webkit-box-flex: 1; + flex: 1 1 auto; + -webkit-box-align: center; + align-items: center; + min-width: 0; + padding: 8px 12px; + z-index: 1; } + .mdc-top-app-bar__section--align-start { + -webkit-box-pack: start; + justify-content: flex-start; + -webkit-box-ordinal-group: 0; + order: -1; } + .mdc-top-app-bar__section--align-end { + -webkit-box-pack: end; + justify-content: flex-end; + -webkit-box-ordinal-group: 2; + order: 1; } + .mdc-top-app-bar__title { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1.25rem; + line-height: 2rem; + font-weight: 500; + letter-spacing: 0.0125em; + text-decoration: inherit; + text-transform: inherit; + /* @noflip */ + padding-left: 20px; + /* @noflip */ + padding-right: 0; + text-overflow: ellipsis; + white-space: nowrap; + overflow: hidden; + z-index: 1; } + [dir="rtl"] .mdc-top-app-bar__title, .mdc-top-app-bar__title[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 20px; } + +.mdc-top-app-bar--short-collapsed { + /* @noflip */ + border-radius: 0 0 24px 0; } + [dir="rtl"] .mdc-top-app-bar--short-collapsed, .mdc-top-app-bar--short-collapsed[dir="rtl"] { + /* @noflip */ + border-radius: 0 0 0 24px; } + +.mdc-top-app-bar--short { + top: 0; + /* @noflip */ + right: auto; + /* @noflip */ + left: 0; + width: 100%; + -webkit-transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); } + [dir="rtl"] .mdc-top-app-bar--short, .mdc-top-app-bar--short[dir="rtl"] { + /* @noflip */ + right: 0; + /* @noflip */ + left: auto; } + .mdc-top-app-bar--short .mdc-top-app-bar__row { + height: 56px; } + .mdc-top-app-bar--short .mdc-top-app-bar__section { + padding: 4px; } + .mdc-top-app-bar--short .mdc-top-app-bar__title { + -webkit-transition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1); + transition: opacity 200ms cubic-bezier(0.4, 0, 0.2, 1); + opacity: 1; } + +.mdc-top-app-bar--short-collapsed { + box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12); + width: 56px; + -webkit-transition: width 300ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 300ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__title { + display: none; } + .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__action-item { + -webkit-transition: padding 150ms cubic-bezier(0.4, 0, 0.2, 1); + transition: padding 150ms cubic-bezier(0.4, 0, 0.2, 1); } + +.mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item { + width: 112px; } + .mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item .mdc-top-app-bar__section--align-end { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 12px; } + [dir="rtl"] .mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item .mdc-top-app-bar__section--align-end, .mdc-top-app-bar--short-collapsed.mdc-top-app-bar--short-has-action-item .mdc-top-app-bar__section--align-end[dir="rtl"] { + /* @noflip */ + padding-left: 12px; + /* @noflip */ + padding-right: 0; } + +.mdc-top-app-bar--dense .mdc-top-app-bar__row { + height: 48px; } + +.mdc-top-app-bar--dense .mdc-top-app-bar__section { + padding: 0 4px; } + +.mdc-top-app-bar--dense .mdc-top-app-bar__title { + /* @noflip */ + padding-left: 12px; + /* @noflip */ + padding-right: 0; } + [dir="rtl"] .mdc-top-app-bar--dense .mdc-top-app-bar__title, .mdc-top-app-bar--dense .mdc-top-app-bar__title[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 12px; } + +.mdc-top-app-bar--prominent .mdc-top-app-bar__row { + height: 128px; } + +.mdc-top-app-bar--prominent .mdc-top-app-bar__title { + align-self: flex-end; + padding-bottom: 2px; } + +.mdc-top-app-bar--prominent .mdc-top-app-bar__action-item, +.mdc-top-app-bar--prominent .mdc-top-app-bar__navigation-icon { + align-self: flex-start; } + +.mdc-top-app-bar--fixed { + -webkit-transition: box-shadow 200ms linear; + transition: box-shadow 200ms linear; } + +.mdc-top-app-bar--fixed-scrolled { + box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12); + -webkit-transition: box-shadow 200ms linear; + transition: box-shadow 200ms linear; } + +.mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__row { + height: 96px; } + +.mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__section { + padding: 0 12px; } + +.mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__title { + /* @noflip */ + padding-left: 20px; + /* @noflip */ + padding-right: 0; + padding-bottom: 9px; } + [dir="rtl"] .mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__title, .mdc-top-app-bar--dense.mdc-top-app-bar--prominent .mdc-top-app-bar__title[dir="rtl"] { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 20px; } + +.mdc-top-app-bar--fixed-adjust { + padding-top: 64px; } + +.mdc-top-app-bar--dense-fixed-adjust { + padding-top: 48px; } + +.mdc-top-app-bar--short-fixed-adjust { + padding-top: 56px; } + +.mdc-top-app-bar--prominent-fixed-adjust { + padding-top: 128px; } + +.mdc-top-app-bar--dense-prominent-fixed-adjust { + padding-top: 96px; } + +@media (max-width: 599px) { + .mdc-top-app-bar__row { + height: 56px; } + .mdc-top-app-bar__section { + padding: 4px; } + .mdc-top-app-bar--short { + -webkit-transition: width 200ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 200ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-top-app-bar--short-collapsed { + -webkit-transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); + transition: width 250ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__section--align-end { + /* @noflip */ + padding-left: 0; + /* @noflip */ + padding-right: 12px; } + [dir="rtl"] .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__section--align-end, .mdc-top-app-bar--short-collapsed .mdc-top-app-bar__section--align-end[dir="rtl"] { + /* @noflip */ + padding-left: 12px; + /* @noflip */ + padding-right: 0; } + .mdc-top-app-bar--prominent .mdc-top-app-bar__title { + padding-bottom: 6px; } + .mdc-top-app-bar--fixed-adjust { + padding-top: 56px; } } + +.mdc-icon-button { + width: 48px; + height: 48px; + padding: 12px; + font-size: 24px; + display: inline-block; + position: relative; + box-sizing: border-box; + border: none; + outline: none; + background-color: transparent; + fill: currentColor; + color: inherit; + text-decoration: none; + cursor: pointer; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; } + .mdc-icon-button svg, + .mdc-icon-button img { + width: 24px; + height: 24px; } + .mdc-icon-button:disabled { + color: rgba(0, 0, 0, 0.38); + /* @alternate */ + color: var(--mdc-theme-text-disabled-on-light, rgba(0, 0, 0, 0.38)); + cursor: default; + pointer-events: none; } + +.mdc-icon-button__icon { + display: inline-block; } + .mdc-icon-button__icon.mdc-icon-button__icon--on { + display: none; } + +.mdc-icon-button--on .mdc-icon-button__icon { + display: none; } + .mdc-icon-button--on .mdc-icon-button__icon.mdc-icon-button__icon--on { + display: inline-block; } + +.mdc-icon-button { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); } + .mdc-icon-button::before, .mdc-icon-button::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-icon-button::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-icon-button.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-icon-button.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-icon-button.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-icon-button.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-icon-button.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-icon-button::before, .mdc-icon-button::after { + top: calc(50% - 50%); + /* @noflip */ + left: calc(50% - 50%); + width: 100%; + height: 100%; } + .mdc-icon-button.mdc-ripple-upgraded::before, .mdc-icon-button.mdc-ripple-upgraded::after { + top: var(--mdc-ripple-top, calc(50% - 50%)); + /* @noflip */ + left: var(--mdc-ripple-left, calc(50% - 50%)); + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-icon-button.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-icon-button::before, .mdc-icon-button::after { + background-color: #000; } + .mdc-icon-button:hover::before { + opacity: 0.04; } + .mdc-icon-button:not(.mdc-ripple-upgraded):focus::before, .mdc-icon-button.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-icon-button:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-icon-button:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-icon-button.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + +/** + * @description homepage cover image + * @author Mashiro + * @since 19/11/1 + */ +.header-top { + position: fixed; + width: 100%; + height: 100%; } + .header-top figure { + width: 100%; + margin: 0; + overflow: hidden; } + +#header-top-after { + width: 100%; } + +/** + * Copyright 2019 Mashiro + * @description site content + * @author Mashiro + * @license MIT + */ +.page-content { + position: relative; + background: white; + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-flow: row nowrap; + -webkit-box-pack: justify; + justify-content: space-between; } + .page-content .main-center { + height: 100%; + width: 800px; + background: #9acd3220; } + .page-content .side-bar-left { + width: 100px; } + .page-content .side-bar-right { + width: 100px; } + +.mdc-card { + border-radius: 4px; + background-color: #fff; + /* @alternate */ + background-color: var(--mdc-theme-surface, #fff); + box-shadow: 0px 2px 1px -1px rgba(0, 0, 0, 0.2), 0px 1px 1px 0px rgba(0, 0, 0, 0.14), 0px 1px 3px 0px rgba(0, 0, 0, 0.12); + display: -webkit-box; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-direction: column; + box-sizing: border-box; } + +.mdc-card--outlined { + box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.2), 0px 0px 0px 0px rgba(0, 0, 0, 0.14), 0px 0px 0px 0px rgba(0, 0, 0, 0.12); + border-width: 1px; + border-style: solid; + border-color: #e0e0e0; } + +.mdc-card__media { + position: relative; + box-sizing: border-box; + background-repeat: no-repeat; + background-position: center; + background-size: cover; } + .mdc-card__media::before { + display: block; + content: ""; } + +.mdc-card__media:first-child { + border-top-left-radius: inherit; + border-top-right-radius: inherit; } + +.mdc-card__media:last-child { + border-bottom-left-radius: inherit; + border-bottom-right-radius: inherit; } + +.mdc-card__media--square::before { + margin-top: 100%; } + +.mdc-card__media--16-9::before { + margin-top: 56.25%; } + +.mdc-card__media-content { + position: absolute; + top: 0; + right: 0; + bottom: 0; + left: 0; + box-sizing: border-box; } + +.mdc-card__primary-action { + display: -webkit-box; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-direction: column; + box-sizing: border-box; + position: relative; + outline: none; + color: inherit; + text-decoration: none; + cursor: pointer; + overflow: hidden; } + +.mdc-card__primary-action:first-child { + border-top-left-radius: inherit; + border-top-right-radius: inherit; } + +.mdc-card__primary-action:last-child { + border-bottom-left-radius: inherit; + border-bottom-right-radius: inherit; } + +.mdc-card__actions { + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-direction: row; + -webkit-box-align: center; + align-items: center; + box-sizing: border-box; + min-height: 52px; + padding: 8px; } + +.mdc-card__actions--full-bleed { + padding: 0; } + +.mdc-card__action-buttons, +.mdc-card__action-icons { + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-direction: row; + -webkit-box-align: center; + align-items: center; + box-sizing: border-box; } + +.mdc-card__action-icons { + color: rgba(0, 0, 0, 0.6); + -webkit-box-flex: 1; + flex-grow: 1; + -webkit-box-pack: end; + justify-content: flex-end; } + +.mdc-card__action-buttons + .mdc-card__action-icons { + /* @noflip */ + margin-left: 16px; + /* @noflip */ + margin-right: 0; } + [dir="rtl"] .mdc-card__action-buttons + .mdc-card__action-icons, .mdc-card__action-buttons + .mdc-card__action-icons[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 16px; } + +.mdc-card__action { + display: -webkit-inline-box; + display: inline-flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-direction: row; + -webkit-box-align: center; + align-items: center; + box-sizing: border-box; + -webkit-box-pack: center; + justify-content: center; + cursor: pointer; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; } + .mdc-card__action:focus { + outline: none; } + +.mdc-card__action--button { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 8px; + padding: 0 8px; } + [dir="rtl"] .mdc-card__action--button, .mdc-card__action--button[dir="rtl"] { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: 0; } + .mdc-card__action--button:last-child { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 0; } + [dir="rtl"] .mdc-card__action--button:last-child, .mdc-card__action--button:last-child[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 0; } + +.mdc-card__actions--full-bleed .mdc-card__action--button { + -webkit-box-pack: justify; + justify-content: space-between; + width: 100%; + height: auto; + max-height: none; + margin: 0; + padding: 8px 16px; + /* @noflip */ + text-align: left; } + [dir="rtl"] .mdc-card__actions--full-bleed .mdc-card__action--button, .mdc-card__actions--full-bleed .mdc-card__action--button[dir="rtl"] { + /* @noflip */ + text-align: right; } + +.mdc-card__action--icon { + margin: -6px 0; + padding: 12px; } + +.mdc-card__action--icon:not(:disabled) { + color: rgba(0, 0, 0, 0.6); } + +.mdc-card__primary-action { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); } + .mdc-card__primary-action::before, .mdc-card__primary-action::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-card__primary-action::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-card__primary-action.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-card__primary-action.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-card__primary-action.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-card__primary-action.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-card__primary-action.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-card__primary-action::before, .mdc-card__primary-action::after { + top: calc(50% - 100%); + /* @noflip */ + left: calc(50% - 100%); + width: 200%; + height: 200%; } + .mdc-card__primary-action.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-card__primary-action::before, .mdc-card__primary-action::after { + background-color: #000; } + .mdc-card__primary-action:hover::before { + opacity: 0.04; } + .mdc-card__primary-action:not(.mdc-ripple-upgraded):focus::before, .mdc-card__primary-action.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-card__primary-action:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-card__primary-action:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + .mdc-card__primary-action.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + +.mdc-button { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 2.25rem; + font-weight: 500; + letter-spacing: 0.08929em; + text-decoration: none; + text-transform: uppercase; + padding: 0 8px 0 8px; + display: -webkit-inline-box; + display: inline-flex; + position: relative; + -webkit-box-align: center; + align-items: center; + -webkit-box-pack: center; + justify-content: center; + box-sizing: border-box; + min-width: 64px; + height: 36px; + border: none; + outline: none; + /* @alternate */ + line-height: inherit; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + -webkit-appearance: none; + overflow: hidden; + vertical-align: middle; + border-radius: 4px; } + .mdc-button::-moz-focus-inner { + padding: 0; + border: 0; } + .mdc-button:active { + outline: none; } + .mdc-button:hover { + cursor: pointer; } + .mdc-button:disabled { + background-color: transparent; + color: rgba(0, 0, 0, 0.37); + cursor: default; + pointer-events: none; } + .mdc-button.mdc-button--dense { + border-radius: 4px; } + .mdc-button:not(:disabled) { + background-color: transparent; } + .mdc-button .mdc-button__icon { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 8px; + display: inline-block; + width: 18px; + height: 18px; + font-size: 18px; + vertical-align: top; } + [dir="rtl"] .mdc-button .mdc-button__icon, .mdc-button .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: 0; } + .mdc-button:not(:disabled) { + color: #fcb8ab; + /* @alternate */ + color: var(--mdc-theme-primary, #fcb8ab); } + +.mdc-button__label + .mdc-button__icon { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: 0; } + [dir="rtl"] .mdc-button__label + .mdc-button__icon, .mdc-button__label + .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: 0; + /* @noflip */ + margin-right: 8px; } + +svg.mdc-button__icon { + fill: currentColor; } + +.mdc-button--raised .mdc-button__icon, +.mdc-button--unelevated .mdc-button__icon, +.mdc-button--outlined .mdc-button__icon { + /* @noflip */ + margin-left: -4px; + /* @noflip */ + margin-right: 8px; } + [dir="rtl"] .mdc-button--raised .mdc-button__icon, .mdc-button--raised .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--unelevated .mdc-button__icon, + .mdc-button--unelevated .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--outlined .mdc-button__icon, + .mdc-button--outlined .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: -4px; } + +.mdc-button--raised .mdc-button__label + .mdc-button__icon, +.mdc-button--unelevated .mdc-button__label + .mdc-button__icon, +.mdc-button--outlined .mdc-button__label + .mdc-button__icon { + /* @noflip */ + margin-left: 8px; + /* @noflip */ + margin-right: -4px; } + [dir="rtl"] .mdc-button--raised .mdc-button__label + .mdc-button__icon, .mdc-button--raised .mdc-button__label + .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--unelevated .mdc-button__label + .mdc-button__icon, + .mdc-button--unelevated .mdc-button__label + .mdc-button__icon[dir="rtl"], [dir="rtl"] + .mdc-button--outlined .mdc-button__label + .mdc-button__icon, + .mdc-button--outlined .mdc-button__label + .mdc-button__icon[dir="rtl"] { + /* @noflip */ + margin-left: -4px; + /* @noflip */ + margin-right: 8px; } + +.mdc-button--raised, +.mdc-button--unelevated { + padding: 0 16px 0 16px; } + .mdc-button--raised:disabled, + .mdc-button--unelevated:disabled { + background-color: rgba(0, 0, 0, 0.12); + color: rgba(0, 0, 0, 0.37); } + .mdc-button--raised:not(:disabled), + .mdc-button--unelevated:not(:disabled) { + background-color: #fcb8ab; } + @supports not (-ms-ime-align: auto) { + .mdc-button--raised:not(:disabled), + .mdc-button--unelevated:not(:disabled) { + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); } } + .mdc-button--raised:not(:disabled), + .mdc-button--unelevated:not(:disabled) { + color: #442b2d; + /* @alternate */ + color: var(--mdc-theme-on-primary, #442b2d); } + +.mdc-button--raised { + box-shadow: 0px 3px 1px -2px rgba(0, 0, 0, 0.2), 0px 2px 2px 0px rgba(0, 0, 0, 0.14), 0px 1px 5px 0px rgba(0, 0, 0, 0.12); + -webkit-transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1); + transition: box-shadow 280ms cubic-bezier(0.4, 0, 0.2, 1); } + .mdc-button--raised:hover, .mdc-button--raised:focus { + box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12); } + .mdc-button--raised:active { + box-shadow: 0px 5px 5px -3px rgba(0, 0, 0, 0.2), 0px 8px 10px 1px rgba(0, 0, 0, 0.14), 0px 3px 14px 2px rgba(0, 0, 0, 0.12); } + .mdc-button--raised:disabled { + box-shadow: 0px 0px 0px 0px rgba(0, 0, 0, 0.2), 0px 0px 0px 0px rgba(0, 0, 0, 0.14), 0px 0px 0px 0px rgba(0, 0, 0, 0.12); } + +.mdc-button--outlined { + border-style: solid; + padding: 0 15px 0 15px; + border-width: 1px; } + .mdc-button--outlined:disabled { + border-color: rgba(0, 0, 0, 0.37); } + .mdc-button--outlined:not(:disabled) { + border-color: #fcb8ab; + /* @alternate */ + border-color: var(--mdc-theme-primary, #fcb8ab); } + +.mdc-button--dense { + height: 32px; + font-size: .8125rem; } + +.mdc-button { + --mdc-ripple-fg-size: 0; + --mdc-ripple-left: 0; + --mdc-ripple-top: 0; + --mdc-ripple-fg-scale: 1; + --mdc-ripple-fg-translate-end: 0; + --mdc-ripple-fg-translate-start: 0; + -webkit-tap-highlight-color: rgba(0, 0, 0, 0); } + .mdc-button::before, .mdc-button::after { + position: absolute; + border-radius: 50%; + opacity: 0; + pointer-events: none; + content: ""; } + .mdc-button::before { + -webkit-transition: opacity 15ms linear, background-color 15ms linear; + transition: opacity 15ms linear, background-color 15ms linear; + z-index: 1; } + .mdc-button.mdc-ripple-upgraded::before { + -webkit-transform: scale(var(--mdc-ripple-fg-scale, 1)); + transform: scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-button.mdc-ripple-upgraded::after { + top: 0; + /* @noflip */ + left: 0; + -webkit-transform: scale(0); + transform: scale(0); + -webkit-transform-origin: center center; + transform-origin: center center; } + .mdc-button.mdc-ripple-upgraded--unbounded::after { + top: var(--mdc-ripple-top, 0); + /* @noflip */ + left: var(--mdc-ripple-left, 0); } + .mdc-button.mdc-ripple-upgraded--foreground-activation::after { + -webkit-animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; + animation: mdc-ripple-fg-radius-in 225ms forwards, mdc-ripple-fg-opacity-in 75ms forwards; } + .mdc-button.mdc-ripple-upgraded--foreground-deactivation::after { + -webkit-animation: mdc-ripple-fg-opacity-out 150ms; + animation: mdc-ripple-fg-opacity-out 150ms; + -webkit-transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); + transform: translate(var(--mdc-ripple-fg-translate-end, 0)) scale(var(--mdc-ripple-fg-scale, 1)); } + .mdc-button::before, .mdc-button::after { + top: calc(50% - 100%); + /* @noflip */ + left: calc(50% - 100%); + width: 200%; + height: 200%; } + .mdc-button.mdc-ripple-upgraded::after { + width: var(--mdc-ripple-fg-size, 100%); + height: var(--mdc-ripple-fg-size, 100%); } + .mdc-button::before, .mdc-button::after { + background-color: #fcb8ab; } + @supports not (-ms-ime-align: auto) { + .mdc-button::before, .mdc-button::after { + /* @alternate */ + background-color: var(--mdc-theme-primary, #fcb8ab); } } + .mdc-button:hover::before { + opacity: 0.08; } + .mdc-button:not(.mdc-ripple-upgraded):focus::before, .mdc-button.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.24; } + .mdc-button:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + .mdc-button:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.24; } + .mdc-button.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.24; } + +.mdc-button--raised::before, .mdc-button--raised::after, +.mdc-button--unelevated::before, +.mdc-button--unelevated::after { + background-color: #442b2d; } + @supports not (-ms-ime-align: auto) { + .mdc-button--raised::before, .mdc-button--raised::after, + .mdc-button--unelevated::before, + .mdc-button--unelevated::after { + /* @alternate */ + background-color: var(--mdc-theme-on-primary, #442b2d); } } + +.mdc-button--raised:hover::before, +.mdc-button--unelevated:hover::before { + opacity: 0.04; } + +.mdc-button--raised:not(.mdc-ripple-upgraded):focus::before, .mdc-button--raised.mdc-ripple-upgraded--background-focused::before, +.mdc-button--unelevated:not(.mdc-ripple-upgraded):focus::before, +.mdc-button--unelevated.mdc-ripple-upgraded--background-focused::before { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + +.mdc-button--raised:not(.mdc-ripple-upgraded)::after, +.mdc-button--unelevated:not(.mdc-ripple-upgraded)::after { + -webkit-transition: opacity 150ms linear; + transition: opacity 150ms linear; } + +.mdc-button--raised:not(.mdc-ripple-upgraded):active::after, +.mdc-button--unelevated:not(.mdc-ripple-upgraded):active::after { + -webkit-transition-duration: 75ms; + transition-duration: 75ms; + opacity: 0.12; } + +.mdc-button--raised.mdc-ripple-upgraded, +.mdc-button--unelevated.mdc-ripple-upgraded { + --mdc-ripple-fg-opacity: 0.12; } + +.mdc-typography { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; } + +.mdc-typography--headline1 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 6rem; + line-height: 6rem; + font-weight: 300; + letter-spacing: -0.01563em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline2 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 3.75rem; + line-height: 3.75rem; + font-weight: 300; + letter-spacing: -0.00833em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline3 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 3rem; + line-height: 3.125rem; + font-weight: 400; + letter-spacing: normal; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline4 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 2.125rem; + line-height: 2.5rem; + font-weight: 400; + letter-spacing: 0.00735em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline5 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1.5rem; + line-height: 2rem; + font-weight: 400; + letter-spacing: normal; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--headline6 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1.25rem; + line-height: 2rem; + font-weight: 500; + letter-spacing: 0.0125em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--subtitle1 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.75rem; + font-weight: 400; + letter-spacing: 0.00937em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--subtitle2 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 1.375rem; + font-weight: 500; + letter-spacing: 0.00714em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--body1 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 1rem; + line-height: 1.5rem; + font-weight: 400; + letter-spacing: 0.03125em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--body2 { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.01786em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--caption { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 1.25rem; + font-weight: 400; + letter-spacing: 0.03333em; + text-decoration: inherit; + text-transform: inherit; } + +.mdc-typography--button { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.875rem; + line-height: 2.25rem; + font-weight: 500; + letter-spacing: 0.08929em; + text-decoration: none; + text-transform: uppercase; } + +.mdc-typography--overline { + font-family: Roboto, sans-serif; + -moz-osx-font-smoothing: grayscale; + -webkit-font-smoothing: antialiased; + font-size: 0.75rem; + line-height: 2rem; + font-weight: 500; + letter-spacing: 0.16667em; + text-decoration: none; + text-transform: uppercase; } + +.post-thumb-item { + height: 300px; + margin: 10px; } + .post-thumb-item .primary-action { + height: 100%; } + .post-thumb-item .primary-action .content { + height: 100%; + width: 100%; + display: -webkit-box; + display: flex; + -webkit-box-orient: horizontal; + -webkit-box-direction: normal; + flex-flow: row nowrap; + -webkit-box-pack: justify; + justify-content: space-between; } + .post-thumb-item .primary-action .content .post-info { + width: 45%; + height: 100%; + display: -webkit-box; + display: flex; + -webkit-box-orient: vertical; + -webkit-box-direction: normal; + flex-flow: column nowrap; + -webkit-box-pack: justify; + justify-content: space-between; } + .post-thumb-item .primary-action .content .post-info .text { + margin: 30px; } + .post-thumb-item .primary-action .content .post-info .text .post-title { + margin: 0; + color: #504e4e; } + .post-thumb-item .primary-action .content .post-info .text .post-date, + .post-thumb-item .primary-action .content .post-info .text .post-meta { + margin: 0; + color: #888; + font-size: 12px; } + .post-thumb-item .primary-action .content .post-info .text .post-date i, + .post-thumb-item .primary-action .content .post-info .text .post-meta i { + font-size: 12px; } + .post-thumb-item .primary-action .content .post-info .text .post-abstract { + margin: 20px 0; + color: #888; } + .post-thumb-item .primary-action .content .post-info .btn--align-left { + margin: auto auto 30px 30px; } + .post-thumb-item .primary-action .content .post-info .btn--align-right { + margin: auto 30px 30px auto; } + .post-thumb-item .primary-action .content .post-thumb { + width: 55%; + overflow: hidden; } + .post-thumb-item .primary-action .content .post-thumb .thumb-img-box { + height: 100%; + width: 100%; } + .post-thumb-item .primary-action .content .post-thumb .thumb-img-box img { + width: 100%; + height: 100%; + -o-object-fit: cover; + object-fit: cover; + -webkit-transition: all .6s; + transition: all .6s; } + .post-thumb-item .primary-action .content .post-thumb .thumb-img-box img:hover { + -webkit-transform: scale(1.1); + transform: scale(1.1); } diff --git a/docs/dist/bundle.js b/docs/dist/bundle.js new file mode 100644 index 0000000..4df994e --- /dev/null +++ b/docs/dist/bundle.js @@ -0,0 +1,6320 @@ +/******/ (function(modules) { // webpackBootstrap +/******/ // The module cache +/******/ var installedModules = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ +/******/ // Check if module is in cache +/******/ if(installedModules[moduleId]) { +/******/ return installedModules[moduleId].exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = installedModules[moduleId] = { +/******/ i: moduleId, +/******/ l: false, +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Flag the module as loaded +/******/ module.l = true; +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/******/ +/******/ // expose the modules object (__webpack_modules__) +/******/ __webpack_require__.m = modules; +/******/ +/******/ // expose the module cache +/******/ __webpack_require__.c = installedModules; +/******/ +/******/ // define getter function for harmony exports +/******/ __webpack_require__.d = function(exports, name, getter) { +/******/ if(!__webpack_require__.o(exports, name)) { +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); +/******/ } +/******/ }; +/******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = function(module) { +/******/ var getter = module && module.__esModule ? +/******/ function getDefault() { return module['default']; } : +/******/ function getModuleExports() { return module; }; +/******/ __webpack_require__.d(getter, 'a', getter); +/******/ return getter; +/******/ }; +/******/ +/******/ // Object.prototype.hasOwnProperty.call +/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; +/******/ +/******/ // __webpack_public_path__ +/******/ __webpack_require__.p = "/dist/"; +/******/ +/******/ +/******/ // Load entry module and return exports +/******/ return __webpack_require__(__webpack_require__.s = 0); +/******/ }) +/************************************************************************/ +/******/ ({ + +/***/ "./node_modules/@material/base/component.js": +/*!**************************************************!*\ + !*** ./node_modules/@material/base/component.js ***! + \**************************************************/ +/*! exports provided: MDCComponent, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCComponent", function() { return MDCComponent; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/base/foundation.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + +var MDCComponent = /** @class */ (function () { + function MDCComponent(root, foundation) { + var args = []; + for (var _i = 2; _i < arguments.length; _i++) { + args[_i - 2] = arguments[_i]; + } + this.root_ = root; + this.initialize.apply(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__spread"](args)); + // Note that we initialize foundation here and not within the constructor's default param so that + // this.root_ is defined and can be used within the foundation class. + this.foundation_ = foundation === undefined ? this.getDefaultFoundation() : foundation; + this.foundation_.init(); + this.initialSyncWithDOM(); + } + MDCComponent.attachTo = function (root) { + // Subclasses which extend MDCBase should provide an attachTo() method that takes a root element and + // returns an instantiated component with its root set to that element. Also note that in the cases of + // subclasses, an explicit foundation class will not have to be passed in; it will simply be initialized + // from getDefaultFoundation(). + return new MDCComponent(root, new _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"]({})); + }; + /* istanbul ignore next: method param only exists for typing purposes; it does not need to be unit tested */ + MDCComponent.prototype.initialize = function () { + var _args = []; + for (var _i = 0; _i < arguments.length; _i++) { + _args[_i] = arguments[_i]; + } + // Subclasses can override this to do any additional setup work that would be considered part of a + // "constructor". Essentially, it is a hook into the parent constructor before the foundation is + // initialized. Any additional arguments besides root and foundation will be passed in here. + }; + MDCComponent.prototype.getDefaultFoundation = function () { + // Subclasses must override this method to return a properly configured foundation class for the + // component. + throw new Error('Subclasses must override getDefaultFoundation to return a properly configured ' + + 'foundation class'); + }; + MDCComponent.prototype.initialSyncWithDOM = function () { + // Subclasses should override this method if they need to perform work to synchronize with a host DOM + // object. An example of this would be a form control wrapper that needs to synchronize its internal state + // to some property or attribute of the host DOM. Please note: this is *not* the place to perform DOM + // reads/writes that would cause layout / paint, as this is called synchronously from within the constructor. + }; + MDCComponent.prototype.destroy = function () { + // Subclasses may implement this method to release any resources / deregister any listeners they have + // attached. An example of this might be deregistering a resize event from the window object. + this.foundation_.destroy(); + }; + MDCComponent.prototype.listen = function (evtType, handler, options) { + this.root_.addEventListener(evtType, handler, options); + }; + MDCComponent.prototype.unlisten = function (evtType, handler, options) { + this.root_.removeEventListener(evtType, handler, options); + }; + /** + * Fires a cross-browser-compatible custom event from the component root of the given type, with the given data. + */ + MDCComponent.prototype.emit = function (evtType, evtData, shouldBubble) { + if (shouldBubble === void 0) { shouldBubble = false; } + var evt; + if (typeof CustomEvent === 'function') { + evt = new CustomEvent(evtType, { + bubbles: shouldBubble, + detail: evtData, + }); + } + else { + evt = document.createEvent('CustomEvent'); + evt.initCustomEvent(evtType, shouldBubble, false, evtData); + } + this.root_.dispatchEvent(evt); + }; + return MDCComponent; +}()); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCComponent); +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/base/foundation.js": +/*!***************************************************!*\ + !*** ./node_modules/@material/base/foundation.js ***! + \***************************************************/ +/*! exports provided: MDCFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFoundation", function() { return MDCFoundation; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var MDCFoundation = /** @class */ (function () { + function MDCFoundation(adapter) { + if (adapter === void 0) { adapter = {}; } + this.adapter_ = adapter; + } + Object.defineProperty(MDCFoundation, "cssClasses", { + get: function () { + // Classes extending MDCFoundation should implement this method to return an object which exports every + // CSS class the foundation class needs as a property. e.g. {ACTIVE: 'mdc-component--active'} + return {}; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFoundation, "strings", { + get: function () { + // Classes extending MDCFoundation should implement this method to return an object which exports all + // semantic strings as constants. e.g. {ARIA_ROLE: 'tablist'} + return {}; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFoundation, "numbers", { + get: function () { + // Classes extending MDCFoundation should implement this method to return an object which exports all + // of its semantic numbers as constants. e.g. {ANIMATION_DELAY_MS: 350} + return {}; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFoundation, "defaultAdapter", { + get: function () { + // Classes extending MDCFoundation may choose to implement this getter in order to provide a convenient + // way of viewing the necessary methods of an adapter. In the future, this could also be used for adapter + // validation. + return {}; + }, + enumerable: true, + configurable: true + }); + MDCFoundation.prototype.init = function () { + // Subclasses should override this method to perform initialization routines (registering events, etc.) + }; + MDCFoundation.prototype.destroy = function () { + // Subclasses should override this method to perform de-initialization routines (de-registering events, etc.) + }; + return MDCFoundation; +}()); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/dom/events.js": +/*!**********************************************!*\ + !*** ./node_modules/@material/dom/events.js ***! + \**********************************************/ +/*! exports provided: applyPassive */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "applyPassive", function() { return applyPassive; }); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +/** + * Stores result from applyPassive to avoid redundant processing to detect + * passive event listener support. + */ +var supportsPassive_; +/** + * Determine whether the current browser supports passive event listeners, and + * if so, use them. + */ +function applyPassive(globalObj, forceRefresh) { + if (globalObj === void 0) { globalObj = window; } + if (forceRefresh === void 0) { forceRefresh = false; } + if (supportsPassive_ === undefined || forceRefresh) { + var isSupported_1 = false; + try { + globalObj.document.addEventListener('test', function () { return undefined; }, { + get passive() { + isSupported_1 = true; + return isSupported_1; + }, + }); + } + catch (e) { + } // tslint:disable-line:no-empty cannot throw error due to tests. tslint also disables console.log. + supportsPassive_ = isSupported_1; + } + return supportsPassive_ ? { passive: true } : false; +} +//# sourceMappingURL=events.js.map + +/***/ }), + +/***/ "./node_modules/@material/dom/ponyfill.js": +/*!************************************************!*\ + !*** ./node_modules/@material/dom/ponyfill.js ***! + \************************************************/ +/*! exports provided: closest, matches */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "closest", function() { return closest; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "matches", function() { return matches; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +/** + * @fileoverview A "ponyfill" is a polyfill that doesn't modify the global prototype chain. + * This makes ponyfills safer than traditional polyfills, especially for libraries like MDC. + */ +function closest(element, selector) { + if (element.closest) { + return element.closest(selector); + } + var el = element; + while (el) { + if (matches(el, selector)) { + return el; + } + el = el.parentElement; + } + return null; +} +function matches(element, selector) { + var nativeMatches = element.matches + || element.webkitMatchesSelector + || element.msMatchesSelector; + return nativeMatches.call(element, selector); +} +//# sourceMappingURL=ponyfill.js.map + +/***/ }), + +/***/ "./node_modules/@material/floating-label/component.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/floating-label/component.js ***! + \************************************************************/ +/*! exports provided: MDCFloatingLabel */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFloatingLabel", function() { return MDCFloatingLabel; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/floating-label/foundation.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCFloatingLabel = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCFloatingLabel, _super); + function MDCFloatingLabel() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCFloatingLabel.attachTo = function (root) { + return new MDCFloatingLabel(root); + }; + /** + * Styles the label to produce the label shake for errors. + * @param shouldShake If true, shakes the label by adding a CSS class; otherwise, stops shaking by removing the class. + */ + MDCFloatingLabel.prototype.shake = function (shouldShake) { + this.foundation_.shake(shouldShake); + }; + /** + * Styles the label to float/dock. + * @param shouldFloat If true, floats the label by adding a CSS class; otherwise, docks it by removing the class. + */ + MDCFloatingLabel.prototype.float = function (shouldFloat) { + this.foundation_.float(shouldFloat); + }; + MDCFloatingLabel.prototype.getWidth = function () { + return this.foundation_.getWidth(); + }; + MDCFloatingLabel.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + getWidth: function () { return _this.root_.scrollWidth; }, + registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCFloatingLabelFoundation"](adapter); + }; + return MDCFloatingLabel; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/floating-label/constants.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/floating-label/constants.js ***! + \************************************************************/ +/*! exports provided: cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + LABEL_FLOAT_ABOVE: 'mdc-floating-label--float-above', + LABEL_SHAKE: 'mdc-floating-label--shake', + ROOT: 'mdc-floating-label', +}; +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/floating-label/foundation.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/floating-label/foundation.js ***! + \*************************************************************/ +/*! exports provided: MDCFloatingLabelFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFloatingLabelFoundation", function() { return MDCFloatingLabelFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/floating-label/constants.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCFloatingLabelFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCFloatingLabelFoundation, _super); + function MDCFloatingLabelFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCFloatingLabelFoundation.defaultAdapter, adapter)) || this; + _this.shakeAnimationEndHandler_ = function () { return _this.handleShakeAnimationEnd_(); }; + return _this; + } + Object.defineProperty(MDCFloatingLabelFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCFloatingLabelFoundation, "defaultAdapter", { + /** + * See {@link MDCFloatingLabelAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + getWidth: function () { return 0; }, + registerInteractionHandler: function () { return undefined; }, + deregisterInteractionHandler: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCFloatingLabelFoundation.prototype.init = function () { + this.adapter_.registerInteractionHandler('animationend', this.shakeAnimationEndHandler_); + }; + MDCFloatingLabelFoundation.prototype.destroy = function () { + this.adapter_.deregisterInteractionHandler('animationend', this.shakeAnimationEndHandler_); + }; + /** + * Returns the width of the label element. + */ + MDCFloatingLabelFoundation.prototype.getWidth = function () { + return this.adapter_.getWidth(); + }; + /** + * Styles the label to produce a shake animation to indicate an error. + * @param shouldShake If true, adds the shake CSS class; otherwise, removes shake class. + */ + MDCFloatingLabelFoundation.prototype.shake = function (shouldShake) { + var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE; + if (shouldShake) { + this.adapter_.addClass(LABEL_SHAKE); + } + else { + this.adapter_.removeClass(LABEL_SHAKE); + } + }; + /** + * Styles the label to float or dock. + * @param shouldFloat If true, adds the float CSS class; otherwise, removes float and shake classes to dock the label. + */ + MDCFloatingLabelFoundation.prototype.float = function (shouldFloat) { + var _a = MDCFloatingLabelFoundation.cssClasses, LABEL_FLOAT_ABOVE = _a.LABEL_FLOAT_ABOVE, LABEL_SHAKE = _a.LABEL_SHAKE; + if (shouldFloat) { + this.adapter_.addClass(LABEL_FLOAT_ABOVE); + } + else { + this.adapter_.removeClass(LABEL_FLOAT_ABOVE); + this.adapter_.removeClass(LABEL_SHAKE); + } + }; + MDCFloatingLabelFoundation.prototype.handleShakeAnimationEnd_ = function () { + var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE; + this.adapter_.removeClass(LABEL_SHAKE); + }; + return MDCFloatingLabelFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCFloatingLabelFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/line-ripple/component.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/line-ripple/component.js ***! + \*********************************************************/ +/*! exports provided: MDCLineRipple */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCLineRipple", function() { return MDCLineRipple; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/line-ripple/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCLineRipple = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCLineRipple, _super); + function MDCLineRipple() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCLineRipple.attachTo = function (root) { + return new MDCLineRipple(root); + }; + /** + * Activates the line ripple + */ + MDCLineRipple.prototype.activate = function () { + this.foundation_.activate(); + }; + /** + * Deactivates the line ripple + */ + MDCLineRipple.prototype.deactivate = function () { + this.foundation_.deactivate(); + }; + /** + * Sets the transform origin given a user's click location. + * The `rippleCenter` is the x-coordinate of the middle of the ripple. + */ + MDCLineRipple.prototype.setRippleCenter = function (xCoordinate) { + this.foundation_.setRippleCenter(xCoordinate); + }; + MDCLineRipple.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + hasClass: function (className) { return _this.root_.classList.contains(className); }, + setStyle: function (propertyName, value) { return _this.root_.style.setProperty(propertyName, value); }, + registerEventHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterEventHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCLineRippleFoundation"](adapter); + }; + return MDCLineRipple; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/line-ripple/constants.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/line-ripple/constants.js ***! + \*********************************************************/ +/*! exports provided: cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + LINE_RIPPLE_ACTIVE: 'mdc-line-ripple--active', + LINE_RIPPLE_DEACTIVATING: 'mdc-line-ripple--deactivating', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/line-ripple/foundation.js": +/*!**********************************************************!*\ + !*** ./node_modules/@material/line-ripple/foundation.js ***! + \**********************************************************/ +/*! exports provided: MDCLineRippleFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCLineRippleFoundation", function() { return MDCLineRippleFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/line-ripple/constants.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCLineRippleFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCLineRippleFoundation, _super); + function MDCLineRippleFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCLineRippleFoundation.defaultAdapter, adapter)) || this; + _this.transitionEndHandler_ = function (evt) { return _this.handleTransitionEnd(evt); }; + return _this; + } + Object.defineProperty(MDCLineRippleFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCLineRippleFoundation, "defaultAdapter", { + /** + * See {@link MDCLineRippleAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return false; }, + setStyle: function () { return undefined; }, + registerEventHandler: function () { return undefined; }, + deregisterEventHandler: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCLineRippleFoundation.prototype.init = function () { + this.adapter_.registerEventHandler('transitionend', this.transitionEndHandler_); + }; + MDCLineRippleFoundation.prototype.destroy = function () { + this.adapter_.deregisterEventHandler('transitionend', this.transitionEndHandler_); + }; + MDCLineRippleFoundation.prototype.activate = function () { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_ACTIVE); + }; + MDCLineRippleFoundation.prototype.setRippleCenter = function (xCoordinate) { + this.adapter_.setStyle('transform-origin', xCoordinate + "px center"); + }; + MDCLineRippleFoundation.prototype.deactivate = function () { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + }; + MDCLineRippleFoundation.prototype.handleTransitionEnd = function (evt) { + // Wait for the line ripple to be either transparent or opaque + // before emitting the animation end event + var isDeactivating = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + if (evt.propertyName === 'opacity') { + if (isDeactivating) { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_ACTIVE); + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].LINE_RIPPLE_DEACTIVATING); + } + } + }; + return MDCLineRippleFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCLineRippleFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/notched-outline/component.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/notched-outline/component.js ***! + \*************************************************************/ +/*! exports provided: MDCNotchedOutline */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCNotchedOutline", function() { return MDCNotchedOutline; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_floating_label_foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/floating-label/foundation */ "./node_modules/@material/floating-label/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/notched-outline/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/notched-outline/foundation.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + +var MDCNotchedOutline = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCNotchedOutline, _super); + function MDCNotchedOutline() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCNotchedOutline.attachTo = function (root) { + return new MDCNotchedOutline(root); + }; + MDCNotchedOutline.prototype.initialSyncWithDOM = function () { + this.notchElement_ = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].NOTCH_ELEMENT_SELECTOR); + var label = this.root_.querySelector('.' + _material_floating_label_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCFloatingLabelFoundation"].cssClasses.ROOT); + if (label) { + label.style.transitionDuration = '0s'; + this.root_.classList.add(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].OUTLINE_UPGRADED); + requestAnimationFrame(function () { + label.style.transitionDuration = ''; + }); + } + else { + this.root_.classList.add(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].NO_LABEL); + } + }; + /** + * Updates classes and styles to open the notch to the specified width. + * @param notchWidth The notch width in the outline. + */ + MDCNotchedOutline.prototype.notch = function (notchWidth) { + this.foundation_.notch(notchWidth); + }; + /** + * Updates classes and styles to close the notch. + */ + MDCNotchedOutline.prototype.closeNotch = function () { + this.foundation_.closeNotch(); + }; + MDCNotchedOutline.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + setNotchWidthProperty: function (width) { return _this.notchElement_.style.setProperty('width', width + 'px'); }, + removeNotchWidthProperty: function () { return _this.notchElement_.style.removeProperty('width'); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_4__["MDCNotchedOutlineFoundation"](adapter); + }; + return MDCNotchedOutline; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/notched-outline/constants.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/notched-outline/constants.js ***! + \*************************************************************/ +/*! exports provided: cssClasses, numbers, strings */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var strings = { + NOTCH_ELEMENT_SELECTOR: '.mdc-notched-outline__notch', +}; +var numbers = { + // This should stay in sync with $mdc-notched-outline-padding * 2. + NOTCH_ELEMENT_PADDING: 8, +}; +var cssClasses = { + NO_LABEL: 'mdc-notched-outline--no-label', + OUTLINE_NOTCHED: 'mdc-notched-outline--notched', + OUTLINE_UPGRADED: 'mdc-notched-outline--upgraded', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/notched-outline/foundation.js": +/*!**************************************************************!*\ + !*** ./node_modules/@material/notched-outline/foundation.js ***! + \**************************************************************/ +/*! exports provided: MDCNotchedOutlineFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCNotchedOutlineFoundation", function() { return MDCNotchedOutlineFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/notched-outline/constants.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCNotchedOutlineFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCNotchedOutlineFoundation, _super); + function MDCNotchedOutlineFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCNotchedOutlineFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCNotchedOutlineFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCNotchedOutlineFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCNotchedOutlineFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCNotchedOutlineFoundation, "defaultAdapter", { + /** + * See {@link MDCNotchedOutlineAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + setNotchWidthProperty: function () { return undefined; }, + removeNotchWidthProperty: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + /** + * Adds the outline notched selector and updates the notch width calculated based off of notchWidth. + */ + MDCNotchedOutlineFoundation.prototype.notch = function (notchWidth) { + var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED; + if (notchWidth > 0) { + notchWidth += _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].NOTCH_ELEMENT_PADDING; // Add padding from left/right. + } + this.adapter_.setNotchWidthProperty(notchWidth); + this.adapter_.addClass(OUTLINE_NOTCHED); + }; + /** + * Removes notched outline selector to close the notch in the outline. + */ + MDCNotchedOutlineFoundation.prototype.closeNotch = function () { + var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED; + this.adapter_.removeClass(OUTLINE_NOTCHED); + this.adapter_.removeNotchWidthProperty(); + }; + return MDCNotchedOutlineFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCNotchedOutlineFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/component.js": +/*!****************************************************!*\ + !*** ./node_modules/@material/ripple/component.js ***! + \****************************************************/ +/*! exports provided: MDCRipple */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCRipple", function() { return MDCRipple; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_dom_events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/dom/events */ "./node_modules/@material/dom/events.js"); +/* harmony import */ var _material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @material/dom/ponyfill */ "./node_modules/@material/dom/ponyfill.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/ripple/foundation.js"); +/* harmony import */ var _util__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./util */ "./node_modules/@material/ripple/util.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + +var MDCRipple = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCRipple, _super); + function MDCRipple() { + var _this = _super !== null && _super.apply(this, arguments) || this; + _this.disabled = false; + return _this; + } + MDCRipple.attachTo = function (root, opts) { + if (opts === void 0) { opts = { isUnbounded: undefined }; } + var ripple = new MDCRipple(root); + // Only override unbounded behavior if option is explicitly specified + if (opts.isUnbounded !== undefined) { + ripple.unbounded = opts.isUnbounded; + } + return ripple; + }; + MDCRipple.createAdapter = function (instance) { + return { + addClass: function (className) { return instance.root_.classList.add(className); }, + browserSupportsCssVars: function () { return _util__WEBPACK_IMPORTED_MODULE_5__["supportsCssVariables"](window); }, + computeBoundingRect: function () { return instance.root_.getBoundingClientRect(); }, + containsEventTarget: function (target) { return instance.root_.contains(target); }, + deregisterDocumentInteractionHandler: function (evtType, handler) { + return document.documentElement.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + deregisterInteractionHandler: function (evtType, handler) { + return instance.root_.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + deregisterResizeHandler: function (handler) { return window.removeEventListener('resize', handler); }, + getWindowPageOffset: function () { return ({ x: window.pageXOffset, y: window.pageYOffset }); }, + isSurfaceActive: function () { return Object(_material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__["matches"])(instance.root_, ':active'); }, + isSurfaceDisabled: function () { return Boolean(instance.disabled); }, + isUnbounded: function () { return Boolean(instance.unbounded); }, + registerDocumentInteractionHandler: function (evtType, handler) { + return document.documentElement.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + registerInteractionHandler: function (evtType, handler) { + return instance.root_.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + registerResizeHandler: function (handler) { return window.addEventListener('resize', handler); }, + removeClass: function (className) { return instance.root_.classList.remove(className); }, + updateCssVariable: function (varName, value) { return instance.root_.style.setProperty(varName, value); }, + }; + }; + Object.defineProperty(MDCRipple.prototype, "unbounded", { + get: function () { + return Boolean(this.unbounded_); + }, + set: function (unbounded) { + this.unbounded_ = Boolean(unbounded); + this.setUnbounded_(); + }, + enumerable: true, + configurable: true + }); + MDCRipple.prototype.activate = function () { + this.foundation_.activate(); + }; + MDCRipple.prototype.deactivate = function () { + this.foundation_.deactivate(); + }; + MDCRipple.prototype.layout = function () { + this.foundation_.layout(); + }; + MDCRipple.prototype.getDefaultFoundation = function () { + return new _foundation__WEBPACK_IMPORTED_MODULE_4__["MDCRippleFoundation"](MDCRipple.createAdapter(this)); + }; + MDCRipple.prototype.initialSyncWithDOM = function () { + var root = this.root_; + this.unbounded = 'mdcRippleIsUnbounded' in root.dataset; + }; + /** + * Closure Compiler throws an access control error when directly accessing a + * protected or private property inside a getter/setter, like unbounded above. + * By accessing the protected property inside a method, we solve that problem. + * That's why this function exists. + */ + MDCRipple.prototype.setUnbounded_ = function () { + this.foundation_.setUnbounded(Boolean(this.unbounded_)); + }; + return MDCRipple; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/constants.js": +/*!****************************************************!*\ + !*** ./node_modules/@material/ripple/constants.js ***! + \****************************************************/ +/*! exports provided: cssClasses, strings, numbers */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + // Ripple is a special case where the "root" component is really a "mixin" of sorts, + // given that it's an 'upgrade' to an existing component. That being said it is the root + // CSS class that all other CSS classes derive from. + BG_FOCUSED: 'mdc-ripple-upgraded--background-focused', + FG_ACTIVATION: 'mdc-ripple-upgraded--foreground-activation', + FG_DEACTIVATION: 'mdc-ripple-upgraded--foreground-deactivation', + ROOT: 'mdc-ripple-upgraded', + UNBOUNDED: 'mdc-ripple-upgraded--unbounded', +}; +var strings = { + VAR_FG_SCALE: '--mdc-ripple-fg-scale', + VAR_FG_SIZE: '--mdc-ripple-fg-size', + VAR_FG_TRANSLATE_END: '--mdc-ripple-fg-translate-end', + VAR_FG_TRANSLATE_START: '--mdc-ripple-fg-translate-start', + VAR_LEFT: '--mdc-ripple-left', + VAR_TOP: '--mdc-ripple-top', +}; +var numbers = { + DEACTIVATION_TIMEOUT_MS: 225, + FG_DEACTIVATION_MS: 150, + INITIAL_ORIGIN_SCALE: 0.6, + PADDING: 10, + TAP_DELAY_MS: 300, +}; +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/foundation.js": +/*!*****************************************************!*\ + !*** ./node_modules/@material/ripple/foundation.js ***! + \*****************************************************/ +/*! exports provided: MDCRippleFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCRippleFoundation", function() { return MDCRippleFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/ripple/constants.js"); +/* harmony import */ var _util__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./util */ "./node_modules/@material/ripple/util.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + +// Activation events registered on the root element of each instance for activation +var ACTIVATION_EVENT_TYPES = [ + 'touchstart', 'pointerdown', 'mousedown', 'keydown', +]; +// Deactivation events registered on documentElement when a pointer-related down event occurs +var POINTER_DEACTIVATION_EVENT_TYPES = [ + 'touchend', 'pointerup', 'mouseup', 'contextmenu', +]; +// simultaneous nested activations +var activatedTargets = []; +var MDCRippleFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCRippleFoundation, _super); + function MDCRippleFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCRippleFoundation.defaultAdapter, adapter)) || this; + _this.activationAnimationHasEnded_ = false; + _this.activationTimer_ = 0; + _this.fgDeactivationRemovalTimer_ = 0; + _this.fgScale_ = '0'; + _this.frame_ = { width: 0, height: 0 }; + _this.initialSize_ = 0; + _this.layoutFrame_ = 0; + _this.maxRadius_ = 0; + _this.unboundedCoords_ = { left: 0, top: 0 }; + _this.activationState_ = _this.defaultActivationState_(); + _this.activationTimerCallback_ = function () { + _this.activationAnimationHasEnded_ = true; + _this.runDeactivationUXLogicIfReady_(); + }; + _this.activateHandler_ = function (e) { return _this.activate_(e); }; + _this.deactivateHandler_ = function () { return _this.deactivate_(); }; + _this.focusHandler_ = function () { return _this.handleFocus(); }; + _this.blurHandler_ = function () { return _this.handleBlur(); }; + _this.resizeHandler_ = function () { return _this.layout(); }; + return _this; + } + Object.defineProperty(MDCRippleFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCRippleFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCRippleFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCRippleFoundation, "defaultAdapter", { + get: function () { + return { + addClass: function () { return undefined; }, + browserSupportsCssVars: function () { return true; }, + computeBoundingRect: function () { return ({ top: 0, right: 0, bottom: 0, left: 0, width: 0, height: 0 }); }, + containsEventTarget: function () { return true; }, + deregisterDocumentInteractionHandler: function () { return undefined; }, + deregisterInteractionHandler: function () { return undefined; }, + deregisterResizeHandler: function () { return undefined; }, + getWindowPageOffset: function () { return ({ x: 0, y: 0 }); }, + isSurfaceActive: function () { return true; }, + isSurfaceDisabled: function () { return true; }, + isUnbounded: function () { return true; }, + registerDocumentInteractionHandler: function () { return undefined; }, + registerInteractionHandler: function () { return undefined; }, + registerResizeHandler: function () { return undefined; }, + removeClass: function () { return undefined; }, + updateCssVariable: function () { return undefined; }, + }; + }, + enumerable: true, + configurable: true + }); + MDCRippleFoundation.prototype.init = function () { + var _this = this; + var supportsPressRipple = this.supportsPressRipple_(); + this.registerRootHandlers_(supportsPressRipple); + if (supportsPressRipple) { + var _a = MDCRippleFoundation.cssClasses, ROOT_1 = _a.ROOT, UNBOUNDED_1 = _a.UNBOUNDED; + requestAnimationFrame(function () { + _this.adapter_.addClass(ROOT_1); + if (_this.adapter_.isUnbounded()) { + _this.adapter_.addClass(UNBOUNDED_1); + // Unbounded ripples need layout logic applied immediately to set coordinates for both shade and ripple + _this.layoutInternal_(); + } + }); + } + }; + MDCRippleFoundation.prototype.destroy = function () { + var _this = this; + if (this.supportsPressRipple_()) { + if (this.activationTimer_) { + clearTimeout(this.activationTimer_); + this.activationTimer_ = 0; + this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_ACTIVATION); + } + if (this.fgDeactivationRemovalTimer_) { + clearTimeout(this.fgDeactivationRemovalTimer_); + this.fgDeactivationRemovalTimer_ = 0; + this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_DEACTIVATION); + } + var _a = MDCRippleFoundation.cssClasses, ROOT_2 = _a.ROOT, UNBOUNDED_2 = _a.UNBOUNDED; + requestAnimationFrame(function () { + _this.adapter_.removeClass(ROOT_2); + _this.adapter_.removeClass(UNBOUNDED_2); + _this.removeCssVars_(); + }); + } + this.deregisterRootHandlers_(); + this.deregisterDeactivationHandlers_(); + }; + /** + * @param evt Optional event containing position information. + */ + MDCRippleFoundation.prototype.activate = function (evt) { + this.activate_(evt); + }; + MDCRippleFoundation.prototype.deactivate = function () { + this.deactivate_(); + }; + MDCRippleFoundation.prototype.layout = function () { + var _this = this; + if (this.layoutFrame_) { + cancelAnimationFrame(this.layoutFrame_); + } + this.layoutFrame_ = requestAnimationFrame(function () { + _this.layoutInternal_(); + _this.layoutFrame_ = 0; + }); + }; + MDCRippleFoundation.prototype.setUnbounded = function (unbounded) { + var UNBOUNDED = MDCRippleFoundation.cssClasses.UNBOUNDED; + if (unbounded) { + this.adapter_.addClass(UNBOUNDED); + } + else { + this.adapter_.removeClass(UNBOUNDED); + } + }; + MDCRippleFoundation.prototype.handleFocus = function () { + var _this = this; + requestAnimationFrame(function () { + return _this.adapter_.addClass(MDCRippleFoundation.cssClasses.BG_FOCUSED); + }); + }; + MDCRippleFoundation.prototype.handleBlur = function () { + var _this = this; + requestAnimationFrame(function () { + return _this.adapter_.removeClass(MDCRippleFoundation.cssClasses.BG_FOCUSED); + }); + }; + /** + * We compute this property so that we are not querying information about the client + * until the point in time where the foundation requests it. This prevents scenarios where + * client-side feature-detection may happen too early, such as when components are rendered on the server + * and then initialized at mount time on the client. + */ + MDCRippleFoundation.prototype.supportsPressRipple_ = function () { + return this.adapter_.browserSupportsCssVars(); + }; + MDCRippleFoundation.prototype.defaultActivationState_ = function () { + return { + activationEvent: undefined, + hasDeactivationUXRun: false, + isActivated: false, + isProgrammatic: false, + wasActivatedByPointer: false, + wasElementMadeActive: false, + }; + }; + /** + * supportsPressRipple Passed from init to save a redundant function call + */ + MDCRippleFoundation.prototype.registerRootHandlers_ = function (supportsPressRipple) { + var _this = this; + if (supportsPressRipple) { + ACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.registerInteractionHandler(evtType, _this.activateHandler_); + }); + if (this.adapter_.isUnbounded()) { + this.adapter_.registerResizeHandler(this.resizeHandler_); + } + } + this.adapter_.registerInteractionHandler('focus', this.focusHandler_); + this.adapter_.registerInteractionHandler('blur', this.blurHandler_); + }; + MDCRippleFoundation.prototype.registerDeactivationHandlers_ = function (evt) { + var _this = this; + if (evt.type === 'keydown') { + this.adapter_.registerInteractionHandler('keyup', this.deactivateHandler_); + } + else { + POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.registerDocumentInteractionHandler(evtType, _this.deactivateHandler_); + }); + } + }; + MDCRippleFoundation.prototype.deregisterRootHandlers_ = function () { + var _this = this; + ACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.deregisterInteractionHandler(evtType, _this.activateHandler_); + }); + this.adapter_.deregisterInteractionHandler('focus', this.focusHandler_); + this.adapter_.deregisterInteractionHandler('blur', this.blurHandler_); + if (this.adapter_.isUnbounded()) { + this.adapter_.deregisterResizeHandler(this.resizeHandler_); + } + }; + MDCRippleFoundation.prototype.deregisterDeactivationHandlers_ = function () { + var _this = this; + this.adapter_.deregisterInteractionHandler('keyup', this.deactivateHandler_); + POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) { + _this.adapter_.deregisterDocumentInteractionHandler(evtType, _this.deactivateHandler_); + }); + }; + MDCRippleFoundation.prototype.removeCssVars_ = function () { + var _this = this; + var rippleStrings = MDCRippleFoundation.strings; + var keys = Object.keys(rippleStrings); + keys.forEach(function (key) { + if (key.indexOf('VAR_') === 0) { + _this.adapter_.updateCssVariable(rippleStrings[key], null); + } + }); + }; + MDCRippleFoundation.prototype.activate_ = function (evt) { + var _this = this; + if (this.adapter_.isSurfaceDisabled()) { + return; + } + var activationState = this.activationState_; + if (activationState.isActivated) { + return; + } + // Avoid reacting to follow-on events fired by touch device after an already-processed user interaction + var previousActivationEvent = this.previousActivationEvent_; + var isSameInteraction = previousActivationEvent && evt !== undefined && previousActivationEvent.type !== evt.type; + if (isSameInteraction) { + return; + } + activationState.isActivated = true; + activationState.isProgrammatic = evt === undefined; + activationState.activationEvent = evt; + activationState.wasActivatedByPointer = activationState.isProgrammatic ? false : evt !== undefined && (evt.type === 'mousedown' || evt.type === 'touchstart' || evt.type === 'pointerdown'); + var hasActivatedChild = evt !== undefined && activatedTargets.length > 0 && activatedTargets.some(function (target) { return _this.adapter_.containsEventTarget(target); }); + if (hasActivatedChild) { + // Immediately reset activation state, while preserving logic that prevents touch follow-on events + this.resetActivationState_(); + return; + } + if (evt !== undefined) { + activatedTargets.push(evt.target); + this.registerDeactivationHandlers_(evt); + } + activationState.wasElementMadeActive = this.checkElementMadeActive_(evt); + if (activationState.wasElementMadeActive) { + this.animateActivation_(); + } + requestAnimationFrame(function () { + // Reset array on next frame after the current event has had a chance to bubble to prevent ancestor ripples + activatedTargets = []; + if (!activationState.wasElementMadeActive + && evt !== undefined + && (evt.key === ' ' || evt.keyCode === 32)) { + // If space was pressed, try again within an rAF call to detect :active, because different UAs report + // active states inconsistently when they're called within event handling code: + // - https://bugs.chromium.org/p/chromium/issues/detail?id=635971 + // - https://bugzilla.mozilla.org/show_bug.cgi?id=1293741 + // We try first outside rAF to support Edge, which does not exhibit this problem, but will crash if a CSS + // variable is set within a rAF callback for a submit button interaction (#2241). + activationState.wasElementMadeActive = _this.checkElementMadeActive_(evt); + if (activationState.wasElementMadeActive) { + _this.animateActivation_(); + } + } + if (!activationState.wasElementMadeActive) { + // Reset activation state immediately if element was not made active. + _this.activationState_ = _this.defaultActivationState_(); + } + }); + }; + MDCRippleFoundation.prototype.checkElementMadeActive_ = function (evt) { + return (evt !== undefined && evt.type === 'keydown') ? this.adapter_.isSurfaceActive() : true; + }; + MDCRippleFoundation.prototype.animateActivation_ = function () { + var _this = this; + var _a = MDCRippleFoundation.strings, VAR_FG_TRANSLATE_START = _a.VAR_FG_TRANSLATE_START, VAR_FG_TRANSLATE_END = _a.VAR_FG_TRANSLATE_END; + var _b = MDCRippleFoundation.cssClasses, FG_DEACTIVATION = _b.FG_DEACTIVATION, FG_ACTIVATION = _b.FG_ACTIVATION; + var DEACTIVATION_TIMEOUT_MS = MDCRippleFoundation.numbers.DEACTIVATION_TIMEOUT_MS; + this.layoutInternal_(); + var translateStart = ''; + var translateEnd = ''; + if (!this.adapter_.isUnbounded()) { + var _c = this.getFgTranslationCoordinates_(), startPoint = _c.startPoint, endPoint = _c.endPoint; + translateStart = startPoint.x + "px, " + startPoint.y + "px"; + translateEnd = endPoint.x + "px, " + endPoint.y + "px"; + } + this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_START, translateStart); + this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_END, translateEnd); + // Cancel any ongoing activation/deactivation animations + clearTimeout(this.activationTimer_); + clearTimeout(this.fgDeactivationRemovalTimer_); + this.rmBoundedActivationClasses_(); + this.adapter_.removeClass(FG_DEACTIVATION); + // Force layout in order to re-trigger the animation. + this.adapter_.computeBoundingRect(); + this.adapter_.addClass(FG_ACTIVATION); + this.activationTimer_ = setTimeout(function () { return _this.activationTimerCallback_(); }, DEACTIVATION_TIMEOUT_MS); + }; + MDCRippleFoundation.prototype.getFgTranslationCoordinates_ = function () { + var _a = this.activationState_, activationEvent = _a.activationEvent, wasActivatedByPointer = _a.wasActivatedByPointer; + var startPoint; + if (wasActivatedByPointer) { + startPoint = Object(_util__WEBPACK_IMPORTED_MODULE_3__["getNormalizedEventCoords"])(activationEvent, this.adapter_.getWindowPageOffset(), this.adapter_.computeBoundingRect()); + } + else { + startPoint = { + x: this.frame_.width / 2, + y: this.frame_.height / 2, + }; + } + // Center the element around the start point. + startPoint = { + x: startPoint.x - (this.initialSize_ / 2), + y: startPoint.y - (this.initialSize_ / 2), + }; + var endPoint = { + x: (this.frame_.width / 2) - (this.initialSize_ / 2), + y: (this.frame_.height / 2) - (this.initialSize_ / 2), + }; + return { startPoint: startPoint, endPoint: endPoint }; + }; + MDCRippleFoundation.prototype.runDeactivationUXLogicIfReady_ = function () { + var _this = this; + // This method is called both when a pointing device is released, and when the activation animation ends. + // The deactivation animation should only run after both of those occur. + var FG_DEACTIVATION = MDCRippleFoundation.cssClasses.FG_DEACTIVATION; + var _a = this.activationState_, hasDeactivationUXRun = _a.hasDeactivationUXRun, isActivated = _a.isActivated; + var activationHasEnded = hasDeactivationUXRun || !isActivated; + if (activationHasEnded && this.activationAnimationHasEnded_) { + this.rmBoundedActivationClasses_(); + this.adapter_.addClass(FG_DEACTIVATION); + this.fgDeactivationRemovalTimer_ = setTimeout(function () { + _this.adapter_.removeClass(FG_DEACTIVATION); + }, _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].FG_DEACTIVATION_MS); + } + }; + MDCRippleFoundation.prototype.rmBoundedActivationClasses_ = function () { + var FG_ACTIVATION = MDCRippleFoundation.cssClasses.FG_ACTIVATION; + this.adapter_.removeClass(FG_ACTIVATION); + this.activationAnimationHasEnded_ = false; + this.adapter_.computeBoundingRect(); + }; + MDCRippleFoundation.prototype.resetActivationState_ = function () { + var _this = this; + this.previousActivationEvent_ = this.activationState_.activationEvent; + this.activationState_ = this.defaultActivationState_(); + // Touch devices may fire additional events for the same interaction within a short time. + // Store the previous event until it's safe to assume that subsequent events are for new interactions. + setTimeout(function () { return _this.previousActivationEvent_ = undefined; }, MDCRippleFoundation.numbers.TAP_DELAY_MS); + }; + MDCRippleFoundation.prototype.deactivate_ = function () { + var _this = this; + var activationState = this.activationState_; + // This can happen in scenarios such as when you have a keyup event that blurs the element. + if (!activationState.isActivated) { + return; + } + var state = tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, activationState); + if (activationState.isProgrammatic) { + requestAnimationFrame(function () { return _this.animateDeactivation_(state); }); + this.resetActivationState_(); + } + else { + this.deregisterDeactivationHandlers_(); + requestAnimationFrame(function () { + _this.activationState_.hasDeactivationUXRun = true; + _this.animateDeactivation_(state); + _this.resetActivationState_(); + }); + } + }; + MDCRippleFoundation.prototype.animateDeactivation_ = function (_a) { + var wasActivatedByPointer = _a.wasActivatedByPointer, wasElementMadeActive = _a.wasElementMadeActive; + if (wasActivatedByPointer || wasElementMadeActive) { + this.runDeactivationUXLogicIfReady_(); + } + }; + MDCRippleFoundation.prototype.layoutInternal_ = function () { + var _this = this; + this.frame_ = this.adapter_.computeBoundingRect(); + var maxDim = Math.max(this.frame_.height, this.frame_.width); + // Surface diameter is treated differently for unbounded vs. bounded ripples. + // Unbounded ripple diameter is calculated smaller since the surface is expected to already be padded appropriately + // to extend the hitbox, and the ripple is expected to meet the edges of the padded hitbox (which is typically + // square). Bounded ripples, on the other hand, are fully expected to expand beyond the surface's longest diameter + // (calculated based on the diagonal plus a constant padding), and are clipped at the surface's border via + // `overflow: hidden`. + var getBoundedRadius = function () { + var hypotenuse = Math.sqrt(Math.pow(_this.frame_.width, 2) + Math.pow(_this.frame_.height, 2)); + return hypotenuse + MDCRippleFoundation.numbers.PADDING; + }; + this.maxRadius_ = this.adapter_.isUnbounded() ? maxDim : getBoundedRadius(); + // Ripple is sized as a fraction of the largest dimension of the surface, then scales up using a CSS scale transform + this.initialSize_ = Math.floor(maxDim * MDCRippleFoundation.numbers.INITIAL_ORIGIN_SCALE); + this.fgScale_ = "" + this.maxRadius_ / this.initialSize_; + this.updateLayoutCssVars_(); + }; + MDCRippleFoundation.prototype.updateLayoutCssVars_ = function () { + var _a = MDCRippleFoundation.strings, VAR_FG_SIZE = _a.VAR_FG_SIZE, VAR_LEFT = _a.VAR_LEFT, VAR_TOP = _a.VAR_TOP, VAR_FG_SCALE = _a.VAR_FG_SCALE; + this.adapter_.updateCssVariable(VAR_FG_SIZE, this.initialSize_ + "px"); + this.adapter_.updateCssVariable(VAR_FG_SCALE, this.fgScale_); + if (this.adapter_.isUnbounded()) { + this.unboundedCoords_ = { + left: Math.round((this.frame_.width / 2) - (this.initialSize_ / 2)), + top: Math.round((this.frame_.height / 2) - (this.initialSize_ / 2)), + }; + this.adapter_.updateCssVariable(VAR_LEFT, this.unboundedCoords_.left + "px"); + this.adapter_.updateCssVariable(VAR_TOP, this.unboundedCoords_.top + "px"); + } + }; + return MDCRippleFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCRippleFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/index.js": +/*!************************************************!*\ + !*** ./node_modules/@material/ripple/index.js ***! + \************************************************/ +/*! exports provided: util, MDCRipple, cssClasses, strings, numbers, MDCRippleFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _util__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./util */ "./node_modules/@material/ripple/util.js"); +/* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "util", function() { return _util__WEBPACK_IMPORTED_MODULE_0__; }); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./component */ "./node_modules/@material/ripple/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCRipple", function() { return _component__WEBPACK_IMPORTED_MODULE_1__["MDCRipple"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/ripple/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/ripple/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCRippleFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_3__["MDCRippleFoundation"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/ripple/util.js": +/*!***********************************************!*\ + !*** ./node_modules/@material/ripple/util.js ***! + \***********************************************/ +/*! exports provided: supportsCssVariables, getNormalizedEventCoords */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "supportsCssVariables", function() { return supportsCssVariables; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getNormalizedEventCoords", function() { return getNormalizedEventCoords; }); +/** + * Stores result from supportsCssVariables to avoid redundant processing to + * detect CSS custom variable support. + */ +var supportsCssVariables_; +function detectEdgePseudoVarBug(windowObj) { + // Detect versions of Edge with buggy var() support + // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/11495448/ + var document = windowObj.document; + var node = document.createElement('div'); + node.className = 'mdc-ripple-surface--test-edge-var-bug'; + // Append to head instead of body because this script might be invoked in the + // head, in which case the body doesn't exist yet. The probe works either way. + document.head.appendChild(node); + // The bug exists if ::before style ends up propagating to the parent element. + // Additionally, getComputedStyle returns null in iframes with display: "none" in Firefox, + // but Firefox is known to support CSS custom properties correctly. + // See: https://bugzilla.mozilla.org/show_bug.cgi?id=548397 + var computedStyle = windowObj.getComputedStyle(node); + var hasPseudoVarBug = computedStyle !== null && computedStyle.borderTopStyle === 'solid'; + if (node.parentNode) { + node.parentNode.removeChild(node); + } + return hasPseudoVarBug; +} +function supportsCssVariables(windowObj, forceRefresh) { + if (forceRefresh === void 0) { forceRefresh = false; } + var CSS = windowObj.CSS; + var supportsCssVars = supportsCssVariables_; + if (typeof supportsCssVariables_ === 'boolean' && !forceRefresh) { + return supportsCssVariables_; + } + var supportsFunctionPresent = CSS && typeof CSS.supports === 'function'; + if (!supportsFunctionPresent) { + return false; + } + var explicitlySupportsCssVars = CSS.supports('--css-vars', 'yes'); + // See: https://bugs.webkit.org/show_bug.cgi?id=154669 + // See: README section on Safari + var weAreFeatureDetectingSafari10plus = (CSS.supports('(--css-vars: yes)') && + CSS.supports('color', '#00000000')); + if (explicitlySupportsCssVars || weAreFeatureDetectingSafari10plus) { + supportsCssVars = !detectEdgePseudoVarBug(windowObj); + } + else { + supportsCssVars = false; + } + if (!forceRefresh) { + supportsCssVariables_ = supportsCssVars; + } + return supportsCssVars; +} +function getNormalizedEventCoords(evt, pageOffset, clientRect) { + if (!evt) { + return { x: 0, y: 0 }; + } + var x = pageOffset.x, y = pageOffset.y; + var documentX = x + clientRect.left; + var documentY = y + clientRect.top; + var normalizedX; + var normalizedY; + // Determine touch point relative to the ripple container. + if (evt.type === 'touchstart') { + var touchEvent = evt; + normalizedX = touchEvent.changedTouches[0].pageX - documentX; + normalizedY = touchEvent.changedTouches[0].pageY - documentY; + } + else { + var mouseEvent = evt; + normalizedX = mouseEvent.pageX - documentX; + normalizedY = mouseEvent.pageY - documentY; + } + return { x: normalizedX, y: normalizedY }; +} +//# sourceMappingURL=util.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/component.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/component.js ***! + \*************************************************************************/ +/*! exports provided: MDCTextFieldCharacterCounter */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounter", function() { return MDCTextFieldCharacterCounter; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/character-counter/foundation.js"); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldCharacterCounter = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldCharacterCounter, _super); + function MDCTextFieldCharacterCounter() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextFieldCharacterCounter.attachTo = function (root) { + return new MDCTextFieldCharacterCounter(root); + }; + Object.defineProperty(MDCTextFieldCharacterCounter.prototype, "foundation", { + get: function () { + return this.foundation_; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldCharacterCounter.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + var adapter = { + setContent: function (content) { + _this.root_.textContent = content; + }, + }; + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldCharacterCounterFoundation"](adapter); + }; + return MDCTextFieldCharacterCounter; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/constants.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/constants.js ***! + \*************************************************************************/ +/*! exports provided: strings, cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + ROOT: 'mdc-text-field-character-counter', +}; +var strings = { + ROOT_SELECTOR: "." + cssClasses.ROOT, +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/foundation.js": +/*!**************************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/foundation.js ***! + \**************************************************************************/ +/*! exports provided: MDCTextFieldCharacterCounterFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounterFoundation", function() { return MDCTextFieldCharacterCounterFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/character-counter/constants.js"); +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldCharacterCounterFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldCharacterCounterFoundation, _super); + function MDCTextFieldCharacterCounterFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldCharacterCounterFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCTextFieldCharacterCounterFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldCharacterCounterFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldCharacterCounterFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldCharacterCounterAdapter} for typing information on parameters and return types. + */ + get: function () { + return { + setContent: function () { return undefined; }, + }; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldCharacterCounterFoundation.prototype.setCounterValue = function (currentLength, maxLength) { + currentLength = Math.min(currentLength, maxLength); + this.adapter_.setContent(currentLength + " / " + maxLength); + }; + return MDCTextFieldCharacterCounterFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldCharacterCounterFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/character-counter/index.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@material/textfield/character-counter/index.js ***! + \*********************************************************************/ +/*! exports provided: characterCountCssClasses, characterCountStrings, MDCTextFieldCharacterCounter, MDCTextFieldCharacterCounterFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/character-counter/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounter", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextFieldCharacterCounter"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/character-counter/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounterFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCTextFieldCharacterCounterFoundation"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/character-counter/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountCssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountStrings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/component.js": +/*!*******************************************************!*\ + !*** ./node_modules/@material/textfield/component.js ***! + \*******************************************************/ +/*! exports provided: MDCTextField */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextField", function() { return MDCTextField; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_dom_events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/dom/events */ "./node_modules/@material/dom/events.js"); +/* harmony import */ var _material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @material/dom/ponyfill */ "./node_modules/@material/dom/ponyfill.js"); +/* harmony import */ var _material_floating_label_component__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @material/floating-label/component */ "./node_modules/@material/floating-label/component.js"); +/* harmony import */ var _material_line_ripple_component__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! @material/line-ripple/component */ "./node_modules/@material/line-ripple/component.js"); +/* harmony import */ var _material_notched_outline_component__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! @material/notched-outline/component */ "./node_modules/@material/notched-outline/component.js"); +/* harmony import */ var _material_ripple_component__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! @material/ripple/component */ "./node_modules/@material/ripple/component.js"); +/* harmony import */ var _material_ripple_foundation__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! @material/ripple/foundation */ "./node_modules/@material/ripple/foundation.js"); +/* harmony import */ var _character_counter_component__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./character-counter/component */ "./node_modules/@material/textfield/character-counter/component.js"); +/* harmony import */ var _character_counter_foundation__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./character-counter/foundation */ "./node_modules/@material/textfield/character-counter/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/foundation.js"); +/* harmony import */ var _helper_text_component__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./helper-text/component */ "./node_modules/@material/textfield/helper-text/component.js"); +/* harmony import */ var _helper_text_foundation__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./helper-text/foundation */ "./node_modules/@material/textfield/helper-text/foundation.js"); +/* harmony import */ var _icon_component__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./icon/component */ "./node_modules/@material/textfield/icon/component.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + + + + + + + + + + + +var MDCTextField = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextField, _super); + function MDCTextField() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextField.attachTo = function (root) { + return new MDCTextField(root); + }; + MDCTextField.prototype.initialize = function (rippleFactory, lineRippleFactory, helperTextFactory, characterCounterFactory, iconFactory, labelFactory, outlineFactory) { + if (rippleFactory === void 0) { rippleFactory = function (el, foundation) { return new _material_ripple_component__WEBPACK_IMPORTED_MODULE_7__["MDCRipple"](el, foundation); }; } + if (lineRippleFactory === void 0) { lineRippleFactory = function (el) { return new _material_line_ripple_component__WEBPACK_IMPORTED_MODULE_5__["MDCLineRipple"](el); }; } + if (helperTextFactory === void 0) { helperTextFactory = function (el) { return new _helper_text_component__WEBPACK_IMPORTED_MODULE_13__["MDCTextFieldHelperText"](el); }; } + if (characterCounterFactory === void 0) { characterCounterFactory = function (el) { return new _character_counter_component__WEBPACK_IMPORTED_MODULE_9__["MDCTextFieldCharacterCounter"](el); }; } + if (iconFactory === void 0) { iconFactory = function (el) { return new _icon_component__WEBPACK_IMPORTED_MODULE_15__["MDCTextFieldIcon"](el); }; } + if (labelFactory === void 0) { labelFactory = function (el) { return new _material_floating_label_component__WEBPACK_IMPORTED_MODULE_4__["MDCFloatingLabel"](el); }; } + if (outlineFactory === void 0) { outlineFactory = function (el) { return new _material_notched_outline_component__WEBPACK_IMPORTED_MODULE_6__["MDCNotchedOutline"](el); }; } + this.input_ = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].INPUT_SELECTOR); + var labelElement = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].LABEL_SELECTOR); + this.label_ = labelElement ? labelFactory(labelElement) : null; + var lineRippleElement = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].LINE_RIPPLE_SELECTOR); + this.lineRipple_ = lineRippleElement ? lineRippleFactory(lineRippleElement) : null; + var outlineElement = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].OUTLINE_SELECTOR); + this.outline_ = outlineElement ? outlineFactory(outlineElement) : null; + // Helper text + var helperTextStrings = _helper_text_foundation__WEBPACK_IMPORTED_MODULE_14__["MDCTextFieldHelperTextFoundation"].strings; + var nextElementSibling = this.root_.nextElementSibling; + var hasHelperLine = (nextElementSibling && nextElementSibling.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].HELPER_LINE)); + var helperTextEl = hasHelperLine && nextElementSibling && nextElementSibling.querySelector(helperTextStrings.ROOT_SELECTOR); + this.helperText_ = helperTextEl ? helperTextFactory(helperTextEl) : null; + // Character counter + var characterCounterStrings = _character_counter_foundation__WEBPACK_IMPORTED_MODULE_10__["MDCTextFieldCharacterCounterFoundation"].strings; + var characterCounterEl = this.root_.querySelector(characterCounterStrings.ROOT_SELECTOR); + // If character counter is not found in root element search in sibling element. + if (!characterCounterEl && hasHelperLine && nextElementSibling) { + characterCounterEl = nextElementSibling.querySelector(characterCounterStrings.ROOT_SELECTOR); + } + this.characterCounter_ = characterCounterEl ? characterCounterFactory(characterCounterEl) : null; + this.leadingIcon_ = null; + this.trailingIcon_ = null; + var iconElements = this.root_.querySelectorAll(_constants__WEBPACK_IMPORTED_MODULE_11__["strings"].ICON_SELECTOR); + if (iconElements.length > 0) { + if (iconElements.length > 1) { // Has both icons. + this.leadingIcon_ = iconFactory(iconElements[0]); + this.trailingIcon_ = iconFactory(iconElements[1]); + } + else { + if (this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].WITH_LEADING_ICON)) { + this.leadingIcon_ = iconFactory(iconElements[0]); + } + else { + this.trailingIcon_ = iconFactory(iconElements[0]); + } + } + } + this.ripple = this.createRipple_(rippleFactory); + }; + MDCTextField.prototype.destroy = function () { + if (this.ripple) { + this.ripple.destroy(); + } + if (this.lineRipple_) { + this.lineRipple_.destroy(); + } + if (this.helperText_) { + this.helperText_.destroy(); + } + if (this.characterCounter_) { + this.characterCounter_.destroy(); + } + if (this.leadingIcon_) { + this.leadingIcon_.destroy(); + } + if (this.trailingIcon_) { + this.trailingIcon_.destroy(); + } + if (this.label_) { + this.label_.destroy(); + } + if (this.outline_) { + this.outline_.destroy(); + } + _super.prototype.destroy.call(this); + }; + /** + * Initializes the Text Field's internal state based on the environment's + * state. + */ + MDCTextField.prototype.initialSyncWithDOM = function () { + this.disabled = this.input_.disabled; + }; + Object.defineProperty(MDCTextField.prototype, "value", { + get: function () { + return this.foundation_.getValue(); + }, + /** + * @param value The value to set on the input. + */ + set: function (value) { + this.foundation_.setValue(value); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "disabled", { + get: function () { + return this.foundation_.isDisabled(); + }, + /** + * @param disabled Sets the Text Field disabled or enabled. + */ + set: function (disabled) { + this.foundation_.setDisabled(disabled); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "valid", { + get: function () { + return this.foundation_.isValid(); + }, + /** + * @param valid Sets the Text Field valid or invalid. + */ + set: function (valid) { + this.foundation_.setValid(valid); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "required", { + get: function () { + return this.input_.required; + }, + /** + * @param required Sets the Text Field to required. + */ + set: function (required) { + this.input_.required = required; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "pattern", { + get: function () { + return this.input_.pattern; + }, + /** + * @param pattern Sets the input element's validation pattern. + */ + set: function (pattern) { + this.input_.pattern = pattern; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "minLength", { + get: function () { + return this.input_.minLength; + }, + /** + * @param minLength Sets the input element's minLength. + */ + set: function (minLength) { + this.input_.minLength = minLength; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "maxLength", { + get: function () { + return this.input_.maxLength; + }, + /** + * @param maxLength Sets the input element's maxLength. + */ + set: function (maxLength) { + // Chrome throws exception if maxLength is set to a value less than zero + if (maxLength < 0) { + this.input_.removeAttribute('maxLength'); + } + else { + this.input_.maxLength = maxLength; + } + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "min", { + get: function () { + return this.input_.min; + }, + /** + * @param min Sets the input element's min. + */ + set: function (min) { + this.input_.min = min; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "max", { + get: function () { + return this.input_.max; + }, + /** + * @param max Sets the input element's max. + */ + set: function (max) { + this.input_.max = max; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "step", { + get: function () { + return this.input_.step; + }, + /** + * @param step Sets the input element's step. + */ + set: function (step) { + this.input_.step = step; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "helperTextContent", { + /** + * Sets the helper text element content. + */ + set: function (content) { + this.foundation_.setHelperTextContent(content); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "leadingIconAriaLabel", { + /** + * Sets the aria label of the leading icon. + */ + set: function (label) { + this.foundation_.setLeadingIconAriaLabel(label); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "leadingIconContent", { + /** + * Sets the text content of the leading icon. + */ + set: function (content) { + this.foundation_.setLeadingIconContent(content); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "trailingIconAriaLabel", { + /** + * Sets the aria label of the trailing icon. + */ + set: function (label) { + this.foundation_.setTrailingIconAriaLabel(label); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "trailingIconContent", { + /** + * Sets the text content of the trailing icon. + */ + set: function (content) { + this.foundation_.setTrailingIconContent(content); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextField.prototype, "useNativeValidation", { + /** + * Enables or disables the use of native validation. Use this for custom validation. + * @param useNativeValidation Set this to false to ignore native input validation. + */ + set: function (useNativeValidation) { + this.foundation_.setUseNativeValidation(useNativeValidation); + }, + enumerable: true, + configurable: true + }); + /** + * Focuses the input element. + */ + MDCTextField.prototype.focus = function () { + this.input_.focus(); + }; + /** + * Recomputes the outline SVG path for the outline element. + */ + MDCTextField.prototype.layout = function () { + var openNotch = this.foundation_.shouldFloat; + this.foundation_.notchOutline(openNotch); + }; + MDCTextField.prototype.getDefaultFoundation = function () { + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, this.getRootAdapterMethods_(), this.getInputAdapterMethods_(), this.getLabelAdapterMethods_(), this.getLineRippleAdapterMethods_(), this.getOutlineAdapterMethods_()); + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_12__["MDCTextFieldFoundation"](adapter, this.getFoundationMap_()); + }; + MDCTextField.prototype.getRootAdapterMethods_ = function () { + var _this = this; + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + hasClass: function (className) { return _this.root_.classList.contains(className); }, + registerTextFieldInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterTextFieldInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + registerValidationAttributeChangeHandler: function (handler) { + var getAttributesList = function (mutationsList) { + return mutationsList + .map(function (mutation) { return mutation.attributeName; }) + .filter(function (attributeName) { return attributeName; }); + }; + var observer = new MutationObserver(function (mutationsList) { return handler(getAttributesList(mutationsList)); }); + var config = { attributes: true }; + observer.observe(_this.input_, config); + return observer; + }, + deregisterValidationAttributeChangeHandler: function (observer) { return observer.disconnect(); }, + }; + // tslint:enable:object-literal-sort-keys + }; + MDCTextField.prototype.getInputAdapterMethods_ = function () { + var _this = this; + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + getNativeInput: function () { return _this.input_; }, + isFocused: function () { return document.activeElement === _this.input_; }, + registerInputInteractionHandler: function (evtType, handler) { + return _this.input_.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + deregisterInputInteractionHandler: function (evtType, handler) { + return _this.input_.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + }, + }; + // tslint:enable:object-literal-sort-keys + }; + MDCTextField.prototype.getLabelAdapterMethods_ = function () { + var _this = this; + return { + floatLabel: function (shouldFloat) { return _this.label_ && _this.label_.float(shouldFloat); }, + getLabelWidth: function () { return _this.label_ ? _this.label_.getWidth() : 0; }, + hasLabel: function () { return Boolean(_this.label_); }, + shakeLabel: function (shouldShake) { return _this.label_ && _this.label_.shake(shouldShake); }, + }; + }; + MDCTextField.prototype.getLineRippleAdapterMethods_ = function () { + var _this = this; + return { + activateLineRipple: function () { + if (_this.lineRipple_) { + _this.lineRipple_.activate(); + } + }, + deactivateLineRipple: function () { + if (_this.lineRipple_) { + _this.lineRipple_.deactivate(); + } + }, + setLineRippleTransformOrigin: function (normalizedX) { + if (_this.lineRipple_) { + _this.lineRipple_.setRippleCenter(normalizedX); + } + }, + }; + }; + MDCTextField.prototype.getOutlineAdapterMethods_ = function () { + var _this = this; + return { + closeOutline: function () { return _this.outline_ && _this.outline_.closeNotch(); }, + hasOutline: function () { return Boolean(_this.outline_); }, + notchOutline: function (labelWidth) { return _this.outline_ && _this.outline_.notch(labelWidth); }, + }; + }; + /** + * @return A map of all subcomponents to subfoundations. + */ + MDCTextField.prototype.getFoundationMap_ = function () { + return { + characterCounter: this.characterCounter_ ? this.characterCounter_.foundation : undefined, + helperText: this.helperText_ ? this.helperText_.foundation : undefined, + leadingIcon: this.leadingIcon_ ? this.leadingIcon_.foundation : undefined, + trailingIcon: this.trailingIcon_ ? this.trailingIcon_.foundation : undefined, + }; + }; + MDCTextField.prototype.createRipple_ = function (rippleFactory) { + var _this = this; + var isTextArea = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].TEXTAREA); + var isOutlined = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_11__["cssClasses"].OUTLINED); + if (isTextArea || isOutlined) { + return null; + } + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, _material_ripple_component__WEBPACK_IMPORTED_MODULE_7__["MDCRipple"].createAdapter(this), { isSurfaceActive: function () { return _material_dom_ponyfill__WEBPACK_IMPORTED_MODULE_3__["matches"](_this.input_, ':active'); }, registerInteractionHandler: function (evtType, handler) { return _this.input_.addEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); }, deregisterInteractionHandler: function (evtType, handler) { + return _this.input_.removeEventListener(evtType, handler, Object(_material_dom_events__WEBPACK_IMPORTED_MODULE_2__["applyPassive"])()); + } }); + // tslint:enable:object-literal-sort-keys + return rippleFactory(this.root_, new _material_ripple_foundation__WEBPACK_IMPORTED_MODULE_8__["MDCRippleFoundation"](adapter)); + }; + return MDCTextField; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/constants.js": +/*!*******************************************************!*\ + !*** ./node_modules/@material/textfield/constants.js ***! + \*******************************************************/ +/*! exports provided: cssClasses, strings, numbers, VALIDATION_ATTR_WHITELIST, ALWAYS_FLOAT_TYPES */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VALIDATION_ATTR_WHITELIST", function() { return VALIDATION_ATTR_WHITELIST; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ALWAYS_FLOAT_TYPES", function() { return ALWAYS_FLOAT_TYPES; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var strings = { + ARIA_CONTROLS: 'aria-controls', + ICON_SELECTOR: '.mdc-text-field__icon', + INPUT_SELECTOR: '.mdc-text-field__input', + LABEL_SELECTOR: '.mdc-floating-label', + LINE_RIPPLE_SELECTOR: '.mdc-line-ripple', + OUTLINE_SELECTOR: '.mdc-notched-outline', +}; +var cssClasses = { + DENSE: 'mdc-text-field--dense', + DISABLED: 'mdc-text-field--disabled', + FOCUSED: 'mdc-text-field--focused', + FULLWIDTH: 'mdc-text-field--fullwidth', + HELPER_LINE: 'mdc-text-field-helper-line', + INVALID: 'mdc-text-field--invalid', + NO_LABEL: 'mdc-text-field--no-label', + OUTLINED: 'mdc-text-field--outlined', + ROOT: 'mdc-text-field', + TEXTAREA: 'mdc-text-field--textarea', + WITH_LEADING_ICON: 'mdc-text-field--with-leading-icon', + WITH_TRAILING_ICON: 'mdc-text-field--with-trailing-icon', +}; +var numbers = { + DENSE_LABEL_SCALE: 0.923, + LABEL_SCALE: 0.75, +}; +/** + * Whitelist based off of https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/HTML5/Constraint_validation + * under the "Validation-related attributes" section. + */ +var VALIDATION_ATTR_WHITELIST = [ + 'pattern', 'min', 'max', 'required', 'step', 'minlength', 'maxlength', +]; +/** + * Label should always float for these types as they show some UI even if value is empty. + */ +var ALWAYS_FLOAT_TYPES = [ + 'color', 'date', 'datetime-local', 'month', 'range', 'time', 'week', +]; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/foundation.js": +/*!********************************************************!*\ + !*** ./node_modules/@material/textfield/foundation.js ***! + \********************************************************/ +/*! exports provided: MDCTextFieldFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldFoundation", function() { return MDCTextFieldFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/constants.js"); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var POINTERDOWN_EVENTS = ['mousedown', 'touchstart']; +var INTERACTION_EVENTS = ['click', 'keydown']; +var MDCTextFieldFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldFoundation, _super); + /** + * @param adapter + * @param foundationMap Map from subcomponent names to their subfoundations. + */ + function MDCTextFieldFoundation(adapter, foundationMap) { + if (foundationMap === void 0) { foundationMap = {}; } + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldFoundation.defaultAdapter, adapter)) || this; + _this.isFocused_ = false; + _this.receivedUserInput_ = false; + _this.isValid_ = true; + _this.useNativeValidation_ = true; + _this.helperText_ = foundationMap.helperText; + _this.characterCounter_ = foundationMap.characterCounter; + _this.leadingIcon_ = foundationMap.leadingIcon; + _this.trailingIcon_ = foundationMap.trailingIcon; + _this.inputFocusHandler_ = function () { return _this.activateFocus(); }; + _this.inputBlurHandler_ = function () { return _this.deactivateFocus(); }; + _this.inputInputHandler_ = function () { return _this.handleInput(); }; + _this.setPointerXOffset_ = function (evt) { return _this.setTransformOrigin(evt); }; + _this.textFieldInteractionHandler_ = function () { return _this.handleTextFieldInteraction(); }; + _this.validationAttributeChangeHandler_ = function (attributesList) { return _this.handleValidationAttributeChange(attributesList); }; + return _this; + } + Object.defineProperty(MDCTextFieldFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation.prototype, "shouldAlwaysFloat_", { + get: function () { + var type = this.getNativeInput_().type; + return _constants__WEBPACK_IMPORTED_MODULE_2__["ALWAYS_FLOAT_TYPES"].indexOf(type) >= 0; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation.prototype, "shouldFloat", { + get: function () { + return this.shouldAlwaysFloat_ || this.isFocused_ || Boolean(this.getValue()) || this.isBadInput_(); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation.prototype, "shouldShake", { + get: function () { + return !this.isFocused_ && !this.isValid() && Boolean(this.getValue()); + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return true; }, + registerTextFieldInteractionHandler: function () { return undefined; }, + deregisterTextFieldInteractionHandler: function () { return undefined; }, + registerInputInteractionHandler: function () { return undefined; }, + deregisterInputInteractionHandler: function () { return undefined; }, + registerValidationAttributeChangeHandler: function () { return new MutationObserver(function () { return undefined; }); }, + deregisterValidationAttributeChangeHandler: function () { return undefined; }, + getNativeInput: function () { return null; }, + isFocused: function () { return false; }, + activateLineRipple: function () { return undefined; }, + deactivateLineRipple: function () { return undefined; }, + setLineRippleTransformOrigin: function () { return undefined; }, + shakeLabel: function () { return undefined; }, + floatLabel: function () { return undefined; }, + hasLabel: function () { return false; }, + getLabelWidth: function () { return 0; }, + hasOutline: function () { return false; }, + notchOutline: function () { return undefined; }, + closeOutline: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCTextFieldFoundation.prototype.init = function () { + var _this = this; + if (this.adapter_.isFocused()) { + this.inputFocusHandler_(); + } + else if (this.adapter_.hasLabel() && this.shouldFloat) { + this.notchOutline(true); + this.adapter_.floatLabel(true); + } + this.adapter_.registerInputInteractionHandler('focus', this.inputFocusHandler_); + this.adapter_.registerInputInteractionHandler('blur', this.inputBlurHandler_); + this.adapter_.registerInputInteractionHandler('input', this.inputInputHandler_); + POINTERDOWN_EVENTS.forEach(function (evtType) { + _this.adapter_.registerInputInteractionHandler(evtType, _this.setPointerXOffset_); + }); + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.registerTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_); + }); + this.validationObserver_ = + this.adapter_.registerValidationAttributeChangeHandler(this.validationAttributeChangeHandler_); + this.setCharacterCounter_(this.getValue().length); + }; + MDCTextFieldFoundation.prototype.destroy = function () { + var _this = this; + this.adapter_.deregisterInputInteractionHandler('focus', this.inputFocusHandler_); + this.adapter_.deregisterInputInteractionHandler('blur', this.inputBlurHandler_); + this.adapter_.deregisterInputInteractionHandler('input', this.inputInputHandler_); + POINTERDOWN_EVENTS.forEach(function (evtType) { + _this.adapter_.deregisterInputInteractionHandler(evtType, _this.setPointerXOffset_); + }); + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.deregisterTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_); + }); + this.adapter_.deregisterValidationAttributeChangeHandler(this.validationObserver_); + }; + /** + * Handles user interactions with the Text Field. + */ + MDCTextFieldFoundation.prototype.handleTextFieldInteraction = function () { + var nativeInput = this.adapter_.getNativeInput(); + if (nativeInput && nativeInput.disabled) { + return; + } + this.receivedUserInput_ = true; + }; + /** + * Handles validation attribute changes + */ + MDCTextFieldFoundation.prototype.handleValidationAttributeChange = function (attributesList) { + var _this = this; + attributesList.some(function (attributeName) { + if (_constants__WEBPACK_IMPORTED_MODULE_2__["VALIDATION_ATTR_WHITELIST"].indexOf(attributeName) > -1) { + _this.styleValidity_(true); + return true; + } + return false; + }); + if (attributesList.indexOf('maxlength') > -1) { + this.setCharacterCounter_(this.getValue().length); + } + }; + /** + * Opens/closes the notched outline. + */ + MDCTextFieldFoundation.prototype.notchOutline = function (openNotch) { + if (!this.adapter_.hasOutline()) { + return; + } + if (openNotch) { + var isDense = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].DENSE); + var labelScale = isDense ? _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].DENSE_LABEL_SCALE : _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"].LABEL_SCALE; + var labelWidth = this.adapter_.getLabelWidth() * labelScale; + this.adapter_.notchOutline(labelWidth); + } + else { + this.adapter_.closeOutline(); + } + }; + /** + * Activates the text field focus state. + */ + MDCTextFieldFoundation.prototype.activateFocus = function () { + this.isFocused_ = true; + this.styleFocused_(this.isFocused_); + this.adapter_.activateLineRipple(); + if (this.adapter_.hasLabel()) { + this.notchOutline(this.shouldFloat); + this.adapter_.floatLabel(this.shouldFloat); + this.adapter_.shakeLabel(this.shouldShake); + } + if (this.helperText_) { + this.helperText_.showToScreenReader(); + } + }; + /** + * Sets the line ripple's transform origin, so that the line ripple activate + * animation will animate out from the user's click location. + */ + MDCTextFieldFoundation.prototype.setTransformOrigin = function (evt) { + var touches = evt.touches; + var targetEvent = touches ? touches[0] : evt; + var targetClientRect = targetEvent.target.getBoundingClientRect(); + var normalizedX = targetEvent.clientX - targetClientRect.left; + this.adapter_.setLineRippleTransformOrigin(normalizedX); + }; + /** + * Handles input change of text input and text area. + */ + MDCTextFieldFoundation.prototype.handleInput = function () { + this.autoCompleteFocus(); + this.setCharacterCounter_(this.getValue().length); + }; + /** + * Activates the Text Field's focus state in cases when the input value + * changes without user input (e.g. programmatically). + */ + MDCTextFieldFoundation.prototype.autoCompleteFocus = function () { + if (!this.receivedUserInput_) { + this.activateFocus(); + } + }; + /** + * Deactivates the Text Field's focus state. + */ + MDCTextFieldFoundation.prototype.deactivateFocus = function () { + this.isFocused_ = false; + this.adapter_.deactivateLineRipple(); + var isValid = this.isValid(); + this.styleValidity_(isValid); + this.styleFocused_(this.isFocused_); + if (this.adapter_.hasLabel()) { + this.notchOutline(this.shouldFloat); + this.adapter_.floatLabel(this.shouldFloat); + this.adapter_.shakeLabel(this.shouldShake); + } + if (!this.shouldFloat) { + this.receivedUserInput_ = false; + } + }; + MDCTextFieldFoundation.prototype.getValue = function () { + return this.getNativeInput_().value; + }; + /** + * @param value The value to set on the input Element. + */ + MDCTextFieldFoundation.prototype.setValue = function (value) { + // Prevent Safari from moving the caret to the end of the input when the value has not changed. + if (this.getValue() !== value) { + this.getNativeInput_().value = value; + } + this.setCharacterCounter_(value.length); + var isValid = this.isValid(); + this.styleValidity_(isValid); + if (this.adapter_.hasLabel()) { + this.notchOutline(this.shouldFloat); + this.adapter_.floatLabel(this.shouldFloat); + this.adapter_.shakeLabel(this.shouldShake); + } + }; + /** + * @return The custom validity state, if set; otherwise, the result of a native validity check. + */ + MDCTextFieldFoundation.prototype.isValid = function () { + return this.useNativeValidation_ + ? this.isNativeInputValid_() : this.isValid_; + }; + /** + * @param isValid Sets the custom validity state of the Text Field. + */ + MDCTextFieldFoundation.prototype.setValid = function (isValid) { + this.isValid_ = isValid; + this.styleValidity_(isValid); + var shouldShake = !isValid && !this.isFocused_; + if (this.adapter_.hasLabel()) { + this.adapter_.shakeLabel(shouldShake); + } + }; + /** + * Enables or disables the use of native validation. Use this for custom validation. + * @param useNativeValidation Set this to false to ignore native input validation. + */ + MDCTextFieldFoundation.prototype.setUseNativeValidation = function (useNativeValidation) { + this.useNativeValidation_ = useNativeValidation; + }; + MDCTextFieldFoundation.prototype.isDisabled = function () { + return this.getNativeInput_().disabled; + }; + /** + * @param disabled Sets the text-field disabled or enabled. + */ + MDCTextFieldFoundation.prototype.setDisabled = function (disabled) { + this.getNativeInput_().disabled = disabled; + this.styleDisabled_(disabled); + }; + /** + * @param content Sets the content of the helper text. + */ + MDCTextFieldFoundation.prototype.setHelperTextContent = function (content) { + if (this.helperText_) { + this.helperText_.setContent(content); + } + }; + /** + * Sets the aria label of the leading icon. + */ + MDCTextFieldFoundation.prototype.setLeadingIconAriaLabel = function (label) { + if (this.leadingIcon_) { + this.leadingIcon_.setAriaLabel(label); + } + }; + /** + * Sets the text content of the leading icon. + */ + MDCTextFieldFoundation.prototype.setLeadingIconContent = function (content) { + if (this.leadingIcon_) { + this.leadingIcon_.setContent(content); + } + }; + /** + * Sets the aria label of the trailing icon. + */ + MDCTextFieldFoundation.prototype.setTrailingIconAriaLabel = function (label) { + if (this.trailingIcon_) { + this.trailingIcon_.setAriaLabel(label); + } + }; + /** + * Sets the text content of the trailing icon. + */ + MDCTextFieldFoundation.prototype.setTrailingIconContent = function (content) { + if (this.trailingIcon_) { + this.trailingIcon_.setContent(content); + } + }; + /** + * Sets character counter values that shows characters used and the total character limit. + */ + MDCTextFieldFoundation.prototype.setCharacterCounter_ = function (currentLength) { + if (!this.characterCounter_) { + return; + } + var maxLength = this.getNativeInput_().maxLength; + if (maxLength === -1) { + throw new Error('MDCTextFieldFoundation: Expected maxlength html property on text input or textarea.'); + } + this.characterCounter_.setCounterValue(currentLength, maxLength); + }; + /** + * @return True if the Text Field input fails in converting the user-supplied value. + */ + MDCTextFieldFoundation.prototype.isBadInput_ = function () { + // The badInput property is not supported in IE 11 💩. + return this.getNativeInput_().validity.badInput || false; + }; + /** + * @return The result of native validity checking (ValidityState.valid). + */ + MDCTextFieldFoundation.prototype.isNativeInputValid_ = function () { + return this.getNativeInput_().validity.valid; + }; + /** + * Styles the component based on the validity state. + */ + MDCTextFieldFoundation.prototype.styleValidity_ = function (isValid) { + var INVALID = MDCTextFieldFoundation.cssClasses.INVALID; + if (isValid) { + this.adapter_.removeClass(INVALID); + } + else { + this.adapter_.addClass(INVALID); + } + if (this.helperText_) { + this.helperText_.setValidity(isValid); + } + }; + /** + * Styles the component based on the focused state. + */ + MDCTextFieldFoundation.prototype.styleFocused_ = function (isFocused) { + var FOCUSED = MDCTextFieldFoundation.cssClasses.FOCUSED; + if (isFocused) { + this.adapter_.addClass(FOCUSED); + } + else { + this.adapter_.removeClass(FOCUSED); + } + }; + /** + * Styles the component based on the disabled state. + */ + MDCTextFieldFoundation.prototype.styleDisabled_ = function (isDisabled) { + var _a = MDCTextFieldFoundation.cssClasses, DISABLED = _a.DISABLED, INVALID = _a.INVALID; + if (isDisabled) { + this.adapter_.addClass(DISABLED); + this.adapter_.removeClass(INVALID); + } + else { + this.adapter_.removeClass(DISABLED); + } + if (this.leadingIcon_) { + this.leadingIcon_.setDisabled(isDisabled); + } + if (this.trailingIcon_) { + this.trailingIcon_.setDisabled(isDisabled); + } + }; + /** + * @return The native text input element from the host environment, or an object with the same shape for unit tests. + */ + MDCTextFieldFoundation.prototype.getNativeInput_ = function () { + // this.adapter_ may be undefined in foundation unit tests. This happens when testdouble is creating a mock object + // and invokes the shouldShake/shouldFloat getters (which in turn call getValue(), which calls this method) before + // init() has been called from the MDCTextField constructor. To work around that issue, we return a dummy object. + var nativeInput = this.adapter_ ? this.adapter_.getNativeInput() : null; + return nativeInput || { + disabled: false, + maxLength: -1, + type: 'input', + validity: { + badInput: false, + valid: true, + }, + value: '', + }; + }; + return MDCTextFieldFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/component.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/component.js ***! + \*******************************************************************/ +/*! exports provided: MDCTextFieldHelperText */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperText", function() { return MDCTextFieldHelperText; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/helper-text/foundation.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldHelperText = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldHelperText, _super); + function MDCTextFieldHelperText() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextFieldHelperText.attachTo = function (root) { + return new MDCTextFieldHelperText(root); + }; + Object.defineProperty(MDCTextFieldHelperText.prototype, "foundation", { + get: function () { + return this.foundation_; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldHelperText.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + hasClass: function (className) { return _this.root_.classList.contains(className); }, + setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); }, + removeAttr: function (attr) { return _this.root_.removeAttribute(attr); }, + setContent: function (content) { + _this.root_.textContent = content; + }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldHelperTextFoundation"](adapter); + }; + return MDCTextFieldHelperText; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/constants.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/constants.js ***! + \*******************************************************************/ +/*! exports provided: strings, cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + HELPER_TEXT_PERSISTENT: 'mdc-text-field-helper-text--persistent', + HELPER_TEXT_VALIDATION_MSG: 'mdc-text-field-helper-text--validation-msg', + ROOT: 'mdc-text-field-helper-text', +}; +var strings = { + ARIA_HIDDEN: 'aria-hidden', + ROLE: 'role', + ROOT_SELECTOR: "." + cssClasses.ROOT, +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/foundation.js": +/*!********************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/foundation.js ***! + \********************************************************************/ +/*! exports provided: MDCTextFieldHelperTextFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperTextFoundation", function() { return MDCTextFieldHelperTextFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/helper-text/constants.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldHelperTextFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldHelperTextFoundation, _super); + function MDCTextFieldHelperTextFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldHelperTextFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCTextFieldHelperTextFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldHelperTextFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldHelperTextFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldHelperTextAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return false; }, + setAttr: function () { return undefined; }, + removeAttr: function () { return undefined; }, + setContent: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + /** + * Sets the content of the helper text field. + */ + MDCTextFieldHelperTextFoundation.prototype.setContent = function (content) { + this.adapter_.setContent(content); + }; + /** + * @param isPersistent Sets the persistency of the helper text. + */ + MDCTextFieldHelperTextFoundation.prototype.setPersistent = function (isPersistent) { + if (isPersistent) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_PERSISTENT); + } + else { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_PERSISTENT); + } + }; + /** + * @param isValidation True to make the helper text act as an error validation message. + */ + MDCTextFieldHelperTextFoundation.prototype.setValidation = function (isValidation) { + if (isValidation) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_VALIDATION_MSG); + } + else { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_VALIDATION_MSG); + } + }; + /** + * Makes the helper text visible to the screen reader. + */ + MDCTextFieldHelperTextFoundation.prototype.showToScreenReader = function () { + this.adapter_.removeAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ARIA_HIDDEN); + }; + /** + * Sets the validity of the helper text based on the input validity. + */ + MDCTextFieldHelperTextFoundation.prototype.setValidity = function (inputIsValid) { + var helperTextIsPersistent = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_PERSISTENT); + var helperTextIsValidationMsg = this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"].HELPER_TEXT_VALIDATION_MSG); + var validationMsgNeedsDisplay = helperTextIsValidationMsg && !inputIsValid; + if (validationMsgNeedsDisplay) { + this.adapter_.setAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ROLE, 'alert'); + } + else { + this.adapter_.removeAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ROLE); + } + if (!helperTextIsPersistent && !validationMsgNeedsDisplay) { + this.hide_(); + } + }; + /** + * Hides the help text from screen readers. + */ + MDCTextFieldHelperTextFoundation.prototype.hide_ = function () { + this.adapter_.setAttr(_constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ARIA_HIDDEN, 'true'); + }; + return MDCTextFieldHelperTextFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldHelperTextFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/helper-text/index.js": +/*!***************************************************************!*\ + !*** ./node_modules/@material/textfield/helper-text/index.js ***! + \***************************************************************/ +/*! exports provided: helperTextCssClasses, helperTextStrings, MDCTextFieldHelperText, MDCTextFieldHelperTextFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/helper-text/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperText", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextFieldHelperText"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/helper-text/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperTextFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCTextFieldHelperTextFoundation"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/helper-text/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextCssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextStrings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/component.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/textfield/icon/component.js ***! + \************************************************************/ +/*! exports provided: MDCTextFieldIcon */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIcon", function() { return MDCTextFieldIcon; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/icon/foundation.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTextFieldIcon = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldIcon, _super); + function MDCTextFieldIcon() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTextFieldIcon.attachTo = function (root) { + return new MDCTextFieldIcon(root); + }; + Object.defineProperty(MDCTextFieldIcon.prototype, "foundation", { + get: function () { + return this.foundation_; + }, + enumerable: true, + configurable: true + }); + MDCTextFieldIcon.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + getAttr: function (attr) { return _this.root_.getAttribute(attr); }, + setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); }, + removeAttr: function (attr) { return _this.root_.removeAttribute(attr); }, + setContent: function (content) { + _this.root_.textContent = content; + }, + registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); }, + deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); }, + notifyIconAction: function () { return _this.emit(_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldIconFoundation"].strings.ICON_EVENT, {} /* evtData */, true /* shouldBubble */); }, + }; + // tslint:enable:object-literal-sort-keys + return new _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldIconFoundation"](adapter); + }; + return MDCTextFieldIcon; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/constants.js": +/*!************************************************************!*\ + !*** ./node_modules/@material/textfield/icon/constants.js ***! + \************************************************************/ +/*! exports provided: strings, cssClasses */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/** + * @license + * Copyright 2016 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var strings = { + ICON_EVENT: 'MDCTextField:icon', + ICON_ROLE: 'button', +}; +var cssClasses = { + ROOT: 'mdc-text-field__icon', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/foundation.js": +/*!*************************************************************!*\ + !*** ./node_modules/@material/textfield/icon/foundation.js ***! + \*************************************************************/ +/*! exports provided: MDCTextFieldIconFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIconFoundation", function() { return MDCTextFieldIconFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/icon/constants.js"); +/** + * @license + * Copyright 2017 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var INTERACTION_EVENTS = ['click', 'keydown']; +var MDCTextFieldIconFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTextFieldIconFoundation, _super); + function MDCTextFieldIconFoundation(adapter) { + var _this = _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTextFieldIconFoundation.defaultAdapter, adapter)) || this; + _this.savedTabIndex_ = null; + _this.interactionHandler_ = function (evt) { return _this.handleInteraction(evt); }; + return _this; + } + Object.defineProperty(MDCTextFieldIconFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldIconFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTextFieldIconFoundation, "defaultAdapter", { + /** + * See {@link MDCTextFieldIconAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + getAttr: function () { return null; }, + setAttr: function () { return undefined; }, + removeAttr: function () { return undefined; }, + setContent: function () { return undefined; }, + registerInteractionHandler: function () { return undefined; }, + deregisterInteractionHandler: function () { return undefined; }, + notifyIconAction: function () { return undefined; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + MDCTextFieldIconFoundation.prototype.init = function () { + var _this = this; + this.savedTabIndex_ = this.adapter_.getAttr('tabindex'); + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.registerInteractionHandler(evtType, _this.interactionHandler_); + }); + }; + MDCTextFieldIconFoundation.prototype.destroy = function () { + var _this = this; + INTERACTION_EVENTS.forEach(function (evtType) { + _this.adapter_.deregisterInteractionHandler(evtType, _this.interactionHandler_); + }); + }; + MDCTextFieldIconFoundation.prototype.setDisabled = function (disabled) { + if (!this.savedTabIndex_) { + return; + } + if (disabled) { + this.adapter_.setAttr('tabindex', '-1'); + this.adapter_.removeAttr('role'); + } + else { + this.adapter_.setAttr('tabindex', this.savedTabIndex_); + this.adapter_.setAttr('role', _constants__WEBPACK_IMPORTED_MODULE_2__["strings"].ICON_ROLE); + } + }; + MDCTextFieldIconFoundation.prototype.setAriaLabel = function (label) { + this.adapter_.setAttr('aria-label', label); + }; + MDCTextFieldIconFoundation.prototype.setContent = function (content) { + this.adapter_.setContent(content); + }; + MDCTextFieldIconFoundation.prototype.handleInteraction = function (evt) { + var isEnterKey = evt.key === 'Enter' || evt.keyCode === 13; + if (evt.type === 'click' || isEnterKey) { + this.adapter_.notifyIconAction(); + } + }; + return MDCTextFieldIconFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTextFieldIconFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/icon/index.js": +/*!********************************************************!*\ + !*** ./node_modules/@material/textfield/icon/index.js ***! + \********************************************************/ +/*! exports provided: iconCssClasses, iconStrings, MDCTextFieldIcon, MDCTextFieldIconFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/icon/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIcon", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextFieldIcon"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/icon/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIconFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_1__["MDCTextFieldIconFoundation"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/icon/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconCssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconStrings", function() { return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/textfield/index.js": +/*!***************************************************!*\ + !*** ./node_modules/@material/textfield/index.js ***! + \***************************************************/ +/*! exports provided: MDCTextField, cssClasses, strings, numbers, VALIDATION_ATTR_WHITELIST, ALWAYS_FLOAT_TYPES, MDCTextFieldFoundation, characterCountCssClasses, characterCountStrings, helperTextCssClasses, helperTextStrings, iconCssClasses, iconStrings, MDCTextFieldCharacterCounter, MDCTextFieldCharacterCounterFoundation, MDCTextFieldHelperText, MDCTextFieldHelperTextFoundation, MDCTextFieldIcon, MDCTextFieldIconFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/textfield/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextField", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTextField"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/textfield/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["strings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VALIDATION_ATTR_WHITELIST", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["VALIDATION_ATTR_WHITELIST"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ALWAYS_FLOAT_TYPES", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["ALWAYS_FLOAT_TYPES"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/textfield/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTextFieldFoundation"]; }); + +/* harmony import */ var _character_counter_index__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./character-counter/index */ "./node_modules/@material/textfield/character-counter/index.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountCssClasses", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["characterCountCssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "characterCountStrings", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["characterCountStrings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounter", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["MDCTextFieldCharacterCounter"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldCharacterCounterFoundation", function() { return _character_counter_index__WEBPACK_IMPORTED_MODULE_3__["MDCTextFieldCharacterCounterFoundation"]; }); + +/* harmony import */ var _helper_text_index__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./helper-text/index */ "./node_modules/@material/textfield/helper-text/index.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextCssClasses", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["helperTextCssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "helperTextStrings", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["helperTextStrings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperText", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["MDCTextFieldHelperText"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldHelperTextFoundation", function() { return _helper_text_index__WEBPACK_IMPORTED_MODULE_4__["MDCTextFieldHelperTextFoundation"]; }); + +/* harmony import */ var _icon_index__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./icon/index */ "./node_modules/@material/textfield/icon/index.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconCssClasses", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["iconCssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "iconStrings", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["iconStrings"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIcon", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["MDCTextFieldIcon"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTextFieldIconFoundation", function() { return _icon_index__WEBPACK_IMPORTED_MODULE_5__["MDCTextFieldIconFoundation"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/component.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/top-app-bar/component.js ***! + \*********************************************************/ +/*! exports provided: MDCTopAppBar */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBar", function() { return MDCTopAppBar; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/component */ "./node_modules/@material/base/component.js"); +/* harmony import */ var _material_ripple_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/ripple/component */ "./node_modules/@material/ripple/component.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _fixed_foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./fixed/foundation */ "./node_modules/@material/top-app-bar/fixed/foundation.js"); +/* harmony import */ var _short_foundation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./short/foundation */ "./node_modules/@material/top-app-bar/short/foundation.js"); +/* harmony import */ var _standard_foundation__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./standard/foundation */ "./node_modules/@material/top-app-bar/standard/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + + +var MDCTopAppBar = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTopAppBar, _super); + function MDCTopAppBar() { + return _super !== null && _super.apply(this, arguments) || this; + } + MDCTopAppBar.attachTo = function (root) { + return new MDCTopAppBar(root); + }; + MDCTopAppBar.prototype.initialize = function (rippleFactory) { + if (rippleFactory === void 0) { rippleFactory = function (el) { return _material_ripple_component__WEBPACK_IMPORTED_MODULE_2__["MDCRipple"].attachTo(el); }; } + this.navIcon_ = this.root_.querySelector(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].NAVIGATION_ICON_SELECTOR); + // Get all icons in the toolbar and instantiate the ripples + var icons = [].slice.call(this.root_.querySelectorAll(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].ACTION_ITEM_SELECTOR)); + if (this.navIcon_) { + icons.push(this.navIcon_); + } + this.iconRipples_ = icons.map(function (icon) { + var ripple = rippleFactory(icon); + ripple.unbounded = true; + return ripple; + }); + this.scrollTarget_ = window; + }; + MDCTopAppBar.prototype.initialSyncWithDOM = function () { + this.handleNavigationClick_ = this.foundation_.handleNavigationClick.bind(this.foundation_); + this.handleWindowResize_ = this.foundation_.handleWindowResize.bind(this.foundation_); + this.handleTargetScroll_ = this.foundation_.handleTargetScroll.bind(this.foundation_); + this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_); + if (this.navIcon_) { + this.navIcon_.addEventListener('click', this.handleNavigationClick_); + } + var isFixed = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].FIXED_CLASS); + var isShort = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].SHORT_CLASS); + if (!isShort && !isFixed) { + window.addEventListener('resize', this.handleWindowResize_); + } + }; + MDCTopAppBar.prototype.destroy = function () { + this.iconRipples_.forEach(function (iconRipple) { return iconRipple.destroy(); }); + this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_); + if (this.navIcon_) { + this.navIcon_.removeEventListener('click', this.handleNavigationClick_); + } + var isFixed = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].FIXED_CLASS); + var isShort = this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].SHORT_CLASS); + if (!isShort && !isFixed) { + window.removeEventListener('resize', this.handleWindowResize_); + } + _super.prototype.destroy.call(this); + }; + MDCTopAppBar.prototype.setScrollTarget = function (target) { + // Remove scroll handler from the previous scroll target + this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_); + this.scrollTarget_ = target; + // Initialize scroll handler on the new scroll target + this.handleTargetScroll_ = + this.foundation_.handleTargetScroll.bind(this.foundation_); + this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_); + }; + MDCTopAppBar.prototype.getDefaultFoundation = function () { + var _this = this; + // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial. + // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable. + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + var adapter = { + hasClass: function (className) { return _this.root_.classList.contains(className); }, + addClass: function (className) { return _this.root_.classList.add(className); }, + removeClass: function (className) { return _this.root_.classList.remove(className); }, + setStyle: function (property, value) { return _this.root_.style.setProperty(property, value); }, + getTopAppBarHeight: function () { return _this.root_.clientHeight; }, + notifyNavigationIconClicked: function () { return _this.emit(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].NAVIGATION_EVENT, {}); }, + getViewportScrollY: function () { + var win = _this.scrollTarget_; + var el = _this.scrollTarget_; + return win.pageYOffset !== undefined ? win.pageYOffset : el.scrollTop; + }, + getTotalActionItems: function () { return _this.root_.querySelectorAll(_constants__WEBPACK_IMPORTED_MODULE_3__["strings"].ACTION_ITEM_SELECTOR).length; }, + }; + // tslint:enable:object-literal-sort-keys + var foundation; + if (this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].SHORT_CLASS)) { + foundation = new _short_foundation__WEBPACK_IMPORTED_MODULE_5__["MDCShortTopAppBarFoundation"](adapter); + } + else if (this.root_.classList.contains(_constants__WEBPACK_IMPORTED_MODULE_3__["cssClasses"].FIXED_CLASS)) { + foundation = new _fixed_foundation__WEBPACK_IMPORTED_MODULE_4__["MDCFixedTopAppBarFoundation"](adapter); + } + else { + foundation = new _standard_foundation__WEBPACK_IMPORTED_MODULE_6__["MDCTopAppBarFoundation"](adapter); + } + return foundation; + }; + return MDCTopAppBar; +}(_material_base_component__WEBPACK_IMPORTED_MODULE_1__["MDCComponent"])); + +//# sourceMappingURL=component.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/constants.js": +/*!*********************************************************!*\ + !*** ./node_modules/@material/top-app-bar/constants.js ***! + \*********************************************************/ +/*! exports provided: cssClasses, numbers, strings */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return cssClasses; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return numbers; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return strings; }); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ +var cssClasses = { + FIXED_CLASS: 'mdc-top-app-bar--fixed', + FIXED_SCROLLED_CLASS: 'mdc-top-app-bar--fixed-scrolled', + SHORT_CLASS: 'mdc-top-app-bar--short', + SHORT_COLLAPSED_CLASS: 'mdc-top-app-bar--short-collapsed', + SHORT_HAS_ACTION_ITEM_CLASS: 'mdc-top-app-bar--short-has-action-item', +}; +var numbers = { + DEBOUNCE_THROTTLE_RESIZE_TIME_MS: 100, + MAX_TOP_APP_BAR_HEIGHT: 128, +}; +var strings = { + ACTION_ITEM_SELECTOR: '.mdc-top-app-bar__action-item', + NAVIGATION_EVENT: 'MDCTopAppBar:nav', + NAVIGATION_ICON_SELECTOR: '.mdc-top-app-bar__navigation-icon', + ROOT_SELECTOR: '.mdc-top-app-bar', + TITLE_SELECTOR: '.mdc-top-app-bar__title', +}; + +//# sourceMappingURL=constants.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/fixed/foundation.js": +/*!****************************************************************!*\ + !*** ./node_modules/@material/top-app-bar/fixed/foundation.js ***! + \****************************************************************/ +/*! exports provided: MDCFixedTopAppBarFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCFixedTopAppBarFoundation", function() { return MDCFixedTopAppBarFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _standard_foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../standard/foundation */ "./node_modules/@material/top-app-bar/standard/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCFixedTopAppBarFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCFixedTopAppBarFoundation, _super); + function MDCFixedTopAppBarFoundation() { + var _this = _super !== null && _super.apply(this, arguments) || this; + /** + * State variable for the previous scroll iteration top app bar state + */ + _this.wasScrolled_ = false; + return _this; + } + /** + * Scroll handler for applying/removing the modifier class on the fixed top app bar. + * @override + */ + MDCFixedTopAppBarFoundation.prototype.handleTargetScroll = function () { + var currentScroll = this.adapter_.getViewportScrollY(); + if (currentScroll <= 0) { + if (this.wasScrolled_) { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].FIXED_SCROLLED_CLASS); + this.wasScrolled_ = false; + } + } + else { + if (!this.wasScrolled_) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].FIXED_SCROLLED_CLASS); + this.wasScrolled_ = true; + } + } + }; + return MDCFixedTopAppBarFoundation; +}(_standard_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCFixedTopAppBarFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/foundation.js": +/*!**********************************************************!*\ + !*** ./node_modules/@material/top-app-bar/foundation.js ***! + \**********************************************************/ +/*! exports provided: MDCTopAppBarBaseFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarBaseFoundation", function() { return MDCTopAppBarBaseFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _material_base_foundation__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/base/foundation */ "./node_modules/@material/base/foundation.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/top-app-bar/constants.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCTopAppBarBaseFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTopAppBarBaseFoundation, _super); + /* istanbul ignore next: optional argument is not a branch statement */ + function MDCTopAppBarBaseFoundation(adapter) { + return _super.call(this, tslib__WEBPACK_IMPORTED_MODULE_0__["__assign"]({}, MDCTopAppBarBaseFoundation.defaultAdapter, adapter)) || this; + } + Object.defineProperty(MDCTopAppBarBaseFoundation, "strings", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["strings"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTopAppBarBaseFoundation, "cssClasses", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["cssClasses"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTopAppBarBaseFoundation, "numbers", { + get: function () { + return _constants__WEBPACK_IMPORTED_MODULE_2__["numbers"]; + }, + enumerable: true, + configurable: true + }); + Object.defineProperty(MDCTopAppBarBaseFoundation, "defaultAdapter", { + /** + * See {@link MDCTopAppBarAdapter} for typing information on parameters and return types. + */ + get: function () { + // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface. + return { + addClass: function () { return undefined; }, + removeClass: function () { return undefined; }, + hasClass: function () { return false; }, + setStyle: function () { return undefined; }, + getTopAppBarHeight: function () { return 0; }, + notifyNavigationIconClicked: function () { return undefined; }, + getViewportScrollY: function () { return 0; }, + getTotalActionItems: function () { return 0; }, + }; + // tslint:enable:object-literal-sort-keys + }, + enumerable: true, + configurable: true + }); + /** Other variants of TopAppBar foundation overrides this method */ + MDCTopAppBarBaseFoundation.prototype.handleTargetScroll = function () { }; // tslint:disable-line:no-empty + /** Other variants of TopAppBar foundation overrides this method */ + MDCTopAppBarBaseFoundation.prototype.handleWindowResize = function () { }; // tslint:disable-line:no-empty + MDCTopAppBarBaseFoundation.prototype.handleNavigationClick = function () { + this.adapter_.notifyNavigationIconClicked(); + }; + return MDCTopAppBarBaseFoundation; +}(_material_base_foundation__WEBPACK_IMPORTED_MODULE_1__["MDCFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTopAppBarBaseFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/index.js": +/*!*****************************************************!*\ + !*** ./node_modules/@material/top-app-bar/index.js ***! + \*****************************************************/ +/*! exports provided: MDCTopAppBar, cssClasses, numbers, strings, MDCTopAppBarBaseFoundation, MDCFixedTopAppBarFoundation, MDCShortTopAppBarFoundation, MDCTopAppBarFoundation */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./component */ "./node_modules/@material/top-app-bar/component.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBar", function() { return _component__WEBPACK_IMPORTED_MODULE_0__["MDCTopAppBar"]; }); + +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "cssClasses", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "numbers", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"]; }); + +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "strings", function() { return _constants__WEBPACK_IMPORTED_MODULE_1__["strings"]; }); + +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation */ "./node_modules/@material/top-app-bar/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarBaseFoundation", function() { return _foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarBaseFoundation"]; }); + +/* harmony import */ var _fixed_foundation__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./fixed/foundation */ "./node_modules/@material/top-app-bar/fixed/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCFixedTopAppBarFoundation", function() { return _fixed_foundation__WEBPACK_IMPORTED_MODULE_3__["MDCFixedTopAppBarFoundation"]; }); + +/* harmony import */ var _short_foundation__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./short/foundation */ "./node_modules/@material/top-app-bar/short/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCShortTopAppBarFoundation", function() { return _short_foundation__WEBPACK_IMPORTED_MODULE_4__["MDCShortTopAppBarFoundation"]; }); + +/* harmony import */ var _standard_foundation__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./standard/foundation */ "./node_modules/@material/top-app-bar/standard/foundation.js"); +/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarFoundation", function() { return _standard_foundation__WEBPACK_IMPORTED_MODULE_5__["MDCTopAppBarFoundation"]; }); + +/** + * @license + * Copyright 2019 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + + + + +//# sourceMappingURL=index.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/short/foundation.js": +/*!****************************************************************!*\ + !*** ./node_modules/@material/top-app-bar/short/foundation.js ***! + \****************************************************************/ +/*! exports provided: MDCShortTopAppBarFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCShortTopAppBarFoundation", function() { return MDCShortTopAppBarFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../foundation */ "./node_modules/@material/top-app-bar/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var MDCShortTopAppBarFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCShortTopAppBarFoundation, _super); + /* istanbul ignore next: optional argument is not a branch statement */ + function MDCShortTopAppBarFoundation(adapter) { + var _this = _super.call(this, adapter) || this; + _this.isCollapsed_ = false; + _this.isAlwaysCollapsed_ = false; + return _this; + } + Object.defineProperty(MDCShortTopAppBarFoundation.prototype, "isCollapsed", { + // Public visibility for backward compatibility. + get: function () { + return this.isCollapsed_; + }, + enumerable: true, + configurable: true + }); + MDCShortTopAppBarFoundation.prototype.init = function () { + _super.prototype.init.call(this); + if (this.adapter_.getTotalActionItems() > 0) { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_HAS_ACTION_ITEM_CLASS); + } + // If initialized with SHORT_COLLAPSED_CLASS, the bar should always be collapsed + this.setAlwaysCollapsed(this.adapter_.hasClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_COLLAPSED_CLASS)); + }; + /** + * Set if the short top app bar should always be collapsed. + * + * @param value When `true`, bar will always be collapsed. When `false`, bar may collapse or expand based on scroll. + */ + MDCShortTopAppBarFoundation.prototype.setAlwaysCollapsed = function (value) { + this.isAlwaysCollapsed_ = !!value; + if (this.isAlwaysCollapsed_) { + this.collapse_(); + } + else { + // let maybeCollapseBar_ determine if the bar should be collapsed + this.maybeCollapseBar_(); + } + }; + MDCShortTopAppBarFoundation.prototype.getAlwaysCollapsed = function () { + return this.isAlwaysCollapsed_; + }; + /** + * Scroll handler for applying/removing the collapsed modifier class on the short top app bar. + * @override + */ + MDCShortTopAppBarFoundation.prototype.handleTargetScroll = function () { + this.maybeCollapseBar_(); + }; + MDCShortTopAppBarFoundation.prototype.maybeCollapseBar_ = function () { + if (this.isAlwaysCollapsed_) { + return; + } + var currentScroll = this.adapter_.getViewportScrollY(); + if (currentScroll <= 0) { + if (this.isCollapsed_) { + this.uncollapse_(); + } + } + else { + if (!this.isCollapsed_) { + this.collapse_(); + } + } + }; + MDCShortTopAppBarFoundation.prototype.uncollapse_ = function () { + this.adapter_.removeClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_COLLAPSED_CLASS); + this.isCollapsed_ = false; + }; + MDCShortTopAppBarFoundation.prototype.collapse_ = function () { + this.adapter_.addClass(_constants__WEBPACK_IMPORTED_MODULE_1__["cssClasses"].SHORT_COLLAPSED_CLASS); + this.isCollapsed_ = true; + }; + return MDCShortTopAppBarFoundation; +}(_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarBaseFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCShortTopAppBarFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/@material/top-app-bar/standard/foundation.js": +/*!*******************************************************************!*\ + !*** ./node_modules/@material/top-app-bar/standard/foundation.js ***! + \*******************************************************************/ +/*! exports provided: MDCTopAppBarFoundation, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MDCTopAppBarFoundation", function() { return MDCTopAppBarFoundation; }); +/* harmony import */ var tslib__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! tslib */ "./node_modules/tslib/tslib.es6.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../constants */ "./node_modules/@material/top-app-bar/constants.js"); +/* harmony import */ var _foundation__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../foundation */ "./node_modules/@material/top-app-bar/foundation.js"); +/** + * @license + * Copyright 2018 Google Inc. + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in + * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + * THE SOFTWARE. + */ + + + +var INITIAL_VALUE = 0; +var MDCTopAppBarFoundation = /** @class */ (function (_super) { + tslib__WEBPACK_IMPORTED_MODULE_0__["__extends"](MDCTopAppBarFoundation, _super); + /* istanbul ignore next: optional argument is not a branch statement */ + function MDCTopAppBarFoundation(adapter) { + var _this = _super.call(this, adapter) || this; + /** + * Indicates if the top app bar was docked in the previous scroll handler iteration. + */ + _this.wasDocked_ = true; + /** + * Indicates if the top app bar is docked in the fully shown position. + */ + _this.isDockedShowing_ = true; + /** + * Variable for current scroll position of the top app bar + */ + _this.currentAppBarOffsetTop_ = 0; + /** + * Used to prevent the top app bar from being scrolled out of view during resize events + */ + _this.isCurrentlyBeingResized_ = false; + /** + * The timeout that's used to throttle the resize events + */ + _this.resizeThrottleId_ = INITIAL_VALUE; + /** + * The timeout that's used to debounce toggling the isCurrentlyBeingResized_ variable after a resize + */ + _this.resizeDebounceId_ = INITIAL_VALUE; + _this.lastScrollPosition_ = _this.adapter_.getViewportScrollY(); + _this.topAppBarHeight_ = _this.adapter_.getTopAppBarHeight(); + return _this; + } + MDCTopAppBarFoundation.prototype.destroy = function () { + _super.prototype.destroy.call(this); + this.adapter_.setStyle('top', ''); + }; + /** + * Scroll handler for the default scroll behavior of the top app bar. + * @override + */ + MDCTopAppBarFoundation.prototype.handleTargetScroll = function () { + var currentScrollPosition = Math.max(this.adapter_.getViewportScrollY(), 0); + var diff = currentScrollPosition - this.lastScrollPosition_; + this.lastScrollPosition_ = currentScrollPosition; + // If the window is being resized the lastScrollPosition_ needs to be updated but the + // current scroll of the top app bar should stay in the same position. + if (!this.isCurrentlyBeingResized_) { + this.currentAppBarOffsetTop_ -= diff; + if (this.currentAppBarOffsetTop_ > 0) { + this.currentAppBarOffsetTop_ = 0; + } + else if (Math.abs(this.currentAppBarOffsetTop_) > this.topAppBarHeight_) { + this.currentAppBarOffsetTop_ = -this.topAppBarHeight_; + } + this.moveTopAppBar_(); + } + }; + /** + * Top app bar resize handler that throttle/debounce functions that execute updates. + * @override + */ + MDCTopAppBarFoundation.prototype.handleWindowResize = function () { + var _this = this; + // Throttle resize events 10 p/s + if (!this.resizeThrottleId_) { + this.resizeThrottleId_ = setTimeout(function () { + _this.resizeThrottleId_ = INITIAL_VALUE; + _this.throttledResizeHandler_(); + }, _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"].DEBOUNCE_THROTTLE_RESIZE_TIME_MS); + } + this.isCurrentlyBeingResized_ = true; + if (this.resizeDebounceId_) { + clearTimeout(this.resizeDebounceId_); + } + this.resizeDebounceId_ = setTimeout(function () { + _this.handleTargetScroll(); + _this.isCurrentlyBeingResized_ = false; + _this.resizeDebounceId_ = INITIAL_VALUE; + }, _constants__WEBPACK_IMPORTED_MODULE_1__["numbers"].DEBOUNCE_THROTTLE_RESIZE_TIME_MS); + }; + /** + * Function to determine if the DOM needs to update. + */ + MDCTopAppBarFoundation.prototype.checkForUpdate_ = function () { + var offscreenBoundaryTop = -this.topAppBarHeight_; + var hasAnyPixelsOffscreen = this.currentAppBarOffsetTop_ < 0; + var hasAnyPixelsOnscreen = this.currentAppBarOffsetTop_ > offscreenBoundaryTop; + var partiallyShowing = hasAnyPixelsOffscreen && hasAnyPixelsOnscreen; + // If it's partially showing, it can't be docked. + if (partiallyShowing) { + this.wasDocked_ = false; + } + else { + // Not previously docked and not partially showing, it's now docked. + if (!this.wasDocked_) { + this.wasDocked_ = true; + return true; + } + else if (this.isDockedShowing_ !== hasAnyPixelsOnscreen) { + this.isDockedShowing_ = hasAnyPixelsOnscreen; + return true; + } + } + return partiallyShowing; + }; + /** + * Function to move the top app bar if needed. + */ + MDCTopAppBarFoundation.prototype.moveTopAppBar_ = function () { + if (this.checkForUpdate_()) { + // Once the top app bar is fully hidden we use the max potential top app bar height as our offset + // so the top app bar doesn't show if the window resizes and the new height > the old height. + var offset = this.currentAppBarOffsetTop_; + if (Math.abs(offset) >= this.topAppBarHeight_) { + offset = -_constants__WEBPACK_IMPORTED_MODULE_1__["numbers"].MAX_TOP_APP_BAR_HEIGHT; + } + this.adapter_.setStyle('top', offset + 'px'); + } + }; + /** + * Throttled function that updates the top app bar scrolled values if the + * top app bar height changes. + */ + MDCTopAppBarFoundation.prototype.throttledResizeHandler_ = function () { + var currentHeight = this.adapter_.getTopAppBarHeight(); + if (this.topAppBarHeight_ !== currentHeight) { + this.wasDocked_ = false; + // Since the top app bar has a different height depending on the screen width, this + // will ensure that the top app bar remains in the correct location if + // completely hidden and a resize makes the top app bar a different height. + this.currentAppBarOffsetTop_ -= this.topAppBarHeight_ - currentHeight; + this.topAppBarHeight_ = currentHeight; + } + this.handleTargetScroll(); + }; + return MDCTopAppBarFoundation; +}(_foundation__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBarBaseFoundation"])); + +// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier. +/* harmony default export */ __webpack_exports__["default"] = (MDCTopAppBarFoundation); +//# sourceMappingURL=foundation.js.map + +/***/ }), + +/***/ "./node_modules/parallax-js/dist/parallax.js": +/*!***************************************************!*\ + !*** ./node_modules/parallax-js/dist/parallax.js ***! + \***************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +/* WEBPACK VAR INJECTION */(function(global) {var require;var require;(function(f){if(true){module.exports=f()}else { var g; }})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return require(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o 1) { + for (var i = 1; i < arguments.length; i++) { + args[i - 1] = arguments[i]; + } + } + queue.push(new Item(fun, args)); + if (queue.length === 1 && !draining) { + runTimeout(drainQueue); + } +}; + +// v8 likes predictible objects +function Item(fun, array) { + this.fun = fun; + this.array = array; +} +Item.prototype.run = function () { + this.fun.apply(null, this.array); +}; +process.title = 'browser'; +process.browser = true; +process.env = {}; +process.argv = []; +process.version = ''; // empty string to avoid regexp issues +process.versions = {}; + +function noop() {} + +process.on = noop; +process.addListener = noop; +process.once = noop; +process.off = noop; +process.removeListener = noop; +process.removeAllListeners = noop; +process.emit = noop; +process.prependListener = noop; +process.prependOnceListener = noop; + +process.listeners = function (name) { return [] } + +process.binding = function (name) { + throw new Error('process.binding is not supported'); +}; + +process.cwd = function () { return '/' }; +process.chdir = function (dir) { + throw new Error('process.chdir is not supported'); +}; +process.umask = function() { return 0; }; + +},{}],4:[function(require,module,exports){ +(function (global){ +var now = require('performance-now') + , root = typeof window === 'undefined' ? global : window + , vendors = ['moz', 'webkit'] + , suffix = 'AnimationFrame' + , raf = root['request' + suffix] + , caf = root['cancel' + suffix] || root['cancelRequest' + suffix] + +for(var i = 0; !raf && i < vendors.length; i++) { + raf = root[vendors[i] + 'Request' + suffix] + caf = root[vendors[i] + 'Cancel' + suffix] + || root[vendors[i] + 'CancelRequest' + suffix] +} + +// Some versions of FF have rAF but not cAF +if(!raf || !caf) { + var last = 0 + , id = 0 + , queue = [] + , frameDuration = 1000 / 60 + + raf = function(callback) { + if(queue.length === 0) { + var _now = now() + , next = Math.max(0, frameDuration - (_now - last)) + last = next + _now + setTimeout(function() { + var cp = queue.slice(0) + // Clear queue here to prevent + // callbacks from appending listeners + // to the current frame's queue + queue.length = 0 + for(var i = 0; i < cp.length; i++) { + if(!cp[i].cancelled) { + try{ + cp[i].callback(last) + } catch(e) { + setTimeout(function() { throw e }, 0) + } + } + } + }, Math.round(next)) + } + queue.push({ + handle: ++id, + callback: callback, + cancelled: false + }) + return id + } + + caf = function(handle) { + for(var i = 0; i < queue.length; i++) { + if(queue[i].handle === handle) { + queue[i].cancelled = true + } + } + } +} + +module.exports = function(fn) { + // Wrap in a new function to prevent + // `cancel` potentially being assigned + // to the native rAF function + return raf.call(root, fn) +} +module.exports.cancel = function() { + caf.apply(root, arguments) +} +module.exports.polyfill = function() { + root.requestAnimationFrame = raf + root.cancelAnimationFrame = caf +} + +}).call(this,typeof global !== "undefined" ? global : typeof self !== "undefined" ? self : typeof window !== "undefined" ? window : {}) + +},{"performance-now":2}],5:[function(require,module,exports){ +'use strict'; + +var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); + +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } + +/** +* Parallax.js +* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org +* @description Creates a parallax effect between an array of layers, +* driving the motion from the gyroscope output of a smartdevice. +* If no gyroscope is available, the cursor position is used. +*/ + +var rqAnFr = require('raf'); +var objectAssign = require('object-assign'); + +var helpers = { + propertyCache: {}, + vendors: [null, ['-webkit-', 'webkit'], ['-moz-', 'Moz'], ['-o-', 'O'], ['-ms-', 'ms']], + + clamp: function clamp(value, min, max) { + return min < max ? value < min ? min : value > max ? max : value : value < max ? max : value > min ? min : value; + }, + data: function data(element, name) { + return helpers.deserialize(element.getAttribute('data-' + name)); + }, + deserialize: function deserialize(value) { + if (value === 'true') { + return true; + } else if (value === 'false') { + return false; + } else if (value === 'null') { + return null; + } else if (!isNaN(parseFloat(value)) && isFinite(value)) { + return parseFloat(value); + } else { + return value; + } + }, + camelCase: function camelCase(value) { + return value.replace(/-+(.)?/g, function (match, character) { + return character ? character.toUpperCase() : ''; + }); + }, + accelerate: function accelerate(element) { + helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)'); + helpers.css(element, 'transform-style', 'preserve-3d'); + helpers.css(element, 'backface-visibility', 'hidden'); + }, + transformSupport: function transformSupport(value) { + var element = document.createElement('div'), + propertySupport = false, + propertyValue = null, + featureSupport = false, + cssProperty = null, + jsProperty = null; + for (var i = 0, l = helpers.vendors.length; i < l; i++) { + if (helpers.vendors[i] !== null) { + cssProperty = helpers.vendors[i][0] + 'transform'; + jsProperty = helpers.vendors[i][1] + 'Transform'; + } else { + cssProperty = 'transform'; + jsProperty = 'transform'; + } + if (element.style[jsProperty] !== undefined) { + propertySupport = true; + break; + } + } + switch (value) { + case '2D': + featureSupport = propertySupport; + break; + case '3D': + if (propertySupport) { + var body = document.body || document.createElement('body'), + documentElement = document.documentElement, + documentOverflow = documentElement.style.overflow, + isCreatedBody = false; + + if (!document.body) { + isCreatedBody = true; + documentElement.style.overflow = 'hidden'; + documentElement.appendChild(body); + body.style.overflow = 'hidden'; + body.style.background = ''; + } + + body.appendChild(element); + element.style[jsProperty] = 'translate3d(1px,1px,1px)'; + propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty); + featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none'; + documentElement.style.overflow = documentOverflow; + body.removeChild(element); + + if (isCreatedBody) { + body.removeAttribute('style'); + body.parentNode.removeChild(body); + } + } + break; + } + return featureSupport; + }, + css: function css(element, property, value) { + var jsProperty = helpers.propertyCache[property]; + if (!jsProperty) { + for (var i = 0, l = helpers.vendors.length; i < l; i++) { + if (helpers.vendors[i] !== null) { + jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property); + } else { + jsProperty = property; + } + if (element.style[jsProperty] !== undefined) { + helpers.propertyCache[property] = jsProperty; + break; + } + } + } + element.style[jsProperty] = value; + } +}; + +var MAGIC_NUMBER = 30, + DEFAULTS = { + relativeInput: false, + clipRelativeInput: false, + inputElement: null, + hoverOnly: false, + calibrationThreshold: 100, + calibrationDelay: 500, + supportDelay: 500, + calibrateX: false, + calibrateY: true, + invertX: true, + invertY: true, + limitX: false, + limitY: false, + scalarX: 10.0, + scalarY: 10.0, + frictionX: 0.1, + frictionY: 0.1, + originX: 0.5, + originY: 0.5, + pointerEvents: false, + precision: 1, + onReady: null, + selector: null +}; + +var Parallax = function () { + function Parallax(element, options) { + _classCallCheck(this, Parallax); + + this.element = element; + + var data = { + calibrateX: helpers.data(this.element, 'calibrate-x'), + calibrateY: helpers.data(this.element, 'calibrate-y'), + invertX: helpers.data(this.element, 'invert-x'), + invertY: helpers.data(this.element, 'invert-y'), + limitX: helpers.data(this.element, 'limit-x'), + limitY: helpers.data(this.element, 'limit-y'), + scalarX: helpers.data(this.element, 'scalar-x'), + scalarY: helpers.data(this.element, 'scalar-y'), + frictionX: helpers.data(this.element, 'friction-x'), + frictionY: helpers.data(this.element, 'friction-y'), + originX: helpers.data(this.element, 'origin-x'), + originY: helpers.data(this.element, 'origin-y'), + pointerEvents: helpers.data(this.element, 'pointer-events'), + precision: helpers.data(this.element, 'precision'), + relativeInput: helpers.data(this.element, 'relative-input'), + clipRelativeInput: helpers.data(this.element, 'clip-relative-input'), + hoverOnly: helpers.data(this.element, 'hover-only'), + inputElement: document.querySelector(helpers.data(this.element, 'input-element')), + selector: helpers.data(this.element, 'selector') + }; + + for (var key in data) { + if (data[key] === null) { + delete data[key]; + } + } + + objectAssign(this, DEFAULTS, data, options); + + if (!this.inputElement) { + this.inputElement = this.element; + } + + this.calibrationTimer = null; + this.calibrationFlag = true; + this.enabled = false; + this.depthsX = []; + this.depthsY = []; + this.raf = null; + + this.bounds = null; + this.elementPositionX = 0; + this.elementPositionY = 0; + this.elementWidth = 0; + this.elementHeight = 0; + + this.elementCenterX = 0; + this.elementCenterY = 0; + + this.elementRangeX = 0; + this.elementRangeY = 0; + + this.calibrationX = 0; + this.calibrationY = 0; + + this.inputX = 0; + this.inputY = 0; + + this.motionX = 0; + this.motionY = 0; + + this.velocityX = 0; + this.velocityY = 0; + + this.onMouseMove = this.onMouseMove.bind(this); + this.onDeviceOrientation = this.onDeviceOrientation.bind(this); + this.onDeviceMotion = this.onDeviceMotion.bind(this); + this.onOrientationTimer = this.onOrientationTimer.bind(this); + this.onMotionTimer = this.onMotionTimer.bind(this); + this.onCalibrationTimer = this.onCalibrationTimer.bind(this); + this.onAnimationFrame = this.onAnimationFrame.bind(this); + this.onWindowResize = this.onWindowResize.bind(this); + + this.windowWidth = null; + this.windowHeight = null; + this.windowCenterX = null; + this.windowCenterY = null; + this.windowRadiusX = null; + this.windowRadiusY = null; + this.portrait = false; + this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i); + this.motionSupport = !!window.DeviceMotionEvent && !this.desktop; + this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop; + this.orientationStatus = 0; + this.motionStatus = 0; + + this.initialise(); + } + + _createClass(Parallax, [{ + key: 'initialise', + value: function initialise() { + if (this.transform2DSupport === undefined) { + this.transform2DSupport = helpers.transformSupport('2D'); + this.transform3DSupport = helpers.transformSupport('3D'); + } + + // Configure Context Styles + if (this.transform3DSupport) { + helpers.accelerate(this.element); + } + + var style = window.getComputedStyle(this.element); + if (style.getPropertyValue('position') === 'static') { + this.element.style.position = 'relative'; + } + + // Pointer events + if (!this.pointerEvents) { + this.element.style.pointerEvents = 'none'; + } + + // Setup + this.updateLayers(); + this.updateDimensions(); + this.enable(); + this.queueCalibration(this.calibrationDelay); + } + }, { + key: 'doReadyCallback', + value: function doReadyCallback() { + if (this.onReady) { + this.onReady(); + } + } + }, { + key: 'updateLayers', + value: function updateLayers() { + if (this.selector) { + this.layers = this.element.querySelectorAll(this.selector); + } else { + this.layers = this.element.children; + } + + if (!this.layers.length) { + console.warn('ParallaxJS: Your scene does not have any layers.'); + } + + this.depthsX = []; + this.depthsY = []; + + for (var index = 0; index < this.layers.length; index++) { + var layer = this.layers[index]; + + if (this.transform3DSupport) { + helpers.accelerate(layer); + } + + layer.style.position = index ? 'absolute' : 'relative'; + layer.style.display = 'block'; + layer.style.left = 0; + layer.style.top = 0; + + var depth = helpers.data(layer, 'depth') || 0; + this.depthsX.push(helpers.data(layer, 'depth-x') || depth); + this.depthsY.push(helpers.data(layer, 'depth-y') || depth); + } + } + }, { + key: 'updateDimensions', + value: function updateDimensions() { + this.windowWidth = window.innerWidth; + this.windowHeight = window.innerHeight; + this.windowCenterX = this.windowWidth * this.originX; + this.windowCenterY = this.windowHeight * this.originY; + this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX); + this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY); + } + }, { + key: 'updateBounds', + value: function updateBounds() { + this.bounds = this.inputElement.getBoundingClientRect(); + this.elementPositionX = this.bounds.left; + this.elementPositionY = this.bounds.top; + this.elementWidth = this.bounds.width; + this.elementHeight = this.bounds.height; + this.elementCenterX = this.elementWidth * this.originX; + this.elementCenterY = this.elementHeight * this.originY; + this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX); + this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY); + } + }, { + key: 'queueCalibration', + value: function queueCalibration(delay) { + clearTimeout(this.calibrationTimer); + this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay); + } + }, { + key: 'enable', + value: function enable() { + if (this.enabled) { + return; + } + this.enabled = true; + + if (this.orientationSupport) { + this.portrait = false; + window.addEventListener('deviceorientation', this.onDeviceOrientation); + this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay); + } else if (this.motionSupport) { + this.portrait = false; + window.addEventListener('devicemotion', this.onDeviceMotion); + this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay); + } else { + this.calibrationX = 0; + this.calibrationY = 0; + this.portrait = false; + window.addEventListener('mousemove', this.onMouseMove); + this.doReadyCallback(); + } + + window.addEventListener('resize', this.onWindowResize); + this.raf = rqAnFr(this.onAnimationFrame); + } + }, { + key: 'disable', + value: function disable() { + if (!this.enabled) { + return; + } + this.enabled = false; + + if (this.orientationSupport) { + window.removeEventListener('deviceorientation', this.onDeviceOrientation); + } else if (this.motionSupport) { + window.removeEventListener('devicemotion', this.onDeviceMotion); + } else { + window.removeEventListener('mousemove', this.onMouseMove); + } + + window.removeEventListener('resize', this.onWindowResize); + rqAnFr.cancel(this.raf); + } + }, { + key: 'calibrate', + value: function calibrate(x, y) { + this.calibrateX = x === undefined ? this.calibrateX : x; + this.calibrateY = y === undefined ? this.calibrateY : y; + } + }, { + key: 'invert', + value: function invert(x, y) { + this.invertX = x === undefined ? this.invertX : x; + this.invertY = y === undefined ? this.invertY : y; + } + }, { + key: 'friction', + value: function friction(x, y) { + this.frictionX = x === undefined ? this.frictionX : x; + this.frictionY = y === undefined ? this.frictionY : y; + } + }, { + key: 'scalar', + value: function scalar(x, y) { + this.scalarX = x === undefined ? this.scalarX : x; + this.scalarY = y === undefined ? this.scalarY : y; + } + }, { + key: 'limit', + value: function limit(x, y) { + this.limitX = x === undefined ? this.limitX : x; + this.limitY = y === undefined ? this.limitY : y; + } + }, { + key: 'origin', + value: function origin(x, y) { + this.originX = x === undefined ? this.originX : x; + this.originY = y === undefined ? this.originY : y; + } + }, { + key: 'setInputElement', + value: function setInputElement(element) { + this.inputElement = element; + this.updateDimensions(); + } + }, { + key: 'setPosition', + value: function setPosition(element, x, y) { + x = x.toFixed(this.precision) + 'px'; + y = y.toFixed(this.precision) + 'px'; + if (this.transform3DSupport) { + helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)'); + } else if (this.transform2DSupport) { + helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')'); + } else { + element.style.left = x; + element.style.top = y; + } + } + }, { + key: 'onOrientationTimer', + value: function onOrientationTimer() { + if (this.orientationSupport && this.orientationStatus === 0) { + this.disable(); + this.orientationSupport = false; + this.enable(); + } else { + this.doReadyCallback(); + } + } + }, { + key: 'onMotionTimer', + value: function onMotionTimer() { + if (this.motionSupport && this.motionStatus === 0) { + this.disable(); + this.motionSupport = false; + this.enable(); + } else { + this.doReadyCallback(); + } + } + }, { + key: 'onCalibrationTimer', + value: function onCalibrationTimer() { + this.calibrationFlag = true; + } + }, { + key: 'onWindowResize', + value: function onWindowResize() { + this.updateDimensions(); + } + }, { + key: 'onAnimationFrame', + value: function onAnimationFrame() { + this.updateBounds(); + var calibratedInputX = this.inputX - this.calibrationX, + calibratedInputY = this.inputY - this.calibrationY; + if (Math.abs(calibratedInputX) > this.calibrationThreshold || Math.abs(calibratedInputY) > this.calibrationThreshold) { + this.queueCalibration(0); + } + if (this.portrait) { + this.motionX = this.calibrateX ? calibratedInputY : this.inputY; + this.motionY = this.calibrateY ? calibratedInputX : this.inputX; + } else { + this.motionX = this.calibrateX ? calibratedInputX : this.inputX; + this.motionY = this.calibrateY ? calibratedInputY : this.inputY; + } + this.motionX *= this.elementWidth * (this.scalarX / 100); + this.motionY *= this.elementHeight * (this.scalarY / 100); + if (!isNaN(parseFloat(this.limitX))) { + this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX); + } + if (!isNaN(parseFloat(this.limitY))) { + this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY); + } + this.velocityX += (this.motionX - this.velocityX) * this.frictionX; + this.velocityY += (this.motionY - this.velocityY) * this.frictionY; + for (var index = 0; index < this.layers.length; index++) { + var layer = this.layers[index], + depthX = this.depthsX[index], + depthY = this.depthsY[index], + xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)), + yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1)); + this.setPosition(layer, xOffset, yOffset); + } + this.raf = rqAnFr(this.onAnimationFrame); + } + }, { + key: 'rotate', + value: function rotate(beta, gamma) { + // Extract Rotation + var x = (beta || 0) / MAGIC_NUMBER, + // -90 :: 90 + y = (gamma || 0) / MAGIC_NUMBER; // -180 :: 180 + + // Detect Orientation Change + var portrait = this.windowHeight > this.windowWidth; + if (this.portrait !== portrait) { + this.portrait = portrait; + this.calibrationFlag = true; + } + + if (this.calibrationFlag) { + this.calibrationFlag = false; + this.calibrationX = x; + this.calibrationY = y; + } + + this.inputX = x; + this.inputY = y; + } + }, { + key: 'onDeviceOrientation', + value: function onDeviceOrientation(event) { + var beta = event.beta; + var gamma = event.gamma; + if (beta !== null && gamma !== null) { + this.orientationStatus = 1; + this.rotate(beta, gamma); + } + } + }, { + key: 'onDeviceMotion', + value: function onDeviceMotion(event) { + var beta = event.rotationRate.beta; + var gamma = event.rotationRate.gamma; + if (beta !== null && gamma !== null) { + this.motionStatus = 1; + this.rotate(beta, gamma); + } + } + }, { + key: 'onMouseMove', + value: function onMouseMove(event) { + var clientX = event.clientX, + clientY = event.clientY; + + // reset input to center if hoverOnly is set and we're not hovering the element + if (this.hoverOnly && (clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth || clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight)) { + this.inputX = 0; + this.inputY = 0; + return; + } + + if (this.relativeInput) { + // Clip mouse coordinates inside element bounds. + if (this.clipRelativeInput) { + clientX = Math.max(clientX, this.elementPositionX); + clientX = Math.min(clientX, this.elementPositionX + this.elementWidth); + clientY = Math.max(clientY, this.elementPositionY); + clientY = Math.min(clientY, this.elementPositionY + this.elementHeight); + } + // Calculate input relative to the element. + if (this.elementRangeX && this.elementRangeY) { + this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX; + this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY; + } + } else { + // Calculate input relative to the window. + if (this.windowRadiusX && this.windowRadiusY) { + this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX; + this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY; + } + } + } + }, { + key: 'destroy', + value: function destroy() { + this.disable(); + + clearTimeout(this.calibrationTimer); + clearTimeout(this.detectionTimer); + + this.element.removeAttribute('style'); + for (var index = 0; index < this.layers.length; index++) { + this.layers[index].removeAttribute('style'); + } + + delete this.element; + delete this.layers; + } + }, { + key: 'version', + value: function version() { + return '3.1.0'; + } + }]); + + return Parallax; +}(); + +module.exports = Parallax; + +},{"object-assign":1,"raf":4}]},{},[5])(5) +}); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/object-assign/index.js","node_modules/performance-now/lib/performance-now.js","node_modules/process/browser.js","node_modules/raf/index.js","src/parallax.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACxLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACxEA;;;;;;;;AAQA,IAAM,SAAS,QAAQ,KAAR,CAAf;AACA,IAAM,eAAe,QAAQ,eAAR,CAArB;;AAEA,IAAM,UAAU;AACd,iBAAe,EADD;AAEd,WAAS,CAAC,IAAD,EAAO,CAAC,UAAD,EAAY,QAAZ,CAAP,EAA8B,CAAC,OAAD,EAAS,KAAT,CAA9B,EAA+C,CAAC,KAAD,EAAO,GAAP,CAA/C,EAA4D,CAAC,MAAD,EAAQ,IAAR,CAA5D,CAFK;;AAId,OAJc,iBAIR,KAJQ,EAID,GAJC,EAII,GAJJ,EAIS;AACrB,WAAO,MAAM,GAAN,GACF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,KADtC,GAEF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,K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","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated by CoffeeScript 1.12.2\n(function() {\n  var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - nodeLoadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    moduleLoadTime = getNanoSeconds();\n    upTime = process.uptime() * 1e9;\n    nodeLoadTime = moduleLoadTime - upTime;\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n\n//# sourceMappingURL=performance-now.js.map\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","var now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n","/**\n* Parallax.js\n* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org\n* @description Creates a parallax effect between an array of layers,\n*              driving the motion from the gyroscope output of a smartdevice.\n*              If no gyroscope is available, the cursor position is used.\n*/\n\nconst rqAnFr = require('raf')\nconst objectAssign = require('object-assign')\n\nconst helpers = {\n  propertyCache: {},\n  vendors: [null, ['-webkit-','webkit'], ['-moz-','Moz'], ['-o-','O'], ['-ms-','ms']],\n\n  clamp(value, min, max) {\n    return min < max\n      ? (value < min ? min : value > max ? max : value)\n      : (value < max ? max : value > min ? min : value)\n  },\n\n  data(element, name) {\n    return helpers.deserialize(element.getAttribute('data-'+name))\n  },\n\n  deserialize(value) {\n    if (value === 'true') {\n      return true\n    } else if (value === 'false') {\n      return false\n    } else if (value === 'null') {\n      return null\n    } else if (!isNaN(parseFloat(value)) && isFinite(value)) {\n      return parseFloat(value)\n    } else {\n      return value\n    }\n  },\n\n  camelCase(value) {\n    return value.replace(/-+(.)?/g, (match, character) => {\n      return character ? character.toUpperCase() : ''\n    })\n  },\n\n  accelerate(element) {\n    helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)')\n    helpers.css(element, 'transform-style', 'preserve-3d')\n    helpers.css(element, 'backface-visibility', 'hidden')\n  },\n\n  transformSupport(value) {\n    let element = document.createElement('div'),\n        propertySupport = false,\n        propertyValue = null,\n        featureSupport = false,\n        cssProperty = null,\n        jsProperty = null\n    for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n      if (helpers.vendors[i] !== null) {\n        cssProperty = helpers.vendors[i][0] + 'transform'\n        jsProperty = helpers.vendors[i][1] + 'Transform'\n      } else {\n        cssProperty = 'transform'\n        jsProperty = 'transform'\n      }\n      if (element.style[jsProperty] !== undefined) {\n        propertySupport = true\n        break\n      }\n    }\n    switch(value) {\n      case '2D':\n        featureSupport = propertySupport\n        break\n      case '3D':\n        if (propertySupport) {\n          let body = document.body || document.createElement('body'),\n              documentElement = document.documentElement,\n              documentOverflow = documentElement.style.overflow,\n              isCreatedBody = false\n\n          if (!document.body) {\n            isCreatedBody = true\n            documentElement.style.overflow = 'hidden'\n            documentElement.appendChild(body)\n            body.style.overflow = 'hidden'\n            body.style.background = ''\n          }\n\n          body.appendChild(element)\n          element.style[jsProperty] = 'translate3d(1px,1px,1px)'\n          propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty)\n          featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none'\n          documentElement.style.overflow = documentOverflow\n          body.removeChild(element)\n\n          if ( isCreatedBody ) {\n            body.removeAttribute('style')\n            body.parentNode.removeChild(body)\n          }\n        }\n        break\n    }\n    return featureSupport\n  },\n\n  css(element, property, value) {\n    let jsProperty = helpers.propertyCache[property]\n    if (!jsProperty) {\n      for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n        if (helpers.vendors[i] !== null) {\n          jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property)\n        } else {\n          jsProperty = property\n        }\n        if (element.style[jsProperty] !== undefined) {\n          helpers.propertyCache[property] = jsProperty\n          break\n        }\n      }\n    }\n    element.style[jsProperty] = value\n  }\n\n}\n\nconst MAGIC_NUMBER = 30,\n      DEFAULTS = {\n        relativeInput: false,\n        clipRelativeInput: false,\n        inputElement: null,\n        hoverOnly: false,\n        calibrationThreshold: 100,\n        calibrationDelay: 500,\n        supportDelay: 500,\n        calibrateX: false,\n        calibrateY: true,\n        invertX: true,\n        invertY: true,\n        limitX: false,\n        limitY: false,\n        scalarX: 10.0,\n        scalarY: 10.0,\n        frictionX: 0.1,\n        frictionY: 0.1,\n        originX: 0.5,\n        originY: 0.5,\n        pointerEvents: false,\n        precision: 1,\n        onReady: null,\n        selector: null\n      }\n\nclass Parallax {\n  constructor(element, options) {\n\n    this.element = element\n\n    const data = {\n      calibrateX: helpers.data(this.element, 'calibrate-x'),\n      calibrateY: helpers.data(this.element, 'calibrate-y'),\n      invertX: helpers.data(this.element, 'invert-x'),\n      invertY: helpers.data(this.element, 'invert-y'),\n      limitX: helpers.data(this.element, 'limit-x'),\n      limitY: helpers.data(this.element, 'limit-y'),\n      scalarX: helpers.data(this.element, 'scalar-x'),\n      scalarY: helpers.data(this.element, 'scalar-y'),\n      frictionX: helpers.data(this.element, 'friction-x'),\n      frictionY: helpers.data(this.element, 'friction-y'),\n      originX: helpers.data(this.element, 'origin-x'),\n      originY: helpers.data(this.element, 'origin-y'),\n      pointerEvents: helpers.data(this.element, 'pointer-events'),\n      precision: helpers.data(this.element, 'precision'),\n      relativeInput: helpers.data(this.element, 'relative-input'),\n      clipRelativeInput: helpers.data(this.element, 'clip-relative-input'),\n      hoverOnly: helpers.data(this.element, 'hover-only'),\n      inputElement: document.querySelector(helpers.data(this.element, 'input-element')),\n      selector: helpers.data(this.element, 'selector')\n    }\n\n    for (let key in data) {\n      if (data[key] === null) {\n        delete data[key]\n      }\n    }\n\n    objectAssign(this, DEFAULTS, data, options)\n\n    if(!this.inputElement) {\n      this.inputElement = this.element\n    }\n\n    this.calibrationTimer = null\n    this.calibrationFlag = true\n    this.enabled = false\n    this.depthsX = []\n    this.depthsY = []\n    this.raf = null\n\n    this.bounds = null\n    this.elementPositionX = 0\n    this.elementPositionY = 0\n    this.elementWidth = 0\n    this.elementHeight = 0\n\n    this.elementCenterX = 0\n    this.elementCenterY = 0\n\n    this.elementRangeX = 0\n    this.elementRangeY = 0\n\n    this.calibrationX = 0\n    this.calibrationY = 0\n\n    this.inputX = 0\n    this.inputY = 0\n\n    this.motionX = 0\n    this.motionY = 0\n\n    this.velocityX = 0\n    this.velocityY = 0\n\n    this.onMouseMove = this.onMouseMove.bind(this)\n    this.onDeviceOrientation = this.onDeviceOrientation.bind(this)\n    this.onDeviceMotion = this.onDeviceMotion.bind(this)\n    this.onOrientationTimer = this.onOrientationTimer.bind(this)\n    this.onMotionTimer = this.onMotionTimer.bind(this)\n    this.onCalibrationTimer = this.onCalibrationTimer.bind(this)\n    this.onAnimationFrame = this.onAnimationFrame.bind(this)\n    this.onWindowResize = this.onWindowResize.bind(this)\n\n    this.windowWidth = null\n    this.windowHeight = null\n    this.windowCenterX = null\n    this.windowCenterY = null\n    this.windowRadiusX = null\n    this.windowRadiusY = null\n    this.portrait = false\n    this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i)\n    this.motionSupport = !!window.DeviceMotionEvent && !this.desktop\n    this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop\n    this.orientationStatus = 0\n    this.motionStatus = 0\n\n    this.initialise()\n  }\n\n  initialise() {\n    if (this.transform2DSupport === undefined) {\n      this.transform2DSupport = helpers.transformSupport('2D')\n      this.transform3DSupport = helpers.transformSupport('3D')\n    }\n\n    // Configure Context Styles\n    if (this.transform3DSupport) {\n      helpers.accelerate(this.element)\n    }\n\n    let style = window.getComputedStyle(this.element)\n    if (style.getPropertyValue('position') === 'static') {\n      this.element.style.position = 'relative'\n    }\n\n    // Pointer events\n    if(!this.pointerEvents) {\n      this.element.style.pointerEvents = 'none'\n    }\n\n    // Setup\n    this.updateLayers()\n    this.updateDimensions()\n    this.enable()\n    this.queueCalibration(this.calibrationDelay)\n  }\n\n  doReadyCallback() {\n    if(this.onReady) {\n      this.onReady()\n    }\n  }\n\n  updateLayers() {\n    if(this.selector) {\n      this.layers = this.element.querySelectorAll(this.selector)\n    } else {\n      this.layers = this.element.children\n    }\n\n    if(!this.layers.length) {\n      console.warn('ParallaxJS: Your scene does not have any layers.')\n    }\n\n    this.depthsX = []\n    this.depthsY = []\n\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index]\n\n      if (this.transform3DSupport) {\n        helpers.accelerate(layer)\n      }\n\n      layer.style.position = index ? 'absolute' : 'relative'\n      layer.style.display = 'block'\n      layer.style.left = 0\n      layer.style.top = 0\n\n      let depth = helpers.data(layer, 'depth') || 0\n      this.depthsX.push(helpers.data(layer, 'depth-x') || depth)\n      this.depthsY.push(helpers.data(layer, 'depth-y') || depth)\n    }\n  }\n\n  updateDimensions() {\n    this.windowWidth = window.innerWidth\n    this.windowHeight = window.innerHeight\n    this.windowCenterX = this.windowWidth * this.originX\n    this.windowCenterY = this.windowHeight * this.originY\n    this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX)\n    this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY)\n  }\n\n  updateBounds() {\n    this.bounds = this.inputElement.getBoundingClientRect()\n    this.elementPositionX = this.bounds.left\n    this.elementPositionY = this.bounds.top\n    this.elementWidth = this.bounds.width\n    this.elementHeight = this.bounds.height\n    this.elementCenterX = this.elementWidth * this.originX\n    this.elementCenterY = this.elementHeight * this.originY\n    this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX)\n    this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY)\n  }\n\n  queueCalibration(delay) {\n    clearTimeout(this.calibrationTimer)\n    this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay)\n  }\n\n  enable() {\n    if (this.enabled) {\n      return\n    }\n    this.enabled = true\n\n    if (this.orientationSupport) {\n      this.portrait = false\n      window.addEventListener('deviceorientation', this.onDeviceOrientation)\n      this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay)\n    } else if (this.motionSupport) {\n      this.portrait = false\n      window.addEventListener('devicemotion', this.onDeviceMotion)\n      this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay)\n    } else {\n      this.calibrationX = 0\n      this.calibrationY = 0\n      this.portrait = false\n      window.addEventListener('mousemove', this.onMouseMove)\n      this.doReadyCallback()\n    }\n\n    window.addEventListener('resize', this.onWindowResize)\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  disable() {\n    if (!this.enabled) {\n      return\n    }\n    this.enabled = false\n\n    if (this.orientationSupport) {\n      window.removeEventListener('deviceorientation', this.onDeviceOrientation)\n    } else if (this.motionSupport) {\n      window.removeEventListener('devicemotion', this.onDeviceMotion)\n    } else {\n      window.removeEventListener('mousemove', this.onMouseMove)\n    }\n\n    window.removeEventListener('resize', this.onWindowResize)\n    rqAnFr.cancel(this.raf)\n  }\n\n  calibrate(x, y) {\n    this.calibrateX = x === undefined ? this.calibrateX : x\n    this.calibrateY = y === undefined ? this.calibrateY : y\n  }\n\n  invert(x, y) {\n    this.invertX = x === undefined ? this.invertX : x\n    this.invertY = y === undefined ? this.invertY : y\n  }\n\n  friction(x, y) {\n    this.frictionX = x === undefined ? this.frictionX : x\n    this.frictionY = y === undefined ? this.frictionY : y\n  }\n\n  scalar(x, y) {\n    this.scalarX = x === undefined ? this.scalarX : x\n    this.scalarY = y === undefined ? this.scalarY : y\n  }\n\n  limit(x, y) {\n    this.limitX = x === undefined ? this.limitX : x\n    this.limitY = y === undefined ? this.limitY : y\n  }\n\n  origin(x, y) {\n    this.originX = x === undefined ? this.originX : x\n    this.originY = y === undefined ? this.originY : y\n  }\n\n  setInputElement(element) {\n    this.inputElement = element\n    this.updateDimensions()\n  }\n\n  setPosition(element, x, y) {\n    x = x.toFixed(this.precision) + 'px'\n    y = y.toFixed(this.precision) + 'px'\n    if (this.transform3DSupport) {\n      helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)')\n    } else if (this.transform2DSupport) {\n      helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')')\n    } else {\n      element.style.left = x\n      element.style.top = y\n    }\n  }\n\n  onOrientationTimer() {\n    if (this.orientationSupport && this.orientationStatus === 0) {\n      this.disable()\n      this.orientationSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onMotionTimer() {\n    if (this.motionSupport && this.motionStatus === 0) {\n      this.disable()\n      this.motionSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onCalibrationTimer() {\n    this.calibrationFlag = true\n  }\n\n  onWindowResize() {\n    this.updateDimensions()\n  }\n\n  onAnimationFrame() {\n    this.updateBounds()\n    let calibratedInputX = this.inputX - this.calibrationX,\n        calibratedInputY = this.inputY - this.calibrationY\n    if ((Math.abs(calibratedInputX) > this.calibrationThreshold) || (Math.abs(calibratedInputY) > this.calibrationThreshold)) {\n      this.queueCalibration(0)\n    }\n    if (this.portrait) {\n      this.motionX = this.calibrateX ? calibratedInputY : this.inputY\n      this.motionY = this.calibrateY ? calibratedInputX : this.inputX\n    } else {\n      this.motionX = this.calibrateX ? calibratedInputX : this.inputX\n      this.motionY = this.calibrateY ? calibratedInputY : this.inputY\n    }\n    this.motionX *= this.elementWidth * (this.scalarX / 100)\n    this.motionY *= this.elementHeight * (this.scalarY / 100)\n    if (!isNaN(parseFloat(this.limitX))) {\n      this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX)\n    }\n    if (!isNaN(parseFloat(this.limitY))) {\n      this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY)\n    }\n    this.velocityX += (this.motionX - this.velocityX) * this.frictionX\n    this.velocityY += (this.motionY - this.velocityY) * this.frictionY\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index],\n          depthX = this.depthsX[index],\n          depthY = this.depthsY[index],\n          xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)),\n          yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1))\n      this.setPosition(layer, xOffset, yOffset)\n    }\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  rotate(beta, gamma){\n    // Extract Rotation\n    let x = (beta || 0) / MAGIC_NUMBER, //  -90 :: 90\n        y = (gamma || 0) / MAGIC_NUMBER // -180 :: 180\n\n    // Detect Orientation Change\n    let portrait = this.windowHeight > this.windowWidth\n    if (this.portrait !== portrait) {\n      this.portrait = portrait\n      this.calibrationFlag = true\n    }\n\n    if (this.calibrationFlag) {\n      this.calibrationFlag = false\n      this.calibrationX = x\n      this.calibrationY = y\n    }\n\n    this.inputX = x\n    this.inputY = y\n  }\n\n  onDeviceOrientation(event) {\n    let beta = event.beta\n    let gamma = event.gamma\n    if (beta !== null && gamma !== null) {\n      this.orientationStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onDeviceMotion(event) {\n    let beta = event.rotationRate.beta\n    let gamma = event.rotationRate.gamma\n    if (beta !== null && gamma !== null) {\n      this.motionStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onMouseMove(event) {\n    let clientX = event.clientX,\n        clientY = event.clientY\n\n    // reset input to center if hoverOnly is set and we're not hovering the element\n    if(this.hoverOnly &&\n      ((clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth) ||\n      (clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight))) {\n        this.inputX = 0\n        this.inputY = 0\n        return\n      }\n\n    if (this.relativeInput) {\n      // Clip mouse coordinates inside element bounds.\n      if (this.clipRelativeInput) {\n        clientX = Math.max(clientX, this.elementPositionX)\n        clientX = Math.min(clientX, this.elementPositionX + this.elementWidth)\n        clientY = Math.max(clientY, this.elementPositionY)\n        clientY = Math.min(clientY, this.elementPositionY + this.elementHeight)\n      }\n      // Calculate input relative to the element.\n      if(this.elementRangeX && this.elementRangeY) {\n        this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX\n        this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY\n      }\n    } else {\n      // Calculate input relative to the window.\n      if(this.windowRadiusX && this.windowRadiusY) {\n        this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX\n        this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY\n      }\n    }\n  }\n\n  destroy() {\n    this.disable()\n\n    clearTimeout(this.calibrationTimer)\n    clearTimeout(this.detectionTimer)\n\n    this.element.removeAttribute('style')\n    for (let index = 0; index < this.layers.length; index++) {\n      this.layers[index].removeAttribute('style')\n    }\n\n    delete this.element\n    delete this.layers\n  }\n\n  version() {\n    return '3.1.0'\n  }\n\n}\n\nmodule.exports = Parallax\n"]} + +/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../webpack/buildin/global.js */ "./node_modules/webpack/buildin/global.js"))) + +/***/ }), + +/***/ "./node_modules/tslib/tslib.es6.js": +/*!*****************************************!*\ + !*** ./node_modules/tslib/tslib.es6.js ***! + \*****************************************/ +/*! exports provided: __extends, __assign, __rest, __decorate, __param, __metadata, __awaiter, __generator, __exportStar, __values, __read, __spread, __spreadArrays, __await, __asyncGenerator, __asyncDelegator, __asyncValues, __makeTemplateObject, __importStar, __importDefault */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__extends", function() { return __extends; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__assign", function() { return __assign; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__rest", function() { return __rest; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__decorate", function() { return __decorate; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__param", function() { return __param; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__metadata", function() { return __metadata; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__awaiter", function() { return __awaiter; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__generator", function() { return __generator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__exportStar", function() { return __exportStar; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__values", function() { return __values; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__read", function() { return __read; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__spread", function() { return __spread; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__spreadArrays", function() { return __spreadArrays; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__await", function() { return __await; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncGenerator", function() { return __asyncGenerator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncDelegator", function() { return __asyncDelegator; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__asyncValues", function() { return __asyncValues; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__makeTemplateObject", function() { return __makeTemplateObject; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__importStar", function() { return __importStar; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "__importDefault", function() { return __importDefault; }); +/*! ***************************************************************************** +Copyright (c) Microsoft Corporation. All rights reserved. +Licensed under the Apache License, Version 2.0 (the "License"); you may not use +this file except in compliance with the License. You may obtain a copy of the +License at http://www.apache.org/licenses/LICENSE-2.0 + +THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY +KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED +WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE, +MERCHANTABLITY OR NON-INFRINGEMENT. + +See the Apache Version 2.0 License for specific language governing permissions +and limitations under the License. +***************************************************************************** */ +/* global Reflect, Promise */ + +var extendStatics = function(d, b) { + extendStatics = Object.setPrototypeOf || + ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || + function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; + return extendStatics(d, b); +}; + +function __extends(d, b) { + extendStatics(d, b); + function __() { this.constructor = d; } + d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); +} + +var __assign = function() { + __assign = Object.assign || function __assign(t) { + for (var s, i = 1, n = arguments.length; i < n; i++) { + s = arguments[i]; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; + } + return t; + } + return __assign.apply(this, arguments); +} + +function __rest(s, e) { + var t = {}; + for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) + t[p] = s[p]; + if (s != null && typeof Object.getOwnPropertySymbols === "function") + for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { + if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) + t[p[i]] = s[p[i]]; + } + return t; +} + +function __decorate(decorators, target, key, desc) { + var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d; + if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc); + else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r; + return c > 3 && r && Object.defineProperty(target, key, r), r; +} + +function __param(paramIndex, decorator) { + return function (target, key) { decorator(target, key, paramIndex); } +} + +function __metadata(metadataKey, metadataValue) { + if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue); +} + +function __awaiter(thisArg, _arguments, P, generator) { + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +} + +function __generator(thisArg, body) { + var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g; + return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g; + function verb(n) { return function (v) { return step([n, v]); }; } + function step(op) { + if (f) throw new TypeError("Generator is already executing."); + while (_) try { + if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t; + if (y = 0, t) op = [op[0] & 2, t.value]; + switch (op[0]) { + case 0: case 1: t = op; break; + case 4: _.label++; return { value: op[1], done: false }; + case 5: _.label++; y = op[1]; op = [0]; continue; + case 7: op = _.ops.pop(); _.trys.pop(); continue; + default: + if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; } + if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; } + if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; } + if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; } + if (t[2]) _.ops.pop(); + _.trys.pop(); continue; + } + op = body.call(thisArg, _); + } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; } + if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true }; + } +} + +function __exportStar(m, exports) { + for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p]; +} + +function __values(o) { + var m = typeof Symbol === "function" && o[Symbol.iterator], i = 0; + if (m) return m.call(o); + return { + next: function () { + if (o && i >= o.length) o = void 0; + return { value: o && o[i++], done: !o }; + } + }; +} + +function __read(o, n) { + var m = typeof Symbol === "function" && o[Symbol.iterator]; + if (!m) return o; + var i = m.call(o), r, ar = [], e; + try { + while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value); + } + catch (error) { e = { error: error }; } + finally { + try { + if (r && !r.done && (m = i["return"])) m.call(i); + } + finally { if (e) throw e.error; } + } + return ar; +} + +function __spread() { + for (var ar = [], i = 0; i < arguments.length; i++) + ar = ar.concat(__read(arguments[i])); + return ar; +} + +function __spreadArrays() { + for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length; + for (var r = Array(s), k = 0, i = 0; i < il; i++) + for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++) + r[k] = a[j]; + return r; +}; + +function __await(v) { + return this instanceof __await ? (this.v = v, this) : new __await(v); +} + +function __asyncGenerator(thisArg, _arguments, generator) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var g = generator.apply(thisArg, _arguments || []), i, q = []; + return i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i; + function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; } + function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } } + function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); } + function fulfill(value) { resume("next", value); } + function reject(value) { resume("throw", value); } + function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); } +} + +function __asyncDelegator(o) { + var i, p; + return i = {}, verb("next"), verb("throw", function (e) { throw e; }), verb("return"), i[Symbol.iterator] = function () { return this; }, i; + function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === "return" } : f ? f(v) : v; } : f; } +} + +function __asyncValues(o) { + if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined."); + var m = o[Symbol.asyncIterator], i; + return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i); + function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; } + function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); } +} + +function __makeTemplateObject(cooked, raw) { + if (Object.defineProperty) { Object.defineProperty(cooked, "raw", { value: raw }); } else { cooked.raw = raw; } + return cooked; +}; + +function __importStar(mod) { + if (mod && mod.__esModule) return mod; + var result = {}; + if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k]; + result.default = mod; + return result; +} + +function __importDefault(mod) { + return (mod && mod.__esModule) ? mod : { default: mod }; +} + + +/***/ }), + +/***/ "./node_modules/webpack/buildin/global.js": +/*!***********************************!*\ + !*** (webpack)/buildin/global.js ***! + \***********************************/ +/*! no static exports found */ +/***/ (function(module, exports) { + +var g; + +// This works in non-strict mode +g = (function() { + return this; +})(); + +try { + // This works if eval is allowed (see CSP) + g = g || new Function("return this")(); +} catch (e) { + // This works if the window reference is available + if (typeof window === "object") g = window; +} + +// g can still be undefined, but nothing to do about it... +// We return undefined, instead of nothing here, so it's +// easier to handle this case. if(!global) { ...} + +module.exports = g; + + +/***/ }), + +/***/ "./src/scss/index.scss": +/*!*****************************!*\ + !*** ./src/scss/index.scss ***! + \*****************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +module.exports = __webpack_require__.p + "bundle.css"; + +/***/ }), + +/***/ "./src/ts/components/mdcConf.ts": +/*!**************************************!*\ + !*** ./src/ts/components/mdcConf.ts ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _material_ripple__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @material/ripple */ "./node_modules/@material/ripple/index.js"); +/* harmony import */ var _material_textfield__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @material/textfield */ "./node_modules/@material/textfield/index.js"); +/* harmony import */ var _material_top_app_bar__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @material/top-app-bar */ "./node_modules/@material/top-app-bar/index.js"); +/** + * Copyright 2019 Mashiro + * @description material-components initial configuration + * @author Mashiro + * @license MIT + */ + + + +const Conf = [['.mdc-top-app-bar', _material_top_app_bar__WEBPACK_IMPORTED_MODULE_2__["MDCTopAppBar"]], ['.mdc-text-field', _material_textfield__WEBPACK_IMPORTED_MODULE_1__["MDCTextField"]], [['.mdc-button', '.primary-action'], _material_ripple__WEBPACK_IMPORTED_MODULE_0__["MDCRipple"]]]; +/* harmony default export */ __webpack_exports__["default"] = (Conf); + +/***/ }), + +/***/ "./src/ts/components/mdcInit.ts": +/*!**************************************!*\ + !*** ./src/ts/components/mdcInit.ts ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _mdcConf__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./mdcConf */ "./src/ts/components/mdcConf.ts"); +/** + * Copyright 2019 Mashiro + * @description material-components initial handler + * @author Mashiro + * @license MIT + */ + +const Conf = _mdcConf__WEBPACK_IMPORTED_MODULE_0__["default"]; +/** + * Initial [material-components-web](https://github.com/material-components/material-components-web/) + * through configuration in `mdcConf.ts``. + * See + */ + +/* harmony default export */ __webpack_exports__["default"] = (function () { + let components = []; + + for (const i of Conf) { + if (typeof i[0] == 'string') { + const component = i[0]; + const constructor = i[1]; + components.map.call(document.querySelectorAll(component), function (e) { + return new constructor(e); + }); + } else if (typeof i[0] == 'object') { + const component = i[0].join(','); + const constructor = i[1]; + components.map.call(document.querySelectorAll(component), function (e) { + return new constructor(e); + }); + } + } +}); + +/***/ }), + +/***/ "./src/ts/index.ts": +/*!*************************!*\ + !*** ./src/ts/index.ts ***! + \*************************/ +/*! no exports provided */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _modules_coverImgInit__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./modules/coverImgInit */ "./src/ts/modules/coverImgInit.ts"); +/* harmony import */ var _modules_headerBarScrollHandler__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./modules/headerBarScrollHandler */ "./src/ts/modules/headerBarScrollHandler.ts"); +/* harmony import */ var _components_mdcInit__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./components/mdcInit */ "./src/ts/components/mdcInit.ts"); +/** + * Copyright 2019 Mashiro + * @description Main + * @author Mashiro + * @license MIT + */ + + + + +window.onscroll = function () { + Object(_modules_headerBarScrollHandler__WEBPACK_IMPORTED_MODULE_1__["default"])(); +}; + +window.onload = function () { + Object(_modules_coverImgInit__WEBPACK_IMPORTED_MODULE_0__["default"])(); + Object(_components_mdcInit__WEBPACK_IMPORTED_MODULE_2__["default"])(); +}; + +/***/ }), + +/***/ "./src/ts/modules/coverImgInit.ts": +/*!****************************************!*\ + !*** ./src/ts/modules/coverImgInit.ts ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var parallax_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! parallax-js */ "./node_modules/parallax-js/dist/parallax.js"); +/* harmony import */ var parallax_js__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(parallax_js__WEBPACK_IMPORTED_MODULE_0__); +/** + * Copyright 2019 Mashiro + * @description Sakura theme module + * @author Mashiro + * @license MIT + */ + +/** + * Initial index cover image and image box. + * Include Parallax box initial and `#cover-img-container` size initial. + */ + +/* harmony default export */ __webpack_exports__["default"] = (function () { + let coverImgContainer = document.querySelector("#cover-img-container"); + coverImgContainer.style.height = `${window.innerHeight}px`; + let headerTopAfter = document.querySelector("#header-top-after"); + headerTopAfter.style.height = `${window.innerHeight}px`; + + /** + * cover: `img#cover-img` + */ + let coverImg = {}; + /** + * mark: `figure#cover-img-container` + */ + + let coverBox = {}; + /** + * layer: `div#img-view` + */ + + let coverView = {}; + coverImg.e = document.querySelector("#cover-img"); + coverImg.w = coverImg.e.naturalWidth; + coverImg.h = coverImg.e.naturalHeight; + coverBox.e = document.querySelector("#cover-img-container"); + coverBox.w = coverBox.e.offsetWidth; + coverBox.h = coverBox.e.offsetHeight; + coverView.e = document.querySelector("#img-view"); + coverBox.e.style.height = `${window.innerHeight}px`; + coverBox.f = coverBox.w >= 1000 || coverBox.h >= 1000 ? 1000 : 500; + + if (coverBox.w >= coverBox.h) { + coverBox.i = coverBox.w / coverBox.f * 50; + coverBox.y = coverBox.i; + coverBox.x = coverBox.i * coverBox.w / coverBox.h; + } else { + coverBox.i = coverBox.h / coverBox.f * 50; + coverBox.x = coverBox.i; + coverBox.y = coverBox.i * coverBox.h / coverBox.w; + } + + coverView.e.style.cssText = ` + width: ${coverBox.w + coverBox.x}px; + height: ${coverBox.h + coverBox.y}px; + margin-left: ${-0.5 * coverBox.x}px; + margin-top: ${-0.5 * coverBox.y}px`; + coverImg.e.style.cssText = ` + width: ${coverView.w + coverView.x}px; + height: ${coverView.h + coverView.y}px`; + + if (!coverImg.w) { + coverImg.w = coverImg.e.offsetWidth; + coverImg.h = coverImg.e.offsetHeight; + } + + coverImg._w = coverImg.e.parentElement.offsetWidth; + coverImg._h = coverImg.e.parentElement.offsetHeight; + coverImg.ratio = coverImg.h / coverImg.w; + + if (coverImg._h / coverImg._w > coverImg.ratio) { + coverImg.e.style.height = coverImg._h + 'px'; + coverImg.e.style.width = coverImg._h / coverImg.ratio + 'px'; + } else { + coverImg.e.style.width = coverImg._w + 'px'; + coverImg.e.style.height = coverImg._w * coverImg.ratio + 'px'; + } + + coverImg.e.style.left = (coverImg._w - parseInt(coverImg.e.style.width)) / 2 + 'px'; + coverImg.e.style.top = (coverImg._h - parseInt(coverImg.e.style.height)) / 2 + 'px'; + let scene = document.querySelector('#cover-img-container'); + let parallaxInstance = new parallax_js__WEBPACK_IMPORTED_MODULE_0___default.a(scene); +}); + +/***/ }), + +/***/ "./src/ts/modules/headerBarScrollHandler.ts": +/*!**************************************************!*\ + !*** ./src/ts/modules/headerBarScrollHandler.ts ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _scrollDirection__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./scrollDirection */ "./src/ts/modules/scrollDirection.ts"); +/** + * @description Sakura theme module + * @author Mashiro + * @since 19/10/31 + * @license MIT + */ + +/** + * Site top bar handler when page scroll + */ + +/* harmony default export */ __webpack_exports__["default"] = (function () { + let ele = document.querySelector("#nav-header"); + + if (Object(_scrollDirection__WEBPACK_IMPORTED_MODULE_0__["default"])('y') == 'down') { + ele.style.top = `-120px`; + } else if (Object(_scrollDirection__WEBPACK_IMPORTED_MODULE_0__["default"])('y') == 'up') { + ele.style.top = `0px`; + } +}); + +/***/ }), + +/***/ "./src/ts/modules/scrollDirection.ts": +/*!*******************************************!*\ + !*** ./src/ts/modules/scrollDirection.ts ***! + \*******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/** + * @description Sakura theme module + * @author Mashiro + * @since 19/10/31 + * @license MIT + */ +let scrollAction = { + x: undefined, + y: undefined, + d: undefined +}; +/** + * Detect window scroll direction + * @param {string} direction option: `Y`/`y` - horizontal; `X`/`x` - vertical + * @return {string} return window scroll direction + */ + +/* harmony default export */ __webpack_exports__["default"] = (function (direction) { + if (scrollAction.x == undefined) { + scrollAction.x = window.pageXOffset; + scrollAction.y = window.pageYOffset; + } + + let diffX = scrollAction.x - window.pageXOffset; + let diffY = scrollAction.y - window.pageYOffset; + + if (direction == 'x' || direction == 'X') { + if (diffX < 0) { + scrollAction.d = 'right'; + } else if (diffX > 0) { + scrollAction.d = 'left'; + } + } else { + if (diffY < 0) { + scrollAction.d = 'down'; + } else if (diffY > 0) { + scrollAction.d = 'up'; + } + } + + scrollAction.x = window.pageXOffset; + scrollAction.y = window.pageYOffset; + return scrollAction.d; +}); + +/***/ }), + +/***/ 0: +/*!*****************************************************!*\ + !*** multi ./src/scss/index.scss ./src/ts/index.ts ***! + \*****************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { + +__webpack_require__(/*! ./src/scss/index.scss */"./src/scss/index.scss"); +module.exports = __webpack_require__(/*! ./src/ts/index.ts */"./src/ts/index.ts"); + + +/***/ }) + +/******/ }); +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/bootstrap","webpack:///./node_modules/@material/base/component.js","webpack:///./node_modules/@material/base/foundation.js","webpack:///./node_modules/@material/dom/events.js","webpack:///./node_modules/@material/dom/ponyfill.js","webpack:///./node_modules/@material/floating-label/component.js","webpack:///./node_modules/@material/floating-label/constants.js","webpack:///./node_modules/@material/floating-label/foundation.js","webpack:///./node_modules/@material/line-ripple/component.js","webpack:///./node_modules/@material/line-ripple/constants.js","webpack:///./node_modules/@material/line-ripple/foundation.js","webpack:///./node_modules/@material/notched-outline/component.js","webpack:///./node_modules/@material/notched-outline/constants.js","webpack:///./node_modules/@material/notched-outline/foundation.js","webpack:///./node_modules/@material/ripple/component.js","webpack:///./node_modules/@material/ripple/constants.js","webpack:///./node_modules/@material/ripple/foundation.js","webpack:///./node_modules/@material/ripple/index.js","webpack:///./node_modules/@material/ripple/util.js","webpack:///./node_modules/@material/textfield/character-counter/component.js","webpack:///./node_modules/@material/textfield/character-counter/constants.js","webpack:///./node_modules/@material/textfield/character-counter/foundation.js","webpack:///./node_modules/@material/textfield/character-counter/index.js","webpack:///./node_modules/@material/textfield/component.js","webpack:///./node_modules/@material/textfield/constants.js","webpack:///./node_modules/@material/textfield/foundation.js","webpack:///./node_modules/@material/textfield/helper-text/component.js","webpack:///./node_modules/@material/textfield/helper-text/constants.js","webpack:///./node_modules/@material/textfield/helper-text/foundation.js","webpack:///./node_modules/@material/textfield/helper-text/index.js","webpack:///./node_modules/@material/textfield/icon/component.js","webpack:///./node_modules/@material/textfield/icon/constants.js","webpack:///./node_modules/@material/textfield/icon/foundation.js","webpack:///./node_modules/@material/textfield/icon/index.js","webpack:///./node_modules/@material/textfield/index.js","webpack:///./node_modules/@material/top-app-bar/component.js","webpack:///./node_modules/@material/top-app-bar/constants.js","webpack:///./node_modules/@material/top-app-bar/fixed/foundation.js","webpack:///./node_modules/@material/top-app-bar/foundation.js","webpack:///./node_modules/@material/top-app-bar/index.js","webpack:///./node_modules/@material/top-app-bar/short/foundation.js","webpack:///./node_modules/@material/top-app-bar/standard/foundation.js","webpack:///./node_modules/parallax-js/dist/parallax.js","webpack:///./node_modules/tslib/tslib.es6.js","webpack:///(webpack)/buildin/global.js","webpack:///./src/scss/index.scss","webpack:///./src/ts/components/mdcConf.ts","webpack:///./src/ts/components/mdcInit.ts","webpack:///./src/ts/index.ts","webpack:///./src/ts/modules/coverImgInit.ts","webpack:///./src/ts/modules/headerBarScrollHandler.ts","webpack:///./src/ts/modules/scrollDirection.ts"],"names":["Conf","MDCTopAppBar","MDCTextField","MDCRipple","mdcConf","components","i","component","constructor","map","call","document","querySelectorAll","e","join","window","onscroll","headerBarScrollHandler","onload","coverImgIni","mdcInit","coverImgContainer","querySelector","style","height","innerHeight","headerTopAfter","coverImg","coverBox","coverView","w","naturalWidth","h","naturalHeight","offsetWidth","offsetHeight","f","y","x","cssText","_w","parentElement","_h","ratio","width","left","parseInt","top","scene","parallaxInstance","Parallax","ele","scrollDirection","scrollAction","undefined","d","direction","pageXOffset","pageYOffset","diffX","diffY"],"mappings":";QAAA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;;QAEA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;;;QAGA;QACA;;QAEA;QACA;;QAEA;QACA;QACA;QACA,0CAA0C,gCAAgC;QAC1E;QACA;;QAEA;QACA;QACA;QACA,wDAAwD,kBAAkB;QAC1E;QACA,iDAAiD,cAAc;QAC/D;;QAEA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA;QACA,yCAAyC,iCAAiC;QAC1E,gHAAgH,mBAAmB,EAAE;QACrI;QACA;;QAEA;QACA;QACA;QACA,2BAA2B,0BAA0B,EAAE;QACvD,iCAAiC,eAAe;QAChD;QACA;QACA;;QAEA;QACA,sDAAsD,+DAA+D;;QAErH;QACA;;;QAGA;QACA;;;;;;;;;;;;;AClFA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACY;AAC7C;AACA;AACA;AACA,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA,oCAAoC,8CAAgB;AACpD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kFAAkF;AAClF;AACA,0CAA0C,yDAAa,GAAG;AAC1D;AACA,0EAA0E;AAC1E;AACA;AACA,wBAAwB,uBAAuB;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,sBAAsB;AAC5D;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACuB;AACxB;AACe,2EAAY,EAAC;AAC5B,qC;;;;;;;;;;;;ACrGA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,cAAc;AAC/C;AACA;AACA;AACA;AACA;AACA,yEAAyE;AACzE;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,oDAAoD;AACpD;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,2DAA2D;AAC3D;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACwB;AACzB;AACe,4EAAa,EAAC;AAC7B,sC;;;;;;;;;;;;AC3EA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,+BAA+B,oBAAoB;AACnD,kCAAkC,sBAAsB;AACxD;AACA;AACA;AACA,qEAAqE,kBAAkB,EAAE;AACzF;AACA;AACA;AACA,iBAAiB;AACjB,aAAa;AACb;AACA;AACA,SAAS;AACT;AACA;AACA,+BAA+B,gBAAgB;AAC/C;AACA,kC;;;;;;;;;;;;AClDA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA,oC;;;;;;;;;;;;AC7CA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACE;AAC1D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA,0EAA0E;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,mCAAmC,gCAAgC,EAAE;AACrE,qEAAqE,uCAAuC,EAAE;AAC9G,uEAAuE,yCAAyC,EAAE;AAClH;AACA;AACA,mBAAmB,sEAA0B;AAC7C;AACA;AACA,CAAC,CAAC,qEAAY;AACc;AAC5B,qC;;;;;;;;;;;;ACpEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,qC;;;;;;;;;;;;AC3BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACjB;AACzC;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD,uDAAuD,yCAAyC;AAChG;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,8BAA8B;AAC9C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,UAAU,EAAE;AACnD,yDAAyD,kBAAkB,EAAE;AAC7E,2DAA2D,kBAAkB,EAAE;AAC/E;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACuB;AACtC;AACe,yFAA0B,EAAC;AAC1C,sC;;;;;;;;;;;;ACzGA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACD;AACvD;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,4CAA4C,kDAAkD,EAAE;AAChG,sDAAsD,2DAA2D,EAAE;AACnH,+DAA+D,uCAAuC,EAAE;AACxG,iEAAiE,yCAAyC,EAAE;AAC5G;AACA;AACA,mBAAmB,mEAAuB;AAC1C;AACA;AACA,CAAC,CAAC,qEAAY;AACW;AACzB,qC;;;;;;;;;;;;ACvEA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACsB;AACtB,qC;;;;;;;;;;;;AC3BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACjB;AACzC;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD,sDAAsD,uCAAuC;AAC7F;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,2BAA2B;AAC3C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,cAAc,EAAE;AACvD,uCAAuC,kBAAkB,EAAE;AAC3D,mDAAmD,kBAAkB,EAAE;AACvE,qDAAqD,kBAAkB,EAAE;AACzE;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qDAAU;AAC5C,+BAA+B,qDAAU;AACzC;AACA;AACA;AACA;AACA;AACA,+BAA+B,qDAAU;AACzC;AACA;AACA;AACA;AACA,oDAAoD,qDAAU;AAC9D;AACA;AACA,0CAA0C,qDAAU;AACpD,0CAA0C,qDAAU;AACpD;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACoB;AACnC;AACe,sFAAuB,EAAC;AACvC,sC;;;;;;;;;;;;AC1FA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACyB;AAC/B;AACS;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD,kDAAO;AAC7D,mDAAmD,8FAA0B;AAC7E;AACA;AACA,qCAAqC,qDAAU;AAC/C;AACA;AACA,aAAa;AACb;AACA;AACA,qCAAqC,qDAAU;AAC/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,qDAAqD,qEAAqE,EAAE;AAC5H,mDAAmD,0DAA0D,EAAE;AAC/G;AACA;AACA,mBAAmB,uEAA2B;AAC9C;AACA;AACA,CAAC,CAAC,qEAAY;AACe;AAC7B,qC;;;;;;;;;;;;AC/EA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACwC;AACxC,qC;;;;;;;;;;;;ACnCA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACC;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,+BAA+B;AAC/C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,oDAAoD,kBAAkB,EAAE;AACxE,uDAAuD,kBAAkB,EAAE;AAC3E;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,kDAAO,uBAAuB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACwB;AACvC;AACe,0FAA2B,EAAC;AAC3C,sC;;;;;;;;;;;;AC5FA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACJ;AACH;AACE;AACpB;AAC/B;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,SAAS,0BAA0B;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,gDAAgD,EAAE;AAC9F,iDAAiD,QAAQ,0DAAyB,SAAS,EAAE;AAC7F,8CAA8C,+CAA+C,EAAE;AAC/F,oDAAoD,wCAAwC,EAAE;AAC9F;AACA,sFAAsF,yEAAY;AAClG,aAAa;AACb;AACA,4EAA4E,yEAAY;AACxF,aAAa;AACb,yDAAyD,sDAAsD,EAAE;AACjH,8CAA8C,UAAU,+CAA+C,EAAE,EAAE;AAC3G,0CAA0C,QAAQ,sEAAO,4BAA4B,EAAE;AACvF,4CAA4C,mCAAmC,EAAE;AACjF,sCAAsC,oCAAoC,EAAE;AAC5E;AACA,mFAAmF,yEAAY;AAC/F,aAAa;AACb;AACA,yEAAyE,yEAAY;AACrF,aAAa;AACb,uDAAuD,mDAAmD,EAAE;AAC5G,+CAA+C,mDAAmD,EAAE;AACpG,0DAA0D,yDAAyD,EAAE;AACrH;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,+DAAmB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,qEAAY;AACO;AACrB,qC;;;;;;;;;;;;AC/GA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,qC;;;;;;;;;;;;AC/CA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACC;AACT;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD;AACA;AACA;AACA;AACA,wBAAwB;AACxB;AACA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;AACA;AACA;AACA,+CAA+C,2BAA2B;AAC1E,gDAAgD,4BAA4B;AAC5E,2CAA2C,4BAA4B;AACvE,0CAA0C,2BAA2B;AACrE,4CAA4C,uBAAuB;AACnE;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,qDAAqD,aAAa,EAAE;AACpE,kDAAkD,UAAU,4DAA4D,EAAE,EAAE;AAC5H,kDAAkD,aAAa,EAAE;AACjE,mEAAmE,kBAAkB,EAAE;AACvF,2DAA2D,kBAAkB,EAAE;AAC/E,sDAAsD,kBAAkB,EAAE;AAC1E,kDAAkD,UAAU,aAAa,EAAE,EAAE;AAC7E,8CAA8C,aAAa,EAAE;AAC7D,gDAAgD,aAAa,EAAE;AAC/D,0CAA0C,aAAa,EAAE;AACzD,iEAAiE,kBAAkB,EAAE;AACrF,yDAAyD,kBAAkB,EAAE;AAC7E,oDAAoD,kBAAkB,EAAE;AACxE,0CAA0C,kBAAkB,EAAE;AAC9D,gDAAgD,kBAAkB,EAAE;AACpE;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6HAA6H,mDAAmD,EAAE;AAClL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wDAAwD,yCAAyC,EAAE;AACnG;AACA;AACA;AACA;AACA;AACA,yBAAyB,sEAAwB;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,EAAE,kDAAO;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,mDAAmD,EAAE;AACrF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,8CAAgB,GAAG;AACvC;AACA,+CAA+C,0CAA0C,EAAE;AAC3F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACgB;AAC/B;AACe,kFAAmB,EAAC;AACnC,sC;;;;;;;;;;;;AC5cA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AACf;AACY;AACA;AACC;AAC7B,iC;;;;;;;;;;;;AC3BA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,kCAAkC,sBAAsB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,gBAAgB;AAChB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA,gC;;;;;;;;;;;;AC1EA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACc;AACtE;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,mBAAmB,kFAAsC;AACzD;AACA;AACA,CAAC,CAAC,qEAAY;AAC0B;AACxC,qC;;;;;;;;;;;;ACtDA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AAC/B,qC;;;;;;;;;;;;AC7BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACR;AAClD;AACA,IAAI,+CAAiB;AACrB;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,0CAA0C;AAC1D;AACA;AACA;AACA,yCAAyC,kBAAkB,EAAE;AAC7D;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACmC;AAClD;AACe,qGAAsC,EAAC;AACtD,sC;;;;;;;;;;;;ACjEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACC;AAC0E;AACvG,iC;;;;;;;;;;;;ACzBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACJ;AACD;AACmB;AACN;AACQ;AACjB;AACW;AACY;AACU;AACtC;AACI;AACY;AACU;AACxB;AACpD;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,4CAA4C,YAAY,oEAAS,iBAAiB,GAAG;AAC5H,2CAA2C,oCAAoC,YAAY,6EAAa,KAAK,GAAG;AAChH,2CAA2C,oCAAoC,YAAY,8EAAsB,KAAK,GAAG;AACzH,iDAAiD,0CAA0C,YAAY,yFAA4B,KAAK,GAAG;AAC3I,qCAAqC,8BAA8B,YAAY,iEAAgB,KAAK,GAAG;AACvG,sCAAsC,+BAA+B,YAAY,mFAAgB,KAAK,GAAG;AACzG,wCAAwC,iCAAiC,YAAY,qFAAiB,KAAK,GAAG;AAC9G,+CAA+C,mDAAO;AACtD,oDAAoD,mDAAO;AAC3D;AACA,yDAAyD,mDAAO;AAChE;AACA,sDAAsD,mDAAO;AAC7D;AACA;AACA,gCAAgC,yFAAgC;AAChE;AACA,yFAAyF,sDAAU;AACnG;AACA;AACA;AACA,sCAAsC,qGAAsC;AAC5E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,mDAAO;AAC9D;AACA,0CAA0C;AAC1C;AACA;AACA;AACA;AACA,kDAAkD,sDAAU;AAC5D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,8CAAgB,GAAG;AACzC;AACA,mBAAmB,mEAAsB;AACzC;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,4CAA4C,kDAAkD,EAAE;AAChG,8EAA8E,uCAAuC,EAAE;AACvH,gFAAgF,yCAAyC,EAAE;AAC3H;AACA;AACA;AACA,kDAAkD,+BAA+B,EAAE;AACnF,0DAA0D,sBAAsB,EAAE;AAClF;AACA,8EAA8E,kDAAkD,EAAE;AAClI,8BAA8B;AAC9B;AACA;AACA,aAAa;AACb,6EAA6E,8BAA8B,EAAE;AAC7G;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yCAAyC,qBAAqB,EAAE;AAChE,oCAAoC,gDAAgD,EAAE;AACtF;AACA,uEAAuE,yEAAY;AACnF,aAAa;AACb;AACA,0EAA0E,yEAAY;AACtF,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,wDAAwD,EAAE;AAC1G,wCAAwC,mDAAmD,EAAE;AAC7F,mCAAmC,8BAA8B,EAAE;AACnE,gDAAgD,wDAAwD,EAAE;AAC1G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,uCAAuC,sDAAsD,EAAE;AAC/F,qCAAqC,gCAAgC,EAAE;AACvE,iDAAiD,2DAA2D,EAAE;AAC9G;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uDAAuD,sDAAU;AACjE,uDAAuD,sDAAU;AACjE;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,8CAAgB,GAAG,EAAE,oEAAS,uBAAuB,+BAA+B,QAAQ,8DAAgB,0BAA0B,EAAE,2DAA2D,wDAAwD,yEAAY,IAAI,EAAE;AACnS,0EAA0E,yEAAY;AACtF,aAAa,EAAE;AACf;AACA,6CAA6C,+EAAmB;AAChE;AACA;AACA,CAAC,CAAC,qEAAY;AACU;AACxB,qC;;;;;;;;;;;;ACpcA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACuF;AACvF,qC;;;;;;;;;;;;AC9DA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACgD;AAC1G;AACA;AACA;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA,uCAAuC,oBAAoB;AAC3D,sCAAsC,8CAAgB,GAAG;AACzD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,8BAA8B;AAC9E,+CAA+C,gCAAgC;AAC/E,gDAAgD,4BAA4B;AAC5E,mDAAmD,sCAAsC;AACzF,0DAA0D,2CAA2C;AACrG,6EAA6E,8DAA8D;AAC3I;AACA;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,mBAAmB,6DAAkB;AACrC,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,0BAA0B;AAC1C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,aAAa,EAAE;AACtD,kEAAkE,kBAAkB,EAAE;AACtF,oEAAoE,kBAAkB,EAAE;AACxF,8DAA8D,kBAAkB,EAAE;AAClF,gEAAgE,kBAAkB,EAAE;AACpF,uEAAuE,0CAA0C,kBAAkB,EAAE,EAAE,EAAE;AACzI,yEAAyE,kBAAkB,EAAE;AAC7F,6CAA6C,aAAa,EAAE;AAC5D,wCAAwC,cAAc,EAAE;AACxD,iDAAiD,kBAAkB,EAAE;AACrE,mDAAmD,kBAAkB,EAAE;AACvE,2DAA2D,kBAAkB,EAAE;AAC/E,yCAAyC,kBAAkB,EAAE;AAC7D,yCAAyC,kBAAkB,EAAE;AAC7D,uCAAuC,cAAc,EAAE;AACvD,4CAA4C,UAAU,EAAE;AACxD,yCAAyC,cAAc,EAAE;AACzD,2CAA2C,kBAAkB,EAAE;AAC/D,2CAA2C,kBAAkB,EAAE;AAC/D;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,oEAAyB;AACzC;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD,qDAAU;AAC3D,uCAAuC,kDAAO,qBAAqB,kDAAO;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAiD;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACmB;AAClC;AACe,qFAAsB,EAAC;AACtC,sC;;;;;;;;;;;;AC3cA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACQ;AAChE;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,4CAA4C,kDAAkD,EAAE;AAChG,6CAA6C,8CAA8C,EAAE;AAC7F,yCAAyC,0CAA0C,EAAE;AACrF;AACA;AACA,aAAa;AACb;AACA;AACA,mBAAmB,4EAAgC;AACnD;AACA;AACA,CAAC,CAAC,qEAAY;AACoB;AAClC,qC;;;;;;;;;;;;AC7DA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AAC/B,qC;;;;;;;;;;;;ACjCA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACR;AAClD;AACA,IAAI,+CAAiB;AACrB;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,oCAAoC;AACpD;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,cAAc,EAAE;AACvD,sCAAsC,kBAAkB,EAAE;AAC1D,yCAAyC,kBAAkB,EAAE;AAC7D,yCAAyC,kBAAkB,EAAE;AAC7D;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,qDAAU;AAC7C;AACA;AACA,sCAAsC,qDAAU;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,qDAAU;AAC7C;AACA;AACA,sCAAsC,qDAAU;AAChD;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,kDAAO;AACxC;AACA;AACA;AACA;AACA;AACA,4DAA4D,qDAAU;AACtE,+DAA+D,qDAAU;AACzE;AACA;AACA,kCAAkC,kDAAO;AACzC;AACA;AACA,qCAAqC,kDAAO;AAC5C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8BAA8B,kDAAO;AACrC;AACA;AACA,CAAC,CAAC,uEAAa;AAC6B;AAC5C;AACe,+FAAgC,EAAC;AAChD,sC;;;;;;;;;;;;AC7HA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACC;AACkE;AAC/F,iC;;;;;;;;;;;;ACzBA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACE;AAC1D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,uCAAuC,EAAE;AAC/E,6CAA6C,8CAA8C,EAAE;AAC7F,yCAAyC,0CAA0C,EAAE;AACrF;AACA;AACA,aAAa;AACb,qEAAqE,uCAAuC,EAAE;AAC9G,uEAAuE,yCAAyC,EAAE;AAClH,2CAA2C,mBAAmB,sEAA0B,uBAAuB,yCAAyC,EAAE;AAC1J;AACA;AACA,mBAAmB,sEAA0B;AAC7C;AACA;AACA,CAAC,CAAC,qEAAY;AACc;AAC5B,qC;;;;;;;;;;;;AC9DA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC+B;AAC/B,qC;;;;;;;;;;;;AC9BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACR;AAClD;AACA;AACA,IAAI,+CAAiB;AACrB;AACA,sCAAsC,8CAAgB,GAAG;AACzD;AACA,oDAAoD,qCAAqC;AACzF;AACA;AACA;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,8BAA8B;AAC9C;AACA;AACA;AACA;AACA,sCAAsC,aAAa,EAAE;AACrD,sCAAsC,kBAAkB,EAAE;AAC1D,yCAAyC,kBAAkB,EAAE;AAC7D,yCAAyC,kBAAkB,EAAE;AAC7D,yDAAyD,kBAAkB,EAAE;AAC7E,2DAA2D,kBAAkB,EAAE;AAC/E,+CAA+C,kBAAkB,EAAE;AACnE;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,kDAAO;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACuB;AACtC;AACe,yFAA0B,EAAC;AAC1C,sC;;;;;;;;;;;;AC/GA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACC;AACsD;AACnF,iC;;;;;;;;;;;;ACzBA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACA;AACC;AACa;AACN;AACP;AAC7B,iC;;;;;;;;;;;;AC5BA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACuB;AACD;AACL;AACe;AACA;AACF;AAC/D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uCAAuC,gCAAgC,QAAQ,oEAAS,cAAc,GAAG;AACzG,iDAAiD,kDAAO;AACxD;AACA,8DAA8D,kDAAO;AACrE;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oDAAoD,qDAAU;AAC9D,oDAAoD,qDAAU;AAC9D;AACA;AACA;AACA;AACA;AACA,yDAAyD,6BAA6B,EAAE;AACxF;AACA;AACA;AACA;AACA,oDAAoD,qDAAU;AAC9D,oDAAoD,qDAAU;AAC9D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,4CAA4C,kDAAkD,EAAE;AAChG,4CAA4C,6CAA6C,EAAE;AAC3F,+CAA+C,gDAAgD,EAAE;AACjG,kDAAkD,uDAAuD,EAAE;AAC3G,6CAA6C,iCAAiC,EAAE;AAChF,sDAAsD,mBAAmB,kDAAO,qBAAqB,EAAE,EAAE;AACzG;AACA;AACA;AACA;AACA,aAAa;AACb,8CAA8C,qCAAqC,kDAAO,8BAA8B,EAAE;AAC1H;AACA;AACA;AACA,0CAA0C,qDAAU;AACpD,6BAA6B,6EAA2B;AACxD;AACA,+CAA+C,qDAAU;AACzD,6BAA6B,6EAA2B;AACxD;AACA;AACA,6BAA6B,2EAAsB;AACnD;AACA;AACA;AACA;AACA,CAAC,CAAC,qEAAY;AACU;AACxB,qC;;;;;;;;;;;;AC3HA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACwC;AACxC,qC;;;;;;;;;;;;ACzCA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACS;AACsB;AAChE;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,qDAAU;AACpD;AACA;AACA;AACA;AACA;AACA,uCAAuC,qDAAU;AACjD;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,2EAAsB;AACe;AACvC;AACe,0FAA2B,EAAC;AAC3C,sC;;;;;;;;;;;;AC3DA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACyB;AACC;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA,iCAAiC,8CAAgB,GAAG;AACpD;AACA;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,qDAAU;AAC7B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,mBAAmB,kDAAO;AAC1B,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,gBAAgB,0BAA0B;AAC1C;AACA;AACA;AACA;AACA,uCAAuC,kBAAkB,EAAE;AAC3D,0CAA0C,kBAAkB,EAAE;AAC9D,uCAAuC,cAAc,EAAE;AACvD,uCAAuC,kBAAkB,EAAE;AAC3D,iDAAiD,UAAU,EAAE;AAC7D,0DAA0D,kBAAkB,EAAE;AAC9E,iDAAiD,UAAU,EAAE;AAC7D,kDAAkD,UAAU,EAAE;AAC9D;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA,2EAA2E,GAAG;AAC9E;AACA,2EAA2E,GAAG;AAC9E;AACA;AACA;AACA;AACA,CAAC,CAAC,uEAAa;AACuB;AACtC;AACe,yFAA0B,EAAC;AAC1C,sC;;;;;;;;;;;;ACrFA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAC4B;AACA;AACC;AACM;AACA;AACG;AACtC,iC;;;;;;;;;;;;AC5BA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACS;AACiB;AAC3D;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,mCAAmC,qDAAU;AAC7C;AACA;AACA,uDAAuD,qDAAU;AACjE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,qDAAU;AAC5C;AACA;AACA;AACA,+BAA+B,qDAAU;AACzC;AACA;AACA;AACA,CAAC,CAAC,sEAA0B;AACW;AACvC;AACe,0FAA2B,EAAC;AAC3C,sC;;;;;;;;;;;;ACxGA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACiC;AACM;AACoB;AAC3D;AACA;AACA,IAAI,+CAAiB;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,EAAE,kDAAO;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,EAAE,kDAAO;AAClB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,kDAAO;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,CAAC,sEAA0B;AACM;AAClC;AACe,qFAAsB,EAAC;AACtC,sC;;;;;;;;;;;ACvKA,mFAAa,GAAG,IAAsD,EAAE,mBAAmB,KAAK,UAAiO,CAAC,aAAa,0BAA0B,0BAA0B,gBAAgB,UAAU,UAAU,0CAA0C,gBAAgB,OAAC,OAAO,oBAAoB,8CAA8C,kCAAkC,YAAY,YAAY,mCAAmC,iBAAiB,gBAAgB,sBAAsB,oBAAoB,0CAA0C,YAAY,WAAW,YAAY,SAAS,GAAG;AAC5yB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA,gCAAgC;AAChC;AACA;AACA;AACA;;AAEA;AACA;AACA,iBAAiB,QAAQ;AACzB;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH,kCAAkC;AAClC;AACA;AACA;;AAEA;AACA,EAAE;AACF;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA,gBAAgB,sBAAsB;AACtC;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,kBAAkB,oBAAoB;AACtC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,CAAC,GAAG;AACJ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA,CAAC;;;;AAID,CAAC;;AAED,CAAC,EAAE,aAAa;AAChB;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;;;;AAIA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,uBAAuB,sBAAsB;AAC7C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,qCAAqC;;AAErC;AACA;AACA;;AAEA,2BAA2B;AAC3B;AACA;AACA;AACA,4BAA4B,UAAU;;AAEtC,CAAC,GAAG;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,cAAc,4BAA4B;AAC1C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,eAAe;AACrC;AACA;AACA;AACA,aAAa;AACb,qCAAqC,UAAU;AAC/C;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA,kBAAkB,kBAAkB;AACpC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC,qIAAqI;;AAEtI,CAAC,EAAE,oBAAoB;AACvB;;AAEA,gCAAgC,2CAA2C,gBAAgB,kBAAkB,OAAO,2BAA2B,wDAAwD,gCAAgC,uDAAuD,2DAA2D,EAAE,EAAE,yDAAyD,qEAAqE,6DAA6D,oBAAoB,GAAG,EAAE;;AAEjjB,iDAAiD,0CAA0C,0DAA0D,EAAE;;AAEvJ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,mBAAmB;AACnB;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,OAAO;AACtD;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,iDAAiD,OAAO;AACxD;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA,yBAAyB,4BAA4B;AACrD;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,4BAA4B;AACrD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,sCAAsC;;AAEtC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;A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","file":"bundle.js","sourcesContent":[" \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"/dist/\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from './foundation';\nvar MDCComponent = /** @class */ (function () {\n    function MDCComponent(root, foundation) {\n        var args = [];\n        for (var _i = 2; _i < arguments.length; _i++) {\n            args[_i - 2] = arguments[_i];\n        }\n        this.root_ = root;\n        this.initialize.apply(this, tslib_1.__spread(args));\n        // Note that we initialize foundation here and not within the constructor's default param so that\n        // this.root_ is defined and can be used within the foundation class.\n        this.foundation_ = foundation === undefined ? this.getDefaultFoundation() : foundation;\n        this.foundation_.init();\n        this.initialSyncWithDOM();\n    }\n    MDCComponent.attachTo = function (root) {\n        // Subclasses which extend MDCBase should provide an attachTo() method that takes a root element and\n        // returns an instantiated component with its root set to that element. Also note that in the cases of\n        // subclasses, an explicit foundation class will not have to be passed in; it will simply be initialized\n        // from getDefaultFoundation().\n        return new MDCComponent(root, new MDCFoundation({}));\n    };\n    /* istanbul ignore next: method param only exists for typing purposes; it does not need to be unit tested */\n    MDCComponent.prototype.initialize = function () {\n        var _args = [];\n        for (var _i = 0; _i < arguments.length; _i++) {\n            _args[_i] = arguments[_i];\n        }\n        // Subclasses can override this to do any additional setup work that would be considered part of a\n        // \"constructor\". Essentially, it is a hook into the parent constructor before the foundation is\n        // initialized. Any additional arguments besides root and foundation will be passed in here.\n    };\n    MDCComponent.prototype.getDefaultFoundation = function () {\n        // Subclasses must override this method to return a properly configured foundation class for the\n        // component.\n        throw new Error('Subclasses must override getDefaultFoundation to return a properly configured ' +\n            'foundation class');\n    };\n    MDCComponent.prototype.initialSyncWithDOM = function () {\n        // Subclasses should override this method if they need to perform work to synchronize with a host DOM\n        // object. An example of this would be a form control wrapper that needs to synchronize its internal state\n        // to some property or attribute of the host DOM. Please note: this is *not* the place to perform DOM\n        // reads/writes that would cause layout / paint, as this is called synchronously from within the constructor.\n    };\n    MDCComponent.prototype.destroy = function () {\n        // Subclasses may implement this method to release any resources / deregister any listeners they have\n        // attached. An example of this might be deregistering a resize event from the window object.\n        this.foundation_.destroy();\n    };\n    MDCComponent.prototype.listen = function (evtType, handler, options) {\n        this.root_.addEventListener(evtType, handler, options);\n    };\n    MDCComponent.prototype.unlisten = function (evtType, handler, options) {\n        this.root_.removeEventListener(evtType, handler, options);\n    };\n    /**\n     * Fires a cross-browser-compatible custom event from the component root of the given type, with the given data.\n     */\n    MDCComponent.prototype.emit = function (evtType, evtData, shouldBubble) {\n        if (shouldBubble === void 0) { shouldBubble = false; }\n        var evt;\n        if (typeof CustomEvent === 'function') {\n            evt = new CustomEvent(evtType, {\n                bubbles: shouldBubble,\n                detail: evtData,\n            });\n        }\n        else {\n            evt = document.createEvent('CustomEvent');\n            evt.initCustomEvent(evtType, shouldBubble, false, evtData);\n        }\n        this.root_.dispatchEvent(evt);\n    };\n    return MDCComponent;\n}());\nexport { MDCComponent };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCComponent;\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar MDCFoundation = /** @class */ (function () {\n    function MDCFoundation(adapter) {\n        if (adapter === void 0) { adapter = {}; }\n        this.adapter_ = adapter;\n    }\n    Object.defineProperty(MDCFoundation, \"cssClasses\", {\n        get: function () {\n            // Classes extending MDCFoundation should implement this method to return an object which exports every\n            // CSS class the foundation class needs as a property. e.g. {ACTIVE: 'mdc-component--active'}\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFoundation, \"strings\", {\n        get: function () {\n            // Classes extending MDCFoundation should implement this method to return an object which exports all\n            // semantic strings as constants. e.g. {ARIA_ROLE: 'tablist'}\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFoundation, \"numbers\", {\n        get: function () {\n            // Classes extending MDCFoundation should implement this method to return an object which exports all\n            // of its semantic numbers as constants. e.g. {ANIMATION_DELAY_MS: 350}\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFoundation, \"defaultAdapter\", {\n        get: function () {\n            // Classes extending MDCFoundation may choose to implement this getter in order to provide a convenient\n            // way of viewing the necessary methods of an adapter. In the future, this could also be used for adapter\n            // validation.\n            return {};\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCFoundation.prototype.init = function () {\n        // Subclasses should override this method to perform initialization routines (registering events, etc.)\n    };\n    MDCFoundation.prototype.destroy = function () {\n        // Subclasses should override this method to perform de-initialization routines (de-registering events, etc.)\n    };\n    return MDCFoundation;\n}());\nexport { MDCFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\n/**\n * Stores result from applyPassive to avoid redundant processing to detect\n * passive event listener support.\n */\nvar supportsPassive_;\n/**\n * Determine whether the current browser supports passive event listeners, and\n * if so, use them.\n */\nexport function applyPassive(globalObj, forceRefresh) {\n    if (globalObj === void 0) { globalObj = window; }\n    if (forceRefresh === void 0) { forceRefresh = false; }\n    if (supportsPassive_ === undefined || forceRefresh) {\n        var isSupported_1 = false;\n        try {\n            globalObj.document.addEventListener('test', function () { return undefined; }, {\n                get passive() {\n                    isSupported_1 = true;\n                    return isSupported_1;\n                },\n            });\n        }\n        catch (e) {\n        } // tslint:disable-line:no-empty cannot throw error due to tests. tslint also disables console.log.\n        supportsPassive_ = isSupported_1;\n    }\n    return supportsPassive_ ? { passive: true } : false;\n}\n//# sourceMappingURL=events.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\n/**\n * @fileoverview A \"ponyfill\" is a polyfill that doesn't modify the global prototype chain.\n * This makes ponyfills safer than traditional polyfills, especially for libraries like MDC.\n */\nexport function closest(element, selector) {\n    if (element.closest) {\n        return element.closest(selector);\n    }\n    var el = element;\n    while (el) {\n        if (matches(el, selector)) {\n            return el;\n        }\n        el = el.parentElement;\n    }\n    return null;\n}\nexport function matches(element, selector) {\n    var nativeMatches = element.matches\n        || element.webkitMatchesSelector\n        || element.msMatchesSelector;\n    return nativeMatches.call(element, selector);\n}\n//# sourceMappingURL=ponyfill.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCFloatingLabelFoundation } from './foundation';\nvar MDCFloatingLabel = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCFloatingLabel, _super);\n    function MDCFloatingLabel() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCFloatingLabel.attachTo = function (root) {\n        return new MDCFloatingLabel(root);\n    };\n    /**\n     * Styles the label to produce the label shake for errors.\n     * @param shouldShake If true, shakes the label by adding a CSS class; otherwise, stops shaking by removing the class.\n     */\n    MDCFloatingLabel.prototype.shake = function (shouldShake) {\n        this.foundation_.shake(shouldShake);\n    };\n    /**\n     * Styles the label to float/dock.\n     * @param shouldFloat If true, floats the label by adding a CSS class; otherwise, docks it by removing the class.\n     */\n    MDCFloatingLabel.prototype.float = function (shouldFloat) {\n        this.foundation_.float(shouldFloat);\n    };\n    MDCFloatingLabel.prototype.getWidth = function () {\n        return this.foundation_.getWidth();\n    };\n    MDCFloatingLabel.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            getWidth: function () { return _this.root_.scrollWidth; },\n            registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCFloatingLabelFoundation(adapter);\n    };\n    return MDCFloatingLabel;\n}(MDCComponent));\nexport { MDCFloatingLabel };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport var cssClasses = {\n    LABEL_FLOAT_ABOVE: 'mdc-floating-label--float-above',\n    LABEL_SHAKE: 'mdc-floating-label--shake',\n    ROOT: 'mdc-floating-label',\n};\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses } from './constants';\nvar MDCFloatingLabelFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCFloatingLabelFoundation, _super);\n    function MDCFloatingLabelFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCFloatingLabelFoundation.defaultAdapter, adapter)) || this;\n        _this.shakeAnimationEndHandler_ = function () { return _this.handleShakeAnimationEnd_(); };\n        return _this;\n    }\n    Object.defineProperty(MDCFloatingLabelFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCFloatingLabelFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCFloatingLabelAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                getWidth: function () { return 0; },\n                registerInteractionHandler: function () { return undefined; },\n                deregisterInteractionHandler: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCFloatingLabelFoundation.prototype.init = function () {\n        this.adapter_.registerInteractionHandler('animationend', this.shakeAnimationEndHandler_);\n    };\n    MDCFloatingLabelFoundation.prototype.destroy = function () {\n        this.adapter_.deregisterInteractionHandler('animationend', this.shakeAnimationEndHandler_);\n    };\n    /**\n     * Returns the width of the label element.\n     */\n    MDCFloatingLabelFoundation.prototype.getWidth = function () {\n        return this.adapter_.getWidth();\n    };\n    /**\n     * Styles the label to produce a shake animation to indicate an error.\n     * @param shouldShake If true, adds the shake CSS class; otherwise, removes shake class.\n     */\n    MDCFloatingLabelFoundation.prototype.shake = function (shouldShake) {\n        var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE;\n        if (shouldShake) {\n            this.adapter_.addClass(LABEL_SHAKE);\n        }\n        else {\n            this.adapter_.removeClass(LABEL_SHAKE);\n        }\n    };\n    /**\n     * Styles the label to float or dock.\n     * @param shouldFloat If true, adds the float CSS class; otherwise, removes float and shake classes to dock the label.\n     */\n    MDCFloatingLabelFoundation.prototype.float = function (shouldFloat) {\n        var _a = MDCFloatingLabelFoundation.cssClasses, LABEL_FLOAT_ABOVE = _a.LABEL_FLOAT_ABOVE, LABEL_SHAKE = _a.LABEL_SHAKE;\n        if (shouldFloat) {\n            this.adapter_.addClass(LABEL_FLOAT_ABOVE);\n        }\n        else {\n            this.adapter_.removeClass(LABEL_FLOAT_ABOVE);\n            this.adapter_.removeClass(LABEL_SHAKE);\n        }\n    };\n    MDCFloatingLabelFoundation.prototype.handleShakeAnimationEnd_ = function () {\n        var LABEL_SHAKE = MDCFloatingLabelFoundation.cssClasses.LABEL_SHAKE;\n        this.adapter_.removeClass(LABEL_SHAKE);\n    };\n    return MDCFloatingLabelFoundation;\n}(MDCFoundation));\nexport { MDCFloatingLabelFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCFloatingLabelFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCLineRippleFoundation } from './foundation';\nvar MDCLineRipple = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCLineRipple, _super);\n    function MDCLineRipple() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCLineRipple.attachTo = function (root) {\n        return new MDCLineRipple(root);\n    };\n    /**\n     * Activates the line ripple\n     */\n    MDCLineRipple.prototype.activate = function () {\n        this.foundation_.activate();\n    };\n    /**\n     * Deactivates the line ripple\n     */\n    MDCLineRipple.prototype.deactivate = function () {\n        this.foundation_.deactivate();\n    };\n    /**\n     * Sets the transform origin given a user's click location.\n     * The `rippleCenter` is the x-coordinate of the middle of the ripple.\n     */\n    MDCLineRipple.prototype.setRippleCenter = function (xCoordinate) {\n        this.foundation_.setRippleCenter(xCoordinate);\n    };\n    MDCLineRipple.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            setStyle: function (propertyName, value) { return _this.root_.style.setProperty(propertyName, value); },\n            registerEventHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterEventHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCLineRippleFoundation(adapter);\n    };\n    return MDCLineRipple;\n}(MDCComponent));\nexport { MDCLineRipple };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    LINE_RIPPLE_ACTIVE: 'mdc-line-ripple--active',\n    LINE_RIPPLE_DEACTIVATING: 'mdc-line-ripple--deactivating',\n};\nexport { cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses } from './constants';\nvar MDCLineRippleFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCLineRippleFoundation, _super);\n    function MDCLineRippleFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCLineRippleFoundation.defaultAdapter, adapter)) || this;\n        _this.transitionEndHandler_ = function (evt) { return _this.handleTransitionEnd(evt); };\n        return _this;\n    }\n    Object.defineProperty(MDCLineRippleFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCLineRippleFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCLineRippleAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return false; },\n                setStyle: function () { return undefined; },\n                registerEventHandler: function () { return undefined; },\n                deregisterEventHandler: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCLineRippleFoundation.prototype.init = function () {\n        this.adapter_.registerEventHandler('transitionend', this.transitionEndHandler_);\n    };\n    MDCLineRippleFoundation.prototype.destroy = function () {\n        this.adapter_.deregisterEventHandler('transitionend', this.transitionEndHandler_);\n    };\n    MDCLineRippleFoundation.prototype.activate = function () {\n        this.adapter_.removeClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n        this.adapter_.addClass(cssClasses.LINE_RIPPLE_ACTIVE);\n    };\n    MDCLineRippleFoundation.prototype.setRippleCenter = function (xCoordinate) {\n        this.adapter_.setStyle('transform-origin', xCoordinate + \"px center\");\n    };\n    MDCLineRippleFoundation.prototype.deactivate = function () {\n        this.adapter_.addClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n    };\n    MDCLineRippleFoundation.prototype.handleTransitionEnd = function (evt) {\n        // Wait for the line ripple to be either transparent or opaque\n        // before emitting the animation end event\n        var isDeactivating = this.adapter_.hasClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n        if (evt.propertyName === 'opacity') {\n            if (isDeactivating) {\n                this.adapter_.removeClass(cssClasses.LINE_RIPPLE_ACTIVE);\n                this.adapter_.removeClass(cssClasses.LINE_RIPPLE_DEACTIVATING);\n            }\n        }\n    };\n    return MDCLineRippleFoundation;\n}(MDCFoundation));\nexport { MDCLineRippleFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCLineRippleFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCFloatingLabelFoundation } from '@material/floating-label/foundation';\nimport { cssClasses, strings } from './constants';\nimport { MDCNotchedOutlineFoundation } from './foundation';\nvar MDCNotchedOutline = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCNotchedOutline, _super);\n    function MDCNotchedOutline() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCNotchedOutline.attachTo = function (root) {\n        return new MDCNotchedOutline(root);\n    };\n    MDCNotchedOutline.prototype.initialSyncWithDOM = function () {\n        this.notchElement_ = this.root_.querySelector(strings.NOTCH_ELEMENT_SELECTOR);\n        var label = this.root_.querySelector('.' + MDCFloatingLabelFoundation.cssClasses.ROOT);\n        if (label) {\n            label.style.transitionDuration = '0s';\n            this.root_.classList.add(cssClasses.OUTLINE_UPGRADED);\n            requestAnimationFrame(function () {\n                label.style.transitionDuration = '';\n            });\n        }\n        else {\n            this.root_.classList.add(cssClasses.NO_LABEL);\n        }\n    };\n    /**\n     * Updates classes and styles to open the notch to the specified width.\n     * @param notchWidth The notch width in the outline.\n     */\n    MDCNotchedOutline.prototype.notch = function (notchWidth) {\n        this.foundation_.notch(notchWidth);\n    };\n    /**\n     * Updates classes and styles to close the notch.\n     */\n    MDCNotchedOutline.prototype.closeNotch = function () {\n        this.foundation_.closeNotch();\n    };\n    MDCNotchedOutline.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            setNotchWidthProperty: function (width) { return _this.notchElement_.style.setProperty('width', width + 'px'); },\n            removeNotchWidthProperty: function () { return _this.notchElement_.style.removeProperty('width'); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCNotchedOutlineFoundation(adapter);\n    };\n    return MDCNotchedOutline;\n}(MDCComponent));\nexport { MDCNotchedOutline };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar strings = {\n    NOTCH_ELEMENT_SELECTOR: '.mdc-notched-outline__notch',\n};\nvar numbers = {\n    // This should stay in sync with $mdc-notched-outline-padding * 2.\n    NOTCH_ELEMENT_PADDING: 8,\n};\nvar cssClasses = {\n    NO_LABEL: 'mdc-notched-outline--no-label',\n    OUTLINE_NOTCHED: 'mdc-notched-outline--notched',\n    OUTLINE_UPGRADED: 'mdc-notched-outline--upgraded',\n};\nexport { cssClasses, numbers, strings };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, numbers, strings } from './constants';\nvar MDCNotchedOutlineFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCNotchedOutlineFoundation, _super);\n    function MDCNotchedOutlineFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCNotchedOutlineFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCNotchedOutlineFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCNotchedOutlineAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                setNotchWidthProperty: function () { return undefined; },\n                removeNotchWidthProperty: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /**\n     * Adds the outline notched selector and updates the notch width calculated based off of notchWidth.\n     */\n    MDCNotchedOutlineFoundation.prototype.notch = function (notchWidth) {\n        var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED;\n        if (notchWidth > 0) {\n            notchWidth += numbers.NOTCH_ELEMENT_PADDING; // Add padding from left/right.\n        }\n        this.adapter_.setNotchWidthProperty(notchWidth);\n        this.adapter_.addClass(OUTLINE_NOTCHED);\n    };\n    /**\n     * Removes notched outline selector to close the notch in the outline.\n     */\n    MDCNotchedOutlineFoundation.prototype.closeNotch = function () {\n        var OUTLINE_NOTCHED = MDCNotchedOutlineFoundation.cssClasses.OUTLINE_NOTCHED;\n        this.adapter_.removeClass(OUTLINE_NOTCHED);\n        this.adapter_.removeNotchWidthProperty();\n    };\n    return MDCNotchedOutlineFoundation;\n}(MDCFoundation));\nexport { MDCNotchedOutlineFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCNotchedOutlineFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { applyPassive } from '@material/dom/events';\nimport { matches } from '@material/dom/ponyfill';\nimport { MDCRippleFoundation } from './foundation';\nimport * as util from './util';\nvar MDCRipple = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCRipple, _super);\n    function MDCRipple() {\n        var _this = _super !== null && _super.apply(this, arguments) || this;\n        _this.disabled = false;\n        return _this;\n    }\n    MDCRipple.attachTo = function (root, opts) {\n        if (opts === void 0) { opts = { isUnbounded: undefined }; }\n        var ripple = new MDCRipple(root);\n        // Only override unbounded behavior if option is explicitly specified\n        if (opts.isUnbounded !== undefined) {\n            ripple.unbounded = opts.isUnbounded;\n        }\n        return ripple;\n    };\n    MDCRipple.createAdapter = function (instance) {\n        return {\n            addClass: function (className) { return instance.root_.classList.add(className); },\n            browserSupportsCssVars: function () { return util.supportsCssVariables(window); },\n            computeBoundingRect: function () { return instance.root_.getBoundingClientRect(); },\n            containsEventTarget: function (target) { return instance.root_.contains(target); },\n            deregisterDocumentInteractionHandler: function (evtType, handler) {\n                return document.documentElement.removeEventListener(evtType, handler, applyPassive());\n            },\n            deregisterInteractionHandler: function (evtType, handler) {\n                return instance.root_.removeEventListener(evtType, handler, applyPassive());\n            },\n            deregisterResizeHandler: function (handler) { return window.removeEventListener('resize', handler); },\n            getWindowPageOffset: function () { return ({ x: window.pageXOffset, y: window.pageYOffset }); },\n            isSurfaceActive: function () { return matches(instance.root_, ':active'); },\n            isSurfaceDisabled: function () { return Boolean(instance.disabled); },\n            isUnbounded: function () { return Boolean(instance.unbounded); },\n            registerDocumentInteractionHandler: function (evtType, handler) {\n                return document.documentElement.addEventListener(evtType, handler, applyPassive());\n            },\n            registerInteractionHandler: function (evtType, handler) {\n                return instance.root_.addEventListener(evtType, handler, applyPassive());\n            },\n            registerResizeHandler: function (handler) { return window.addEventListener('resize', handler); },\n            removeClass: function (className) { return instance.root_.classList.remove(className); },\n            updateCssVariable: function (varName, value) { return instance.root_.style.setProperty(varName, value); },\n        };\n    };\n    Object.defineProperty(MDCRipple.prototype, \"unbounded\", {\n        get: function () {\n            return Boolean(this.unbounded_);\n        },\n        set: function (unbounded) {\n            this.unbounded_ = Boolean(unbounded);\n            this.setUnbounded_();\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCRipple.prototype.activate = function () {\n        this.foundation_.activate();\n    };\n    MDCRipple.prototype.deactivate = function () {\n        this.foundation_.deactivate();\n    };\n    MDCRipple.prototype.layout = function () {\n        this.foundation_.layout();\n    };\n    MDCRipple.prototype.getDefaultFoundation = function () {\n        return new MDCRippleFoundation(MDCRipple.createAdapter(this));\n    };\n    MDCRipple.prototype.initialSyncWithDOM = function () {\n        var root = this.root_;\n        this.unbounded = 'mdcRippleIsUnbounded' in root.dataset;\n    };\n    /**\n     * Closure Compiler throws an access control error when directly accessing a\n     * protected or private property inside a getter/setter, like unbounded above.\n     * By accessing the protected property inside a method, we solve that problem.\n     * That's why this function exists.\n     */\n    MDCRipple.prototype.setUnbounded_ = function () {\n        this.foundation_.setUnbounded(Boolean(this.unbounded_));\n    };\n    return MDCRipple;\n}(MDCComponent));\nexport { MDCRipple };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport var cssClasses = {\n    // Ripple is a special case where the \"root\" component is really a \"mixin\" of sorts,\n    // given that it's an 'upgrade' to an existing component. That being said it is the root\n    // CSS class that all other CSS classes derive from.\n    BG_FOCUSED: 'mdc-ripple-upgraded--background-focused',\n    FG_ACTIVATION: 'mdc-ripple-upgraded--foreground-activation',\n    FG_DEACTIVATION: 'mdc-ripple-upgraded--foreground-deactivation',\n    ROOT: 'mdc-ripple-upgraded',\n    UNBOUNDED: 'mdc-ripple-upgraded--unbounded',\n};\nexport var strings = {\n    VAR_FG_SCALE: '--mdc-ripple-fg-scale',\n    VAR_FG_SIZE: '--mdc-ripple-fg-size',\n    VAR_FG_TRANSLATE_END: '--mdc-ripple-fg-translate-end',\n    VAR_FG_TRANSLATE_START: '--mdc-ripple-fg-translate-start',\n    VAR_LEFT: '--mdc-ripple-left',\n    VAR_TOP: '--mdc-ripple-top',\n};\nexport var numbers = {\n    DEACTIVATION_TIMEOUT_MS: 225,\n    FG_DEACTIVATION_MS: 150,\n    INITIAL_ORIGIN_SCALE: 0.6,\n    PADDING: 10,\n    TAP_DELAY_MS: 300,\n};\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, numbers, strings } from './constants';\nimport { getNormalizedEventCoords } from './util';\n// Activation events registered on the root element of each instance for activation\nvar ACTIVATION_EVENT_TYPES = [\n    'touchstart', 'pointerdown', 'mousedown', 'keydown',\n];\n// Deactivation events registered on documentElement when a pointer-related down event occurs\nvar POINTER_DEACTIVATION_EVENT_TYPES = [\n    'touchend', 'pointerup', 'mouseup', 'contextmenu',\n];\n// simultaneous nested activations\nvar activatedTargets = [];\nvar MDCRippleFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCRippleFoundation, _super);\n    function MDCRippleFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCRippleFoundation.defaultAdapter, adapter)) || this;\n        _this.activationAnimationHasEnded_ = false;\n        _this.activationTimer_ = 0;\n        _this.fgDeactivationRemovalTimer_ = 0;\n        _this.fgScale_ = '0';\n        _this.frame_ = { width: 0, height: 0 };\n        _this.initialSize_ = 0;\n        _this.layoutFrame_ = 0;\n        _this.maxRadius_ = 0;\n        _this.unboundedCoords_ = { left: 0, top: 0 };\n        _this.activationState_ = _this.defaultActivationState_();\n        _this.activationTimerCallback_ = function () {\n            _this.activationAnimationHasEnded_ = true;\n            _this.runDeactivationUXLogicIfReady_();\n        };\n        _this.activateHandler_ = function (e) { return _this.activate_(e); };\n        _this.deactivateHandler_ = function () { return _this.deactivate_(); };\n        _this.focusHandler_ = function () { return _this.handleFocus(); };\n        _this.blurHandler_ = function () { return _this.handleBlur(); };\n        _this.resizeHandler_ = function () { return _this.layout(); };\n        return _this;\n    }\n    Object.defineProperty(MDCRippleFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCRippleFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCRippleFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCRippleFoundation, \"defaultAdapter\", {\n        get: function () {\n            return {\n                addClass: function () { return undefined; },\n                browserSupportsCssVars: function () { return true; },\n                computeBoundingRect: function () { return ({ top: 0, right: 0, bottom: 0, left: 0, width: 0, height: 0 }); },\n                containsEventTarget: function () { return true; },\n                deregisterDocumentInteractionHandler: function () { return undefined; },\n                deregisterInteractionHandler: function () { return undefined; },\n                deregisterResizeHandler: function () { return undefined; },\n                getWindowPageOffset: function () { return ({ x: 0, y: 0 }); },\n                isSurfaceActive: function () { return true; },\n                isSurfaceDisabled: function () { return true; },\n                isUnbounded: function () { return true; },\n                registerDocumentInteractionHandler: function () { return undefined; },\n                registerInteractionHandler: function () { return undefined; },\n                registerResizeHandler: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                updateCssVariable: function () { return undefined; },\n            };\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCRippleFoundation.prototype.init = function () {\n        var _this = this;\n        var supportsPressRipple = this.supportsPressRipple_();\n        this.registerRootHandlers_(supportsPressRipple);\n        if (supportsPressRipple) {\n            var _a = MDCRippleFoundation.cssClasses, ROOT_1 = _a.ROOT, UNBOUNDED_1 = _a.UNBOUNDED;\n            requestAnimationFrame(function () {\n                _this.adapter_.addClass(ROOT_1);\n                if (_this.adapter_.isUnbounded()) {\n                    _this.adapter_.addClass(UNBOUNDED_1);\n                    // Unbounded ripples need layout logic applied immediately to set coordinates for both shade and ripple\n                    _this.layoutInternal_();\n                }\n            });\n        }\n    };\n    MDCRippleFoundation.prototype.destroy = function () {\n        var _this = this;\n        if (this.supportsPressRipple_()) {\n            if (this.activationTimer_) {\n                clearTimeout(this.activationTimer_);\n                this.activationTimer_ = 0;\n                this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_ACTIVATION);\n            }\n            if (this.fgDeactivationRemovalTimer_) {\n                clearTimeout(this.fgDeactivationRemovalTimer_);\n                this.fgDeactivationRemovalTimer_ = 0;\n                this.adapter_.removeClass(MDCRippleFoundation.cssClasses.FG_DEACTIVATION);\n            }\n            var _a = MDCRippleFoundation.cssClasses, ROOT_2 = _a.ROOT, UNBOUNDED_2 = _a.UNBOUNDED;\n            requestAnimationFrame(function () {\n                _this.adapter_.removeClass(ROOT_2);\n                _this.adapter_.removeClass(UNBOUNDED_2);\n                _this.removeCssVars_();\n            });\n        }\n        this.deregisterRootHandlers_();\n        this.deregisterDeactivationHandlers_();\n    };\n    /**\n     * @param evt Optional event containing position information.\n     */\n    MDCRippleFoundation.prototype.activate = function (evt) {\n        this.activate_(evt);\n    };\n    MDCRippleFoundation.prototype.deactivate = function () {\n        this.deactivate_();\n    };\n    MDCRippleFoundation.prototype.layout = function () {\n        var _this = this;\n        if (this.layoutFrame_) {\n            cancelAnimationFrame(this.layoutFrame_);\n        }\n        this.layoutFrame_ = requestAnimationFrame(function () {\n            _this.layoutInternal_();\n            _this.layoutFrame_ = 0;\n        });\n    };\n    MDCRippleFoundation.prototype.setUnbounded = function (unbounded) {\n        var UNBOUNDED = MDCRippleFoundation.cssClasses.UNBOUNDED;\n        if (unbounded) {\n            this.adapter_.addClass(UNBOUNDED);\n        }\n        else {\n            this.adapter_.removeClass(UNBOUNDED);\n        }\n    };\n    MDCRippleFoundation.prototype.handleFocus = function () {\n        var _this = this;\n        requestAnimationFrame(function () {\n            return _this.adapter_.addClass(MDCRippleFoundation.cssClasses.BG_FOCUSED);\n        });\n    };\n    MDCRippleFoundation.prototype.handleBlur = function () {\n        var _this = this;\n        requestAnimationFrame(function () {\n            return _this.adapter_.removeClass(MDCRippleFoundation.cssClasses.BG_FOCUSED);\n        });\n    };\n    /**\n     * We compute this property so that we are not querying information about the client\n     * until the point in time where the foundation requests it. This prevents scenarios where\n     * client-side feature-detection may happen too early, such as when components are rendered on the server\n     * and then initialized at mount time on the client.\n     */\n    MDCRippleFoundation.prototype.supportsPressRipple_ = function () {\n        return this.adapter_.browserSupportsCssVars();\n    };\n    MDCRippleFoundation.prototype.defaultActivationState_ = function () {\n        return {\n            activationEvent: undefined,\n            hasDeactivationUXRun: false,\n            isActivated: false,\n            isProgrammatic: false,\n            wasActivatedByPointer: false,\n            wasElementMadeActive: false,\n        };\n    };\n    /**\n     * supportsPressRipple Passed from init to save a redundant function call\n     */\n    MDCRippleFoundation.prototype.registerRootHandlers_ = function (supportsPressRipple) {\n        var _this = this;\n        if (supportsPressRipple) {\n            ACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n                _this.adapter_.registerInteractionHandler(evtType, _this.activateHandler_);\n            });\n            if (this.adapter_.isUnbounded()) {\n                this.adapter_.registerResizeHandler(this.resizeHandler_);\n            }\n        }\n        this.adapter_.registerInteractionHandler('focus', this.focusHandler_);\n        this.adapter_.registerInteractionHandler('blur', this.blurHandler_);\n    };\n    MDCRippleFoundation.prototype.registerDeactivationHandlers_ = function (evt) {\n        var _this = this;\n        if (evt.type === 'keydown') {\n            this.adapter_.registerInteractionHandler('keyup', this.deactivateHandler_);\n        }\n        else {\n            POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n                _this.adapter_.registerDocumentInteractionHandler(evtType, _this.deactivateHandler_);\n            });\n        }\n    };\n    MDCRippleFoundation.prototype.deregisterRootHandlers_ = function () {\n        var _this = this;\n        ACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n            _this.adapter_.deregisterInteractionHandler(evtType, _this.activateHandler_);\n        });\n        this.adapter_.deregisterInteractionHandler('focus', this.focusHandler_);\n        this.adapter_.deregisterInteractionHandler('blur', this.blurHandler_);\n        if (this.adapter_.isUnbounded()) {\n            this.adapter_.deregisterResizeHandler(this.resizeHandler_);\n        }\n    };\n    MDCRippleFoundation.prototype.deregisterDeactivationHandlers_ = function () {\n        var _this = this;\n        this.adapter_.deregisterInteractionHandler('keyup', this.deactivateHandler_);\n        POINTER_DEACTIVATION_EVENT_TYPES.forEach(function (evtType) {\n            _this.adapter_.deregisterDocumentInteractionHandler(evtType, _this.deactivateHandler_);\n        });\n    };\n    MDCRippleFoundation.prototype.removeCssVars_ = function () {\n        var _this = this;\n        var rippleStrings = MDCRippleFoundation.strings;\n        var keys = Object.keys(rippleStrings);\n        keys.forEach(function (key) {\n            if (key.indexOf('VAR_') === 0) {\n                _this.adapter_.updateCssVariable(rippleStrings[key], null);\n            }\n        });\n    };\n    MDCRippleFoundation.prototype.activate_ = function (evt) {\n        var _this = this;\n        if (this.adapter_.isSurfaceDisabled()) {\n            return;\n        }\n        var activationState = this.activationState_;\n        if (activationState.isActivated) {\n            return;\n        }\n        // Avoid reacting to follow-on events fired by touch device after an already-processed user interaction\n        var previousActivationEvent = this.previousActivationEvent_;\n        var isSameInteraction = previousActivationEvent && evt !== undefined && previousActivationEvent.type !== evt.type;\n        if (isSameInteraction) {\n            return;\n        }\n        activationState.isActivated = true;\n        activationState.isProgrammatic = evt === undefined;\n        activationState.activationEvent = evt;\n        activationState.wasActivatedByPointer = activationState.isProgrammatic ? false : evt !== undefined && (evt.type === 'mousedown' || evt.type === 'touchstart' || evt.type === 'pointerdown');\n        var hasActivatedChild = evt !== undefined && activatedTargets.length > 0 && activatedTargets.some(function (target) { return _this.adapter_.containsEventTarget(target); });\n        if (hasActivatedChild) {\n            // Immediately reset activation state, while preserving logic that prevents touch follow-on events\n            this.resetActivationState_();\n            return;\n        }\n        if (evt !== undefined) {\n            activatedTargets.push(evt.target);\n            this.registerDeactivationHandlers_(evt);\n        }\n        activationState.wasElementMadeActive = this.checkElementMadeActive_(evt);\n        if (activationState.wasElementMadeActive) {\n            this.animateActivation_();\n        }\n        requestAnimationFrame(function () {\n            // Reset array on next frame after the current event has had a chance to bubble to prevent ancestor ripples\n            activatedTargets = [];\n            if (!activationState.wasElementMadeActive\n                && evt !== undefined\n                && (evt.key === ' ' || evt.keyCode === 32)) {\n                // If space was pressed, try again within an rAF call to detect :active, because different UAs report\n                // active states inconsistently when they're called within event handling code:\n                // - https://bugs.chromium.org/p/chromium/issues/detail?id=635971\n                // - https://bugzilla.mozilla.org/show_bug.cgi?id=1293741\n                // We try first outside rAF to support Edge, which does not exhibit this problem, but will crash if a CSS\n                // variable is set within a rAF callback for a submit button interaction (#2241).\n                activationState.wasElementMadeActive = _this.checkElementMadeActive_(evt);\n                if (activationState.wasElementMadeActive) {\n                    _this.animateActivation_();\n                }\n            }\n            if (!activationState.wasElementMadeActive) {\n                // Reset activation state immediately if element was not made active.\n                _this.activationState_ = _this.defaultActivationState_();\n            }\n        });\n    };\n    MDCRippleFoundation.prototype.checkElementMadeActive_ = function (evt) {\n        return (evt !== undefined && evt.type === 'keydown') ? this.adapter_.isSurfaceActive() : true;\n    };\n    MDCRippleFoundation.prototype.animateActivation_ = function () {\n        var _this = this;\n        var _a = MDCRippleFoundation.strings, VAR_FG_TRANSLATE_START = _a.VAR_FG_TRANSLATE_START, VAR_FG_TRANSLATE_END = _a.VAR_FG_TRANSLATE_END;\n        var _b = MDCRippleFoundation.cssClasses, FG_DEACTIVATION = _b.FG_DEACTIVATION, FG_ACTIVATION = _b.FG_ACTIVATION;\n        var DEACTIVATION_TIMEOUT_MS = MDCRippleFoundation.numbers.DEACTIVATION_TIMEOUT_MS;\n        this.layoutInternal_();\n        var translateStart = '';\n        var translateEnd = '';\n        if (!this.adapter_.isUnbounded()) {\n            var _c = this.getFgTranslationCoordinates_(), startPoint = _c.startPoint, endPoint = _c.endPoint;\n            translateStart = startPoint.x + \"px, \" + startPoint.y + \"px\";\n            translateEnd = endPoint.x + \"px, \" + endPoint.y + \"px\";\n        }\n        this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_START, translateStart);\n        this.adapter_.updateCssVariable(VAR_FG_TRANSLATE_END, translateEnd);\n        // Cancel any ongoing activation/deactivation animations\n        clearTimeout(this.activationTimer_);\n        clearTimeout(this.fgDeactivationRemovalTimer_);\n        this.rmBoundedActivationClasses_();\n        this.adapter_.removeClass(FG_DEACTIVATION);\n        // Force layout in order to re-trigger the animation.\n        this.adapter_.computeBoundingRect();\n        this.adapter_.addClass(FG_ACTIVATION);\n        this.activationTimer_ = setTimeout(function () { return _this.activationTimerCallback_(); }, DEACTIVATION_TIMEOUT_MS);\n    };\n    MDCRippleFoundation.prototype.getFgTranslationCoordinates_ = function () {\n        var _a = this.activationState_, activationEvent = _a.activationEvent, wasActivatedByPointer = _a.wasActivatedByPointer;\n        var startPoint;\n        if (wasActivatedByPointer) {\n            startPoint = getNormalizedEventCoords(activationEvent, this.adapter_.getWindowPageOffset(), this.adapter_.computeBoundingRect());\n        }\n        else {\n            startPoint = {\n                x: this.frame_.width / 2,\n                y: this.frame_.height / 2,\n            };\n        }\n        // Center the element around the start point.\n        startPoint = {\n            x: startPoint.x - (this.initialSize_ / 2),\n            y: startPoint.y - (this.initialSize_ / 2),\n        };\n        var endPoint = {\n            x: (this.frame_.width / 2) - (this.initialSize_ / 2),\n            y: (this.frame_.height / 2) - (this.initialSize_ / 2),\n        };\n        return { startPoint: startPoint, endPoint: endPoint };\n    };\n    MDCRippleFoundation.prototype.runDeactivationUXLogicIfReady_ = function () {\n        var _this = this;\n        // This method is called both when a pointing device is released, and when the activation animation ends.\n        // The deactivation animation should only run after both of those occur.\n        var FG_DEACTIVATION = MDCRippleFoundation.cssClasses.FG_DEACTIVATION;\n        var _a = this.activationState_, hasDeactivationUXRun = _a.hasDeactivationUXRun, isActivated = _a.isActivated;\n        var activationHasEnded = hasDeactivationUXRun || !isActivated;\n        if (activationHasEnded && this.activationAnimationHasEnded_) {\n            this.rmBoundedActivationClasses_();\n            this.adapter_.addClass(FG_DEACTIVATION);\n            this.fgDeactivationRemovalTimer_ = setTimeout(function () {\n                _this.adapter_.removeClass(FG_DEACTIVATION);\n            }, numbers.FG_DEACTIVATION_MS);\n        }\n    };\n    MDCRippleFoundation.prototype.rmBoundedActivationClasses_ = function () {\n        var FG_ACTIVATION = MDCRippleFoundation.cssClasses.FG_ACTIVATION;\n        this.adapter_.removeClass(FG_ACTIVATION);\n        this.activationAnimationHasEnded_ = false;\n        this.adapter_.computeBoundingRect();\n    };\n    MDCRippleFoundation.prototype.resetActivationState_ = function () {\n        var _this = this;\n        this.previousActivationEvent_ = this.activationState_.activationEvent;\n        this.activationState_ = this.defaultActivationState_();\n        // Touch devices may fire additional events for the same interaction within a short time.\n        // Store the previous event until it's safe to assume that subsequent events are for new interactions.\n        setTimeout(function () { return _this.previousActivationEvent_ = undefined; }, MDCRippleFoundation.numbers.TAP_DELAY_MS);\n    };\n    MDCRippleFoundation.prototype.deactivate_ = function () {\n        var _this = this;\n        var activationState = this.activationState_;\n        // This can happen in scenarios such as when you have a keyup event that blurs the element.\n        if (!activationState.isActivated) {\n            return;\n        }\n        var state = tslib_1.__assign({}, activationState);\n        if (activationState.isProgrammatic) {\n            requestAnimationFrame(function () { return _this.animateDeactivation_(state); });\n            this.resetActivationState_();\n        }\n        else {\n            this.deregisterDeactivationHandlers_();\n            requestAnimationFrame(function () {\n                _this.activationState_.hasDeactivationUXRun = true;\n                _this.animateDeactivation_(state);\n                _this.resetActivationState_();\n            });\n        }\n    };\n    MDCRippleFoundation.prototype.animateDeactivation_ = function (_a) {\n        var wasActivatedByPointer = _a.wasActivatedByPointer, wasElementMadeActive = _a.wasElementMadeActive;\n        if (wasActivatedByPointer || wasElementMadeActive) {\n            this.runDeactivationUXLogicIfReady_();\n        }\n    };\n    MDCRippleFoundation.prototype.layoutInternal_ = function () {\n        var _this = this;\n        this.frame_ = this.adapter_.computeBoundingRect();\n        var maxDim = Math.max(this.frame_.height, this.frame_.width);\n        // Surface diameter is treated differently for unbounded vs. bounded ripples.\n        // Unbounded ripple diameter is calculated smaller since the surface is expected to already be padded appropriately\n        // to extend the hitbox, and the ripple is expected to meet the edges of the padded hitbox (which is typically\n        // square). Bounded ripples, on the other hand, are fully expected to expand beyond the surface's longest diameter\n        // (calculated based on the diagonal plus a constant padding), and are clipped at the surface's border via\n        // `overflow: hidden`.\n        var getBoundedRadius = function () {\n            var hypotenuse = Math.sqrt(Math.pow(_this.frame_.width, 2) + Math.pow(_this.frame_.height, 2));\n            return hypotenuse + MDCRippleFoundation.numbers.PADDING;\n        };\n        this.maxRadius_ = this.adapter_.isUnbounded() ? maxDim : getBoundedRadius();\n        // Ripple is sized as a fraction of the largest dimension of the surface, then scales up using a CSS scale transform\n        this.initialSize_ = Math.floor(maxDim * MDCRippleFoundation.numbers.INITIAL_ORIGIN_SCALE);\n        this.fgScale_ = \"\" + this.maxRadius_ / this.initialSize_;\n        this.updateLayoutCssVars_();\n    };\n    MDCRippleFoundation.prototype.updateLayoutCssVars_ = function () {\n        var _a = MDCRippleFoundation.strings, VAR_FG_SIZE = _a.VAR_FG_SIZE, VAR_LEFT = _a.VAR_LEFT, VAR_TOP = _a.VAR_TOP, VAR_FG_SCALE = _a.VAR_FG_SCALE;\n        this.adapter_.updateCssVariable(VAR_FG_SIZE, this.initialSize_ + \"px\");\n        this.adapter_.updateCssVariable(VAR_FG_SCALE, this.fgScale_);\n        if (this.adapter_.isUnbounded()) {\n            this.unboundedCoords_ = {\n                left: Math.round((this.frame_.width / 2) - (this.initialSize_ / 2)),\n                top: Math.round((this.frame_.height / 2) - (this.initialSize_ / 2)),\n            };\n            this.adapter_.updateCssVariable(VAR_LEFT, this.unboundedCoords_.left + \"px\");\n            this.adapter_.updateCssVariable(VAR_TOP, this.unboundedCoords_.top + \"px\");\n        }\n    };\n    return MDCRippleFoundation;\n}(MDCFoundation));\nexport { MDCRippleFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCRippleFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as util from './util';\nexport { util };\nexport * from './component';\nexport * from './constants';\nexport * from './foundation';\n//# sourceMappingURL=index.js.map","/**\n * Stores result from supportsCssVariables to avoid redundant processing to\n * detect CSS custom variable support.\n */\nvar supportsCssVariables_;\nfunction detectEdgePseudoVarBug(windowObj) {\n    // Detect versions of Edge with buggy var() support\n    // See: https://developer.microsoft.com/en-us/microsoft-edge/platform/issues/11495448/\n    var document = windowObj.document;\n    var node = document.createElement('div');\n    node.className = 'mdc-ripple-surface--test-edge-var-bug';\n    // Append to head instead of body because this script might be invoked in the\n    // head, in which case the body doesn't exist yet. The probe works either way.\n    document.head.appendChild(node);\n    // The bug exists if ::before style ends up propagating to the parent element.\n    // Additionally, getComputedStyle returns null in iframes with display: \"none\" in Firefox,\n    // but Firefox is known to support CSS custom properties correctly.\n    // See: https://bugzilla.mozilla.org/show_bug.cgi?id=548397\n    var computedStyle = windowObj.getComputedStyle(node);\n    var hasPseudoVarBug = computedStyle !== null && computedStyle.borderTopStyle === 'solid';\n    if (node.parentNode) {\n        node.parentNode.removeChild(node);\n    }\n    return hasPseudoVarBug;\n}\nexport function supportsCssVariables(windowObj, forceRefresh) {\n    if (forceRefresh === void 0) { forceRefresh = false; }\n    var CSS = windowObj.CSS;\n    var supportsCssVars = supportsCssVariables_;\n    if (typeof supportsCssVariables_ === 'boolean' && !forceRefresh) {\n        return supportsCssVariables_;\n    }\n    var supportsFunctionPresent = CSS && typeof CSS.supports === 'function';\n    if (!supportsFunctionPresent) {\n        return false;\n    }\n    var explicitlySupportsCssVars = CSS.supports('--css-vars', 'yes');\n    // See: https://bugs.webkit.org/show_bug.cgi?id=154669\n    // See: README section on Safari\n    var weAreFeatureDetectingSafari10plus = (CSS.supports('(--css-vars: yes)') &&\n        CSS.supports('color', '#00000000'));\n    if (explicitlySupportsCssVars || weAreFeatureDetectingSafari10plus) {\n        supportsCssVars = !detectEdgePseudoVarBug(windowObj);\n    }\n    else {\n        supportsCssVars = false;\n    }\n    if (!forceRefresh) {\n        supportsCssVariables_ = supportsCssVars;\n    }\n    return supportsCssVars;\n}\nexport function getNormalizedEventCoords(evt, pageOffset, clientRect) {\n    if (!evt) {\n        return { x: 0, y: 0 };\n    }\n    var x = pageOffset.x, y = pageOffset.y;\n    var documentX = x + clientRect.left;\n    var documentY = y + clientRect.top;\n    var normalizedX;\n    var normalizedY;\n    // Determine touch point relative to the ripple container.\n    if (evt.type === 'touchstart') {\n        var touchEvent = evt;\n        normalizedX = touchEvent.changedTouches[0].pageX - documentX;\n        normalizedY = touchEvent.changedTouches[0].pageY - documentY;\n    }\n    else {\n        var mouseEvent = evt;\n        normalizedX = mouseEvent.pageX - documentX;\n        normalizedY = mouseEvent.pageY - documentY;\n    }\n    return { x: normalizedX, y: normalizedY };\n}\n//# sourceMappingURL=util.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCTextFieldCharacterCounterFoundation } from './foundation';\nvar MDCTextFieldCharacterCounter = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldCharacterCounter, _super);\n    function MDCTextFieldCharacterCounter() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextFieldCharacterCounter.attachTo = function (root) {\n        return new MDCTextFieldCharacterCounter(root);\n    };\n    Object.defineProperty(MDCTextFieldCharacterCounter.prototype, \"foundation\", {\n        get: function () {\n            return this.foundation_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldCharacterCounter.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        var adapter = {\n            setContent: function (content) {\n                _this.root_.textContent = content;\n            },\n        };\n        return new MDCTextFieldCharacterCounterFoundation(adapter);\n    };\n    return MDCTextFieldCharacterCounter;\n}(MDCComponent));\nexport { MDCTextFieldCharacterCounter };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    ROOT: 'mdc-text-field-character-counter',\n};\nvar strings = {\n    ROOT_SELECTOR: \".\" + cssClasses.ROOT,\n};\nexport { strings, cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, strings } from './constants';\nvar MDCTextFieldCharacterCounterFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldCharacterCounterFoundation, _super);\n    function MDCTextFieldCharacterCounterFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCTextFieldCharacterCounterFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCTextFieldCharacterCounterFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldCharacterCounterFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldCharacterCounterFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldCharacterCounterAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            return {\n                setContent: function () { return undefined; },\n            };\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldCharacterCounterFoundation.prototype.setCounterValue = function (currentLength, maxLength) {\n        currentLength = Math.min(currentLength, maxLength);\n        this.adapter_.setContent(currentLength + \" / \" + maxLength);\n    };\n    return MDCTextFieldCharacterCounterFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldCharacterCounterFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldCharacterCounterFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './foundation';\nexport { cssClasses as characterCountCssClasses, strings as characterCountStrings } from './constants';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { applyPassive } from '@material/dom/events';\nimport * as ponyfill from '@material/dom/ponyfill';\nimport { MDCFloatingLabel } from '@material/floating-label/component';\nimport { MDCLineRipple } from '@material/line-ripple/component';\nimport { MDCNotchedOutline } from '@material/notched-outline/component';\nimport { MDCRipple } from '@material/ripple/component';\nimport { MDCRippleFoundation } from '@material/ripple/foundation';\nimport { MDCTextFieldCharacterCounter, } from './character-counter/component';\nimport { MDCTextFieldCharacterCounterFoundation } from './character-counter/foundation';\nimport { cssClasses, strings } from './constants';\nimport { MDCTextFieldFoundation } from './foundation';\nimport { MDCTextFieldHelperText, } from './helper-text/component';\nimport { MDCTextFieldHelperTextFoundation } from './helper-text/foundation';\nimport { MDCTextFieldIcon } from './icon/component';\nvar MDCTextField = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextField, _super);\n    function MDCTextField() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextField.attachTo = function (root) {\n        return new MDCTextField(root);\n    };\n    MDCTextField.prototype.initialize = function (rippleFactory, lineRippleFactory, helperTextFactory, characterCounterFactory, iconFactory, labelFactory, outlineFactory) {\n        if (rippleFactory === void 0) { rippleFactory = function (el, foundation) { return new MDCRipple(el, foundation); }; }\n        if (lineRippleFactory === void 0) { lineRippleFactory = function (el) { return new MDCLineRipple(el); }; }\n        if (helperTextFactory === void 0) { helperTextFactory = function (el) { return new MDCTextFieldHelperText(el); }; }\n        if (characterCounterFactory === void 0) { characterCounterFactory = function (el) { return new MDCTextFieldCharacterCounter(el); }; }\n        if (iconFactory === void 0) { iconFactory = function (el) { return new MDCTextFieldIcon(el); }; }\n        if (labelFactory === void 0) { labelFactory = function (el) { return new MDCFloatingLabel(el); }; }\n        if (outlineFactory === void 0) { outlineFactory = function (el) { return new MDCNotchedOutline(el); }; }\n        this.input_ = this.root_.querySelector(strings.INPUT_SELECTOR);\n        var labelElement = this.root_.querySelector(strings.LABEL_SELECTOR);\n        this.label_ = labelElement ? labelFactory(labelElement) : null;\n        var lineRippleElement = this.root_.querySelector(strings.LINE_RIPPLE_SELECTOR);\n        this.lineRipple_ = lineRippleElement ? lineRippleFactory(lineRippleElement) : null;\n        var outlineElement = this.root_.querySelector(strings.OUTLINE_SELECTOR);\n        this.outline_ = outlineElement ? outlineFactory(outlineElement) : null;\n        // Helper text\n        var helperTextStrings = MDCTextFieldHelperTextFoundation.strings;\n        var nextElementSibling = this.root_.nextElementSibling;\n        var hasHelperLine = (nextElementSibling && nextElementSibling.classList.contains(cssClasses.HELPER_LINE));\n        var helperTextEl = hasHelperLine && nextElementSibling && nextElementSibling.querySelector(helperTextStrings.ROOT_SELECTOR);\n        this.helperText_ = helperTextEl ? helperTextFactory(helperTextEl) : null;\n        // Character counter\n        var characterCounterStrings = MDCTextFieldCharacterCounterFoundation.strings;\n        var characterCounterEl = this.root_.querySelector(characterCounterStrings.ROOT_SELECTOR);\n        // If character counter is not found in root element search in sibling element.\n        if (!characterCounterEl && hasHelperLine && nextElementSibling) {\n            characterCounterEl = nextElementSibling.querySelector(characterCounterStrings.ROOT_SELECTOR);\n        }\n        this.characterCounter_ = characterCounterEl ? characterCounterFactory(characterCounterEl) : null;\n        this.leadingIcon_ = null;\n        this.trailingIcon_ = null;\n        var iconElements = this.root_.querySelectorAll(strings.ICON_SELECTOR);\n        if (iconElements.length > 0) {\n            if (iconElements.length > 1) { // Has both icons.\n                this.leadingIcon_ = iconFactory(iconElements[0]);\n                this.trailingIcon_ = iconFactory(iconElements[1]);\n            }\n            else {\n                if (this.root_.classList.contains(cssClasses.WITH_LEADING_ICON)) {\n                    this.leadingIcon_ = iconFactory(iconElements[0]);\n                }\n                else {\n                    this.trailingIcon_ = iconFactory(iconElements[0]);\n                }\n            }\n        }\n        this.ripple = this.createRipple_(rippleFactory);\n    };\n    MDCTextField.prototype.destroy = function () {\n        if (this.ripple) {\n            this.ripple.destroy();\n        }\n        if (this.lineRipple_) {\n            this.lineRipple_.destroy();\n        }\n        if (this.helperText_) {\n            this.helperText_.destroy();\n        }\n        if (this.characterCounter_) {\n            this.characterCounter_.destroy();\n        }\n        if (this.leadingIcon_) {\n            this.leadingIcon_.destroy();\n        }\n        if (this.trailingIcon_) {\n            this.trailingIcon_.destroy();\n        }\n        if (this.label_) {\n            this.label_.destroy();\n        }\n        if (this.outline_) {\n            this.outline_.destroy();\n        }\n        _super.prototype.destroy.call(this);\n    };\n    /**\n     * Initializes the Text Field's internal state based on the environment's\n     * state.\n     */\n    MDCTextField.prototype.initialSyncWithDOM = function () {\n        this.disabled = this.input_.disabled;\n    };\n    Object.defineProperty(MDCTextField.prototype, \"value\", {\n        get: function () {\n            return this.foundation_.getValue();\n        },\n        /**\n         * @param value The value to set on the input.\n         */\n        set: function (value) {\n            this.foundation_.setValue(value);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"disabled\", {\n        get: function () {\n            return this.foundation_.isDisabled();\n        },\n        /**\n         * @param disabled Sets the Text Field disabled or enabled.\n         */\n        set: function (disabled) {\n            this.foundation_.setDisabled(disabled);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"valid\", {\n        get: function () {\n            return this.foundation_.isValid();\n        },\n        /**\n         * @param valid Sets the Text Field valid or invalid.\n         */\n        set: function (valid) {\n            this.foundation_.setValid(valid);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"required\", {\n        get: function () {\n            return this.input_.required;\n        },\n        /**\n         * @param required Sets the Text Field to required.\n         */\n        set: function (required) {\n            this.input_.required = required;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"pattern\", {\n        get: function () {\n            return this.input_.pattern;\n        },\n        /**\n         * @param pattern Sets the input element's validation pattern.\n         */\n        set: function (pattern) {\n            this.input_.pattern = pattern;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"minLength\", {\n        get: function () {\n            return this.input_.minLength;\n        },\n        /**\n         * @param minLength Sets the input element's minLength.\n         */\n        set: function (minLength) {\n            this.input_.minLength = minLength;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"maxLength\", {\n        get: function () {\n            return this.input_.maxLength;\n        },\n        /**\n         * @param maxLength Sets the input element's maxLength.\n         */\n        set: function (maxLength) {\n            // Chrome throws exception if maxLength is set to a value less than zero\n            if (maxLength < 0) {\n                this.input_.removeAttribute('maxLength');\n            }\n            else {\n                this.input_.maxLength = maxLength;\n            }\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"min\", {\n        get: function () {\n            return this.input_.min;\n        },\n        /**\n         * @param min Sets the input element's min.\n         */\n        set: function (min) {\n            this.input_.min = min;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"max\", {\n        get: function () {\n            return this.input_.max;\n        },\n        /**\n         * @param max Sets the input element's max.\n         */\n        set: function (max) {\n            this.input_.max = max;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"step\", {\n        get: function () {\n            return this.input_.step;\n        },\n        /**\n         * @param step Sets the input element's step.\n         */\n        set: function (step) {\n            this.input_.step = step;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"helperTextContent\", {\n        /**\n         * Sets the helper text element content.\n         */\n        set: function (content) {\n            this.foundation_.setHelperTextContent(content);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"leadingIconAriaLabel\", {\n        /**\n         * Sets the aria label of the leading icon.\n         */\n        set: function (label) {\n            this.foundation_.setLeadingIconAriaLabel(label);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"leadingIconContent\", {\n        /**\n         * Sets the text content of the leading icon.\n         */\n        set: function (content) {\n            this.foundation_.setLeadingIconContent(content);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"trailingIconAriaLabel\", {\n        /**\n         * Sets the aria label of the trailing icon.\n         */\n        set: function (label) {\n            this.foundation_.setTrailingIconAriaLabel(label);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"trailingIconContent\", {\n        /**\n         * Sets the text content of the trailing icon.\n         */\n        set: function (content) {\n            this.foundation_.setTrailingIconContent(content);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextField.prototype, \"useNativeValidation\", {\n        /**\n         * Enables or disables the use of native validation. Use this for custom validation.\n         * @param useNativeValidation Set this to false to ignore native input validation.\n         */\n        set: function (useNativeValidation) {\n            this.foundation_.setUseNativeValidation(useNativeValidation);\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /**\n     * Focuses the input element.\n     */\n    MDCTextField.prototype.focus = function () {\n        this.input_.focus();\n    };\n    /**\n     * Recomputes the outline SVG path for the outline element.\n     */\n    MDCTextField.prototype.layout = function () {\n        var openNotch = this.foundation_.shouldFloat;\n        this.foundation_.notchOutline(openNotch);\n    };\n    MDCTextField.prototype.getDefaultFoundation = function () {\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = tslib_1.__assign({}, this.getRootAdapterMethods_(), this.getInputAdapterMethods_(), this.getLabelAdapterMethods_(), this.getLineRippleAdapterMethods_(), this.getOutlineAdapterMethods_());\n        // tslint:enable:object-literal-sort-keys\n        return new MDCTextFieldFoundation(adapter, this.getFoundationMap_());\n    };\n    MDCTextField.prototype.getRootAdapterMethods_ = function () {\n        var _this = this;\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        return {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            registerTextFieldInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterTextFieldInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n            registerValidationAttributeChangeHandler: function (handler) {\n                var getAttributesList = function (mutationsList) {\n                    return mutationsList\n                        .map(function (mutation) { return mutation.attributeName; })\n                        .filter(function (attributeName) { return attributeName; });\n                };\n                var observer = new MutationObserver(function (mutationsList) { return handler(getAttributesList(mutationsList)); });\n                var config = { attributes: true };\n                observer.observe(_this.input_, config);\n                return observer;\n            },\n            deregisterValidationAttributeChangeHandler: function (observer) { return observer.disconnect(); },\n        };\n        // tslint:enable:object-literal-sort-keys\n    };\n    MDCTextField.prototype.getInputAdapterMethods_ = function () {\n        var _this = this;\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        return {\n            getNativeInput: function () { return _this.input_; },\n            isFocused: function () { return document.activeElement === _this.input_; },\n            registerInputInteractionHandler: function (evtType, handler) {\n                return _this.input_.addEventListener(evtType, handler, applyPassive());\n            },\n            deregisterInputInteractionHandler: function (evtType, handler) {\n                return _this.input_.removeEventListener(evtType, handler, applyPassive());\n            },\n        };\n        // tslint:enable:object-literal-sort-keys\n    };\n    MDCTextField.prototype.getLabelAdapterMethods_ = function () {\n        var _this = this;\n        return {\n            floatLabel: function (shouldFloat) { return _this.label_ && _this.label_.float(shouldFloat); },\n            getLabelWidth: function () { return _this.label_ ? _this.label_.getWidth() : 0; },\n            hasLabel: function () { return Boolean(_this.label_); },\n            shakeLabel: function (shouldShake) { return _this.label_ && _this.label_.shake(shouldShake); },\n        };\n    };\n    MDCTextField.prototype.getLineRippleAdapterMethods_ = function () {\n        var _this = this;\n        return {\n            activateLineRipple: function () {\n                if (_this.lineRipple_) {\n                    _this.lineRipple_.activate();\n                }\n            },\n            deactivateLineRipple: function () {\n                if (_this.lineRipple_) {\n                    _this.lineRipple_.deactivate();\n                }\n            },\n            setLineRippleTransformOrigin: function (normalizedX) {\n                if (_this.lineRipple_) {\n                    _this.lineRipple_.setRippleCenter(normalizedX);\n                }\n            },\n        };\n    };\n    MDCTextField.prototype.getOutlineAdapterMethods_ = function () {\n        var _this = this;\n        return {\n            closeOutline: function () { return _this.outline_ && _this.outline_.closeNotch(); },\n            hasOutline: function () { return Boolean(_this.outline_); },\n            notchOutline: function (labelWidth) { return _this.outline_ && _this.outline_.notch(labelWidth); },\n        };\n    };\n    /**\n     * @return A map of all subcomponents to subfoundations.\n     */\n    MDCTextField.prototype.getFoundationMap_ = function () {\n        return {\n            characterCounter: this.characterCounter_ ? this.characterCounter_.foundation : undefined,\n            helperText: this.helperText_ ? this.helperText_.foundation : undefined,\n            leadingIcon: this.leadingIcon_ ? this.leadingIcon_.foundation : undefined,\n            trailingIcon: this.trailingIcon_ ? this.trailingIcon_.foundation : undefined,\n        };\n    };\n    MDCTextField.prototype.createRipple_ = function (rippleFactory) {\n        var _this = this;\n        var isTextArea = this.root_.classList.contains(cssClasses.TEXTAREA);\n        var isOutlined = this.root_.classList.contains(cssClasses.OUTLINED);\n        if (isTextArea || isOutlined) {\n            return null;\n        }\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = tslib_1.__assign({}, MDCRipple.createAdapter(this), { isSurfaceActive: function () { return ponyfill.matches(_this.input_, ':active'); }, registerInteractionHandler: function (evtType, handler) { return _this.input_.addEventListener(evtType, handler, applyPassive()); }, deregisterInteractionHandler: function (evtType, handler) {\n                return _this.input_.removeEventListener(evtType, handler, applyPassive());\n            } });\n        // tslint:enable:object-literal-sort-keys\n        return rippleFactory(this.root_, new MDCRippleFoundation(adapter));\n    };\n    return MDCTextField;\n}(MDCComponent));\nexport { MDCTextField };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar strings = {\n    ARIA_CONTROLS: 'aria-controls',\n    ICON_SELECTOR: '.mdc-text-field__icon',\n    INPUT_SELECTOR: '.mdc-text-field__input',\n    LABEL_SELECTOR: '.mdc-floating-label',\n    LINE_RIPPLE_SELECTOR: '.mdc-line-ripple',\n    OUTLINE_SELECTOR: '.mdc-notched-outline',\n};\nvar cssClasses = {\n    DENSE: 'mdc-text-field--dense',\n    DISABLED: 'mdc-text-field--disabled',\n    FOCUSED: 'mdc-text-field--focused',\n    FULLWIDTH: 'mdc-text-field--fullwidth',\n    HELPER_LINE: 'mdc-text-field-helper-line',\n    INVALID: 'mdc-text-field--invalid',\n    NO_LABEL: 'mdc-text-field--no-label',\n    OUTLINED: 'mdc-text-field--outlined',\n    ROOT: 'mdc-text-field',\n    TEXTAREA: 'mdc-text-field--textarea',\n    WITH_LEADING_ICON: 'mdc-text-field--with-leading-icon',\n    WITH_TRAILING_ICON: 'mdc-text-field--with-trailing-icon',\n};\nvar numbers = {\n    DENSE_LABEL_SCALE: 0.923,\n    LABEL_SCALE: 0.75,\n};\n/**\n * Whitelist based off of https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/HTML5/Constraint_validation\n * under the \"Validation-related attributes\" section.\n */\nvar VALIDATION_ATTR_WHITELIST = [\n    'pattern', 'min', 'max', 'required', 'step', 'minlength', 'maxlength',\n];\n/**\n * Label should always float for these types as they show some UI even if value is empty.\n */\nvar ALWAYS_FLOAT_TYPES = [\n    'color', 'date', 'datetime-local', 'month', 'range', 'time', 'week',\n];\nexport { cssClasses, strings, numbers, VALIDATION_ATTR_WHITELIST, ALWAYS_FLOAT_TYPES };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { ALWAYS_FLOAT_TYPES, cssClasses, numbers, strings, VALIDATION_ATTR_WHITELIST } from './constants';\nvar POINTERDOWN_EVENTS = ['mousedown', 'touchstart'];\nvar INTERACTION_EVENTS = ['click', 'keydown'];\nvar MDCTextFieldFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldFoundation, _super);\n    /**\n     * @param adapter\n     * @param foundationMap Map from subcomponent names to their subfoundations.\n     */\n    function MDCTextFieldFoundation(adapter, foundationMap) {\n        if (foundationMap === void 0) { foundationMap = {}; }\n        var _this = _super.call(this, tslib_1.__assign({}, MDCTextFieldFoundation.defaultAdapter, adapter)) || this;\n        _this.isFocused_ = false;\n        _this.receivedUserInput_ = false;\n        _this.isValid_ = true;\n        _this.useNativeValidation_ = true;\n        _this.helperText_ = foundationMap.helperText;\n        _this.characterCounter_ = foundationMap.characterCounter;\n        _this.leadingIcon_ = foundationMap.leadingIcon;\n        _this.trailingIcon_ = foundationMap.trailingIcon;\n        _this.inputFocusHandler_ = function () { return _this.activateFocus(); };\n        _this.inputBlurHandler_ = function () { return _this.deactivateFocus(); };\n        _this.inputInputHandler_ = function () { return _this.handleInput(); };\n        _this.setPointerXOffset_ = function (evt) { return _this.setTransformOrigin(evt); };\n        _this.textFieldInteractionHandler_ = function () { return _this.handleTextFieldInteraction(); };\n        _this.validationAttributeChangeHandler_ = function (attributesList) { return _this.handleValidationAttributeChange(attributesList); };\n        return _this;\n    }\n    Object.defineProperty(MDCTextFieldFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation.prototype, \"shouldAlwaysFloat_\", {\n        get: function () {\n            var type = this.getNativeInput_().type;\n            return ALWAYS_FLOAT_TYPES.indexOf(type) >= 0;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation.prototype, \"shouldFloat\", {\n        get: function () {\n            return this.shouldAlwaysFloat_ || this.isFocused_ || Boolean(this.getValue()) || this.isBadInput_();\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation.prototype, \"shouldShake\", {\n        get: function () {\n            return !this.isFocused_ && !this.isValid() && Boolean(this.getValue());\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return true; },\n                registerTextFieldInteractionHandler: function () { return undefined; },\n                deregisterTextFieldInteractionHandler: function () { return undefined; },\n                registerInputInteractionHandler: function () { return undefined; },\n                deregisterInputInteractionHandler: function () { return undefined; },\n                registerValidationAttributeChangeHandler: function () { return new MutationObserver(function () { return undefined; }); },\n                deregisterValidationAttributeChangeHandler: function () { return undefined; },\n                getNativeInput: function () { return null; },\n                isFocused: function () { return false; },\n                activateLineRipple: function () { return undefined; },\n                deactivateLineRipple: function () { return undefined; },\n                setLineRippleTransformOrigin: function () { return undefined; },\n                shakeLabel: function () { return undefined; },\n                floatLabel: function () { return undefined; },\n                hasLabel: function () { return false; },\n                getLabelWidth: function () { return 0; },\n                hasOutline: function () { return false; },\n                notchOutline: function () { return undefined; },\n                closeOutline: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldFoundation.prototype.init = function () {\n        var _this = this;\n        if (this.adapter_.isFocused()) {\n            this.inputFocusHandler_();\n        }\n        else if (this.adapter_.hasLabel() && this.shouldFloat) {\n            this.notchOutline(true);\n            this.adapter_.floatLabel(true);\n        }\n        this.adapter_.registerInputInteractionHandler('focus', this.inputFocusHandler_);\n        this.adapter_.registerInputInteractionHandler('blur', this.inputBlurHandler_);\n        this.adapter_.registerInputInteractionHandler('input', this.inputInputHandler_);\n        POINTERDOWN_EVENTS.forEach(function (evtType) {\n            _this.adapter_.registerInputInteractionHandler(evtType, _this.setPointerXOffset_);\n        });\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.registerTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_);\n        });\n        this.validationObserver_ =\n            this.adapter_.registerValidationAttributeChangeHandler(this.validationAttributeChangeHandler_);\n        this.setCharacterCounter_(this.getValue().length);\n    };\n    MDCTextFieldFoundation.prototype.destroy = function () {\n        var _this = this;\n        this.adapter_.deregisterInputInteractionHandler('focus', this.inputFocusHandler_);\n        this.adapter_.deregisterInputInteractionHandler('blur', this.inputBlurHandler_);\n        this.adapter_.deregisterInputInteractionHandler('input', this.inputInputHandler_);\n        POINTERDOWN_EVENTS.forEach(function (evtType) {\n            _this.adapter_.deregisterInputInteractionHandler(evtType, _this.setPointerXOffset_);\n        });\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.deregisterTextFieldInteractionHandler(evtType, _this.textFieldInteractionHandler_);\n        });\n        this.adapter_.deregisterValidationAttributeChangeHandler(this.validationObserver_);\n    };\n    /**\n     * Handles user interactions with the Text Field.\n     */\n    MDCTextFieldFoundation.prototype.handleTextFieldInteraction = function () {\n        var nativeInput = this.adapter_.getNativeInput();\n        if (nativeInput && nativeInput.disabled) {\n            return;\n        }\n        this.receivedUserInput_ = true;\n    };\n    /**\n     * Handles validation attribute changes\n     */\n    MDCTextFieldFoundation.prototype.handleValidationAttributeChange = function (attributesList) {\n        var _this = this;\n        attributesList.some(function (attributeName) {\n            if (VALIDATION_ATTR_WHITELIST.indexOf(attributeName) > -1) {\n                _this.styleValidity_(true);\n                return true;\n            }\n            return false;\n        });\n        if (attributesList.indexOf('maxlength') > -1) {\n            this.setCharacterCounter_(this.getValue().length);\n        }\n    };\n    /**\n     * Opens/closes the notched outline.\n     */\n    MDCTextFieldFoundation.prototype.notchOutline = function (openNotch) {\n        if (!this.adapter_.hasOutline()) {\n            return;\n        }\n        if (openNotch) {\n            var isDense = this.adapter_.hasClass(cssClasses.DENSE);\n            var labelScale = isDense ? numbers.DENSE_LABEL_SCALE : numbers.LABEL_SCALE;\n            var labelWidth = this.adapter_.getLabelWidth() * labelScale;\n            this.adapter_.notchOutline(labelWidth);\n        }\n        else {\n            this.adapter_.closeOutline();\n        }\n    };\n    /**\n     * Activates the text field focus state.\n     */\n    MDCTextFieldFoundation.prototype.activateFocus = function () {\n        this.isFocused_ = true;\n        this.styleFocused_(this.isFocused_);\n        this.adapter_.activateLineRipple();\n        if (this.adapter_.hasLabel()) {\n            this.notchOutline(this.shouldFloat);\n            this.adapter_.floatLabel(this.shouldFloat);\n            this.adapter_.shakeLabel(this.shouldShake);\n        }\n        if (this.helperText_) {\n            this.helperText_.showToScreenReader();\n        }\n    };\n    /**\n     * Sets the line ripple's transform origin, so that the line ripple activate\n     * animation will animate out from the user's click location.\n     */\n    MDCTextFieldFoundation.prototype.setTransformOrigin = function (evt) {\n        var touches = evt.touches;\n        var targetEvent = touches ? touches[0] : evt;\n        var targetClientRect = targetEvent.target.getBoundingClientRect();\n        var normalizedX = targetEvent.clientX - targetClientRect.left;\n        this.adapter_.setLineRippleTransformOrigin(normalizedX);\n    };\n    /**\n     * Handles input change of text input and text area.\n     */\n    MDCTextFieldFoundation.prototype.handleInput = function () {\n        this.autoCompleteFocus();\n        this.setCharacterCounter_(this.getValue().length);\n    };\n    /**\n     * Activates the Text Field's focus state in cases when the input value\n     * changes without user input (e.g. programmatically).\n     */\n    MDCTextFieldFoundation.prototype.autoCompleteFocus = function () {\n        if (!this.receivedUserInput_) {\n            this.activateFocus();\n        }\n    };\n    /**\n     * Deactivates the Text Field's focus state.\n     */\n    MDCTextFieldFoundation.prototype.deactivateFocus = function () {\n        this.isFocused_ = false;\n        this.adapter_.deactivateLineRipple();\n        var isValid = this.isValid();\n        this.styleValidity_(isValid);\n        this.styleFocused_(this.isFocused_);\n        if (this.adapter_.hasLabel()) {\n            this.notchOutline(this.shouldFloat);\n            this.adapter_.floatLabel(this.shouldFloat);\n            this.adapter_.shakeLabel(this.shouldShake);\n        }\n        if (!this.shouldFloat) {\n            this.receivedUserInput_ = false;\n        }\n    };\n    MDCTextFieldFoundation.prototype.getValue = function () {\n        return this.getNativeInput_().value;\n    };\n    /**\n     * @param value The value to set on the input Element.\n     */\n    MDCTextFieldFoundation.prototype.setValue = function (value) {\n        // Prevent Safari from moving the caret to the end of the input when the value has not changed.\n        if (this.getValue() !== value) {\n            this.getNativeInput_().value = value;\n        }\n        this.setCharacterCounter_(value.length);\n        var isValid = this.isValid();\n        this.styleValidity_(isValid);\n        if (this.adapter_.hasLabel()) {\n            this.notchOutline(this.shouldFloat);\n            this.adapter_.floatLabel(this.shouldFloat);\n            this.adapter_.shakeLabel(this.shouldShake);\n        }\n    };\n    /**\n     * @return The custom validity state, if set; otherwise, the result of a native validity check.\n     */\n    MDCTextFieldFoundation.prototype.isValid = function () {\n        return this.useNativeValidation_\n            ? this.isNativeInputValid_() : this.isValid_;\n    };\n    /**\n     * @param isValid Sets the custom validity state of the Text Field.\n     */\n    MDCTextFieldFoundation.prototype.setValid = function (isValid) {\n        this.isValid_ = isValid;\n        this.styleValidity_(isValid);\n        var shouldShake = !isValid && !this.isFocused_;\n        if (this.adapter_.hasLabel()) {\n            this.adapter_.shakeLabel(shouldShake);\n        }\n    };\n    /**\n     * Enables or disables the use of native validation. Use this for custom validation.\n     * @param useNativeValidation Set this to false to ignore native input validation.\n     */\n    MDCTextFieldFoundation.prototype.setUseNativeValidation = function (useNativeValidation) {\n        this.useNativeValidation_ = useNativeValidation;\n    };\n    MDCTextFieldFoundation.prototype.isDisabled = function () {\n        return this.getNativeInput_().disabled;\n    };\n    /**\n     * @param disabled Sets the text-field disabled or enabled.\n     */\n    MDCTextFieldFoundation.prototype.setDisabled = function (disabled) {\n        this.getNativeInput_().disabled = disabled;\n        this.styleDisabled_(disabled);\n    };\n    /**\n     * @param content Sets the content of the helper text.\n     */\n    MDCTextFieldFoundation.prototype.setHelperTextContent = function (content) {\n        if (this.helperText_) {\n            this.helperText_.setContent(content);\n        }\n    };\n    /**\n     * Sets the aria label of the leading icon.\n     */\n    MDCTextFieldFoundation.prototype.setLeadingIconAriaLabel = function (label) {\n        if (this.leadingIcon_) {\n            this.leadingIcon_.setAriaLabel(label);\n        }\n    };\n    /**\n     * Sets the text content of the leading icon.\n     */\n    MDCTextFieldFoundation.prototype.setLeadingIconContent = function (content) {\n        if (this.leadingIcon_) {\n            this.leadingIcon_.setContent(content);\n        }\n    };\n    /**\n     * Sets the aria label of the trailing icon.\n     */\n    MDCTextFieldFoundation.prototype.setTrailingIconAriaLabel = function (label) {\n        if (this.trailingIcon_) {\n            this.trailingIcon_.setAriaLabel(label);\n        }\n    };\n    /**\n     * Sets the text content of the trailing icon.\n     */\n    MDCTextFieldFoundation.prototype.setTrailingIconContent = function (content) {\n        if (this.trailingIcon_) {\n            this.trailingIcon_.setContent(content);\n        }\n    };\n    /**\n     * Sets character counter values that shows characters used and the total character limit.\n     */\n    MDCTextFieldFoundation.prototype.setCharacterCounter_ = function (currentLength) {\n        if (!this.characterCounter_) {\n            return;\n        }\n        var maxLength = this.getNativeInput_().maxLength;\n        if (maxLength === -1) {\n            throw new Error('MDCTextFieldFoundation: Expected maxlength html property on text input or textarea.');\n        }\n        this.characterCounter_.setCounterValue(currentLength, maxLength);\n    };\n    /**\n     * @return True if the Text Field input fails in converting the user-supplied value.\n     */\n    MDCTextFieldFoundation.prototype.isBadInput_ = function () {\n        // The badInput property is not supported in IE 11 💩.\n        return this.getNativeInput_().validity.badInput || false;\n    };\n    /**\n     * @return The result of native validity checking (ValidityState.valid).\n     */\n    MDCTextFieldFoundation.prototype.isNativeInputValid_ = function () {\n        return this.getNativeInput_().validity.valid;\n    };\n    /**\n     * Styles the component based on the validity state.\n     */\n    MDCTextFieldFoundation.prototype.styleValidity_ = function (isValid) {\n        var INVALID = MDCTextFieldFoundation.cssClasses.INVALID;\n        if (isValid) {\n            this.adapter_.removeClass(INVALID);\n        }\n        else {\n            this.adapter_.addClass(INVALID);\n        }\n        if (this.helperText_) {\n            this.helperText_.setValidity(isValid);\n        }\n    };\n    /**\n     * Styles the component based on the focused state.\n     */\n    MDCTextFieldFoundation.prototype.styleFocused_ = function (isFocused) {\n        var FOCUSED = MDCTextFieldFoundation.cssClasses.FOCUSED;\n        if (isFocused) {\n            this.adapter_.addClass(FOCUSED);\n        }\n        else {\n            this.adapter_.removeClass(FOCUSED);\n        }\n    };\n    /**\n     * Styles the component based on the disabled state.\n     */\n    MDCTextFieldFoundation.prototype.styleDisabled_ = function (isDisabled) {\n        var _a = MDCTextFieldFoundation.cssClasses, DISABLED = _a.DISABLED, INVALID = _a.INVALID;\n        if (isDisabled) {\n            this.adapter_.addClass(DISABLED);\n            this.adapter_.removeClass(INVALID);\n        }\n        else {\n            this.adapter_.removeClass(DISABLED);\n        }\n        if (this.leadingIcon_) {\n            this.leadingIcon_.setDisabled(isDisabled);\n        }\n        if (this.trailingIcon_) {\n            this.trailingIcon_.setDisabled(isDisabled);\n        }\n    };\n    /**\n     * @return The native text input element from the host environment, or an object with the same shape for unit tests.\n     */\n    MDCTextFieldFoundation.prototype.getNativeInput_ = function () {\n        // this.adapter_ may be undefined in foundation unit tests. This happens when testdouble is creating a mock object\n        // and invokes the shouldShake/shouldFloat getters (which in turn call getValue(), which calls this method) before\n        // init() has been called from the MDCTextField constructor. To work around that issue, we return a dummy object.\n        var nativeInput = this.adapter_ ? this.adapter_.getNativeInput() : null;\n        return nativeInput || {\n            disabled: false,\n            maxLength: -1,\n            type: 'input',\n            validity: {\n                badInput: false,\n                valid: true,\n            },\n            value: '',\n        };\n    };\n    return MDCTextFieldFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCTextFieldHelperTextFoundation } from './foundation';\nvar MDCTextFieldHelperText = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldHelperText, _super);\n    function MDCTextFieldHelperText() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextFieldHelperText.attachTo = function (root) {\n        return new MDCTextFieldHelperText(root);\n    };\n    Object.defineProperty(MDCTextFieldHelperText.prototype, \"foundation\", {\n        get: function () {\n            return this.foundation_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldHelperText.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); },\n            removeAttr: function (attr) { return _this.root_.removeAttribute(attr); },\n            setContent: function (content) {\n                _this.root_.textContent = content;\n            },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCTextFieldHelperTextFoundation(adapter);\n    };\n    return MDCTextFieldHelperText;\n}(MDCComponent));\nexport { MDCTextFieldHelperText };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    HELPER_TEXT_PERSISTENT: 'mdc-text-field-helper-text--persistent',\n    HELPER_TEXT_VALIDATION_MSG: 'mdc-text-field-helper-text--validation-msg',\n    ROOT: 'mdc-text-field-helper-text',\n};\nvar strings = {\n    ARIA_HIDDEN: 'aria-hidden',\n    ROLE: 'role',\n    ROOT_SELECTOR: \".\" + cssClasses.ROOT,\n};\nexport { strings, cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, strings } from './constants';\nvar MDCTextFieldHelperTextFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldHelperTextFoundation, _super);\n    function MDCTextFieldHelperTextFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCTextFieldHelperTextFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCTextFieldHelperTextFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldHelperTextFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldHelperTextFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldHelperTextAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return false; },\n                setAttr: function () { return undefined; },\n                removeAttr: function () { return undefined; },\n                setContent: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /**\n     * Sets the content of the helper text field.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setContent = function (content) {\n        this.adapter_.setContent(content);\n    };\n    /**\n     * @param isPersistent Sets the persistency of the helper text.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setPersistent = function (isPersistent) {\n        if (isPersistent) {\n            this.adapter_.addClass(cssClasses.HELPER_TEXT_PERSISTENT);\n        }\n        else {\n            this.adapter_.removeClass(cssClasses.HELPER_TEXT_PERSISTENT);\n        }\n    };\n    /**\n     * @param isValidation True to make the helper text act as an error validation message.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setValidation = function (isValidation) {\n        if (isValidation) {\n            this.adapter_.addClass(cssClasses.HELPER_TEXT_VALIDATION_MSG);\n        }\n        else {\n            this.adapter_.removeClass(cssClasses.HELPER_TEXT_VALIDATION_MSG);\n        }\n    };\n    /**\n     * Makes the helper text visible to the screen reader.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.showToScreenReader = function () {\n        this.adapter_.removeAttr(strings.ARIA_HIDDEN);\n    };\n    /**\n     * Sets the validity of the helper text based on the input validity.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.setValidity = function (inputIsValid) {\n        var helperTextIsPersistent = this.adapter_.hasClass(cssClasses.HELPER_TEXT_PERSISTENT);\n        var helperTextIsValidationMsg = this.adapter_.hasClass(cssClasses.HELPER_TEXT_VALIDATION_MSG);\n        var validationMsgNeedsDisplay = helperTextIsValidationMsg && !inputIsValid;\n        if (validationMsgNeedsDisplay) {\n            this.adapter_.setAttr(strings.ROLE, 'alert');\n        }\n        else {\n            this.adapter_.removeAttr(strings.ROLE);\n        }\n        if (!helperTextIsPersistent && !validationMsgNeedsDisplay) {\n            this.hide_();\n        }\n    };\n    /**\n     * Hides the help text from screen readers.\n     */\n    MDCTextFieldHelperTextFoundation.prototype.hide_ = function () {\n        this.adapter_.setAttr(strings.ARIA_HIDDEN, 'true');\n    };\n    return MDCTextFieldHelperTextFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldHelperTextFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldHelperTextFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './foundation';\nexport { cssClasses as helperTextCssClasses, strings as helperTextStrings } from './constants';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCTextFieldIconFoundation } from './foundation';\nvar MDCTextFieldIcon = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldIcon, _super);\n    function MDCTextFieldIcon() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTextFieldIcon.attachTo = function (root) {\n        return new MDCTextFieldIcon(root);\n    };\n    Object.defineProperty(MDCTextFieldIcon.prototype, \"foundation\", {\n        get: function () {\n            return this.foundation_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldIcon.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            getAttr: function (attr) { return _this.root_.getAttribute(attr); },\n            setAttr: function (attr, value) { return _this.root_.setAttribute(attr, value); },\n            removeAttr: function (attr) { return _this.root_.removeAttribute(attr); },\n            setContent: function (content) {\n                _this.root_.textContent = content;\n            },\n            registerInteractionHandler: function (evtType, handler) { return _this.listen(evtType, handler); },\n            deregisterInteractionHandler: function (evtType, handler) { return _this.unlisten(evtType, handler); },\n            notifyIconAction: function () { return _this.emit(MDCTextFieldIconFoundation.strings.ICON_EVENT, {} /* evtData */, true /* shouldBubble */); },\n        };\n        // tslint:enable:object-literal-sort-keys\n        return new MDCTextFieldIconFoundation(adapter);\n    };\n    return MDCTextFieldIcon;\n}(MDCComponent));\nexport { MDCTextFieldIcon };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2016 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar strings = {\n    ICON_EVENT: 'MDCTextField:icon',\n    ICON_ROLE: 'button',\n};\nvar cssClasses = {\n    ROOT: 'mdc-text-field__icon',\n};\nexport { strings, cssClasses };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2017 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, strings } from './constants';\nvar INTERACTION_EVENTS = ['click', 'keydown'];\nvar MDCTextFieldIconFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTextFieldIconFoundation, _super);\n    function MDCTextFieldIconFoundation(adapter) {\n        var _this = _super.call(this, tslib_1.__assign({}, MDCTextFieldIconFoundation.defaultAdapter, adapter)) || this;\n        _this.savedTabIndex_ = null;\n        _this.interactionHandler_ = function (evt) { return _this.handleInteraction(evt); };\n        return _this;\n    }\n    Object.defineProperty(MDCTextFieldIconFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldIconFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTextFieldIconFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTextFieldIconAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                getAttr: function () { return null; },\n                setAttr: function () { return undefined; },\n                removeAttr: function () { return undefined; },\n                setContent: function () { return undefined; },\n                registerInteractionHandler: function () { return undefined; },\n                deregisterInteractionHandler: function () { return undefined; },\n                notifyIconAction: function () { return undefined; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCTextFieldIconFoundation.prototype.init = function () {\n        var _this = this;\n        this.savedTabIndex_ = this.adapter_.getAttr('tabindex');\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.registerInteractionHandler(evtType, _this.interactionHandler_);\n        });\n    };\n    MDCTextFieldIconFoundation.prototype.destroy = function () {\n        var _this = this;\n        INTERACTION_EVENTS.forEach(function (evtType) {\n            _this.adapter_.deregisterInteractionHandler(evtType, _this.interactionHandler_);\n        });\n    };\n    MDCTextFieldIconFoundation.prototype.setDisabled = function (disabled) {\n        if (!this.savedTabIndex_) {\n            return;\n        }\n        if (disabled) {\n            this.adapter_.setAttr('tabindex', '-1');\n            this.adapter_.removeAttr('role');\n        }\n        else {\n            this.adapter_.setAttr('tabindex', this.savedTabIndex_);\n            this.adapter_.setAttr('role', strings.ICON_ROLE);\n        }\n    };\n    MDCTextFieldIconFoundation.prototype.setAriaLabel = function (label) {\n        this.adapter_.setAttr('aria-label', label);\n    };\n    MDCTextFieldIconFoundation.prototype.setContent = function (content) {\n        this.adapter_.setContent(content);\n    };\n    MDCTextFieldIconFoundation.prototype.handleInteraction = function (evt) {\n        var isEnterKey = evt.key === 'Enter' || evt.keyCode === 13;\n        if (evt.type === 'click' || isEnterKey) {\n            this.adapter_.notifyIconAction();\n        }\n    };\n    return MDCTextFieldIconFoundation;\n}(MDCFoundation));\nexport { MDCTextFieldIconFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTextFieldIconFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './foundation';\nexport { cssClasses as iconCssClasses, strings as iconStrings } from './constants';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './constants';\nexport * from './foundation';\nexport * from './character-counter/index';\nexport * from './helper-text/index';\nexport * from './icon/index';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCComponent } from '@material/base/component';\nimport { MDCRipple } from '@material/ripple/component';\nimport { cssClasses, strings } from './constants';\nimport { MDCFixedTopAppBarFoundation } from './fixed/foundation';\nimport { MDCShortTopAppBarFoundation } from './short/foundation';\nimport { MDCTopAppBarFoundation } from './standard/foundation';\nvar MDCTopAppBar = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTopAppBar, _super);\n    function MDCTopAppBar() {\n        return _super !== null && _super.apply(this, arguments) || this;\n    }\n    MDCTopAppBar.attachTo = function (root) {\n        return new MDCTopAppBar(root);\n    };\n    MDCTopAppBar.prototype.initialize = function (rippleFactory) {\n        if (rippleFactory === void 0) { rippleFactory = function (el) { return MDCRipple.attachTo(el); }; }\n        this.navIcon_ = this.root_.querySelector(strings.NAVIGATION_ICON_SELECTOR);\n        // Get all icons in the toolbar and instantiate the ripples\n        var icons = [].slice.call(this.root_.querySelectorAll(strings.ACTION_ITEM_SELECTOR));\n        if (this.navIcon_) {\n            icons.push(this.navIcon_);\n        }\n        this.iconRipples_ = icons.map(function (icon) {\n            var ripple = rippleFactory(icon);\n            ripple.unbounded = true;\n            return ripple;\n        });\n        this.scrollTarget_ = window;\n    };\n    MDCTopAppBar.prototype.initialSyncWithDOM = function () {\n        this.handleNavigationClick_ = this.foundation_.handleNavigationClick.bind(this.foundation_);\n        this.handleWindowResize_ = this.foundation_.handleWindowResize.bind(this.foundation_);\n        this.handleTargetScroll_ = this.foundation_.handleTargetScroll.bind(this.foundation_);\n        this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_);\n        if (this.navIcon_) {\n            this.navIcon_.addEventListener('click', this.handleNavigationClick_);\n        }\n        var isFixed = this.root_.classList.contains(cssClasses.FIXED_CLASS);\n        var isShort = this.root_.classList.contains(cssClasses.SHORT_CLASS);\n        if (!isShort && !isFixed) {\n            window.addEventListener('resize', this.handleWindowResize_);\n        }\n    };\n    MDCTopAppBar.prototype.destroy = function () {\n        this.iconRipples_.forEach(function (iconRipple) { return iconRipple.destroy(); });\n        this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_);\n        if (this.navIcon_) {\n            this.navIcon_.removeEventListener('click', this.handleNavigationClick_);\n        }\n        var isFixed = this.root_.classList.contains(cssClasses.FIXED_CLASS);\n        var isShort = this.root_.classList.contains(cssClasses.SHORT_CLASS);\n        if (!isShort && !isFixed) {\n            window.removeEventListener('resize', this.handleWindowResize_);\n        }\n        _super.prototype.destroy.call(this);\n    };\n    MDCTopAppBar.prototype.setScrollTarget = function (target) {\n        // Remove scroll handler from the previous scroll target\n        this.scrollTarget_.removeEventListener('scroll', this.handleTargetScroll_);\n        this.scrollTarget_ = target;\n        // Initialize scroll handler on the new scroll target\n        this.handleTargetScroll_ =\n            this.foundation_.handleTargetScroll.bind(this.foundation_);\n        this.scrollTarget_.addEventListener('scroll', this.handleTargetScroll_);\n    };\n    MDCTopAppBar.prototype.getDefaultFoundation = function () {\n        var _this = this;\n        // DO NOT INLINE this variable. For backward compatibility, foundations take a Partial<MDCFooAdapter>.\n        // To ensure we don't accidentally omit any methods, we need a separate, strongly typed adapter variable.\n        // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n        var adapter = {\n            hasClass: function (className) { return _this.root_.classList.contains(className); },\n            addClass: function (className) { return _this.root_.classList.add(className); },\n            removeClass: function (className) { return _this.root_.classList.remove(className); },\n            setStyle: function (property, value) { return _this.root_.style.setProperty(property, value); },\n            getTopAppBarHeight: function () { return _this.root_.clientHeight; },\n            notifyNavigationIconClicked: function () { return _this.emit(strings.NAVIGATION_EVENT, {}); },\n            getViewportScrollY: function () {\n                var win = _this.scrollTarget_;\n                var el = _this.scrollTarget_;\n                return win.pageYOffset !== undefined ? win.pageYOffset : el.scrollTop;\n            },\n            getTotalActionItems: function () { return _this.root_.querySelectorAll(strings.ACTION_ITEM_SELECTOR).length; },\n        };\n        // tslint:enable:object-literal-sort-keys\n        var foundation;\n        if (this.root_.classList.contains(cssClasses.SHORT_CLASS)) {\n            foundation = new MDCShortTopAppBarFoundation(adapter);\n        }\n        else if (this.root_.classList.contains(cssClasses.FIXED_CLASS)) {\n            foundation = new MDCFixedTopAppBarFoundation(adapter);\n        }\n        else {\n            foundation = new MDCTopAppBarFoundation(adapter);\n        }\n        return foundation;\n    };\n    return MDCTopAppBar;\n}(MDCComponent));\nexport { MDCTopAppBar };\n//# sourceMappingURL=component.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nvar cssClasses = {\n    FIXED_CLASS: 'mdc-top-app-bar--fixed',\n    FIXED_SCROLLED_CLASS: 'mdc-top-app-bar--fixed-scrolled',\n    SHORT_CLASS: 'mdc-top-app-bar--short',\n    SHORT_COLLAPSED_CLASS: 'mdc-top-app-bar--short-collapsed',\n    SHORT_HAS_ACTION_ITEM_CLASS: 'mdc-top-app-bar--short-has-action-item',\n};\nvar numbers = {\n    DEBOUNCE_THROTTLE_RESIZE_TIME_MS: 100,\n    MAX_TOP_APP_BAR_HEIGHT: 128,\n};\nvar strings = {\n    ACTION_ITEM_SELECTOR: '.mdc-top-app-bar__action-item',\n    NAVIGATION_EVENT: 'MDCTopAppBar:nav',\n    NAVIGATION_ICON_SELECTOR: '.mdc-top-app-bar__navigation-icon',\n    ROOT_SELECTOR: '.mdc-top-app-bar',\n    TITLE_SELECTOR: '.mdc-top-app-bar__title',\n};\nexport { cssClasses, numbers, strings };\n//# sourceMappingURL=constants.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { cssClasses } from '../constants';\nimport { MDCTopAppBarFoundation } from '../standard/foundation';\nvar MDCFixedTopAppBarFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCFixedTopAppBarFoundation, _super);\n    function MDCFixedTopAppBarFoundation() {\n        var _this = _super !== null && _super.apply(this, arguments) || this;\n        /**\n         * State variable for the previous scroll iteration top app bar state\n         */\n        _this.wasScrolled_ = false;\n        return _this;\n    }\n    /**\n     * Scroll handler for applying/removing the modifier class on the fixed top app bar.\n     * @override\n     */\n    MDCFixedTopAppBarFoundation.prototype.handleTargetScroll = function () {\n        var currentScroll = this.adapter_.getViewportScrollY();\n        if (currentScroll <= 0) {\n            if (this.wasScrolled_) {\n                this.adapter_.removeClass(cssClasses.FIXED_SCROLLED_CLASS);\n                this.wasScrolled_ = false;\n            }\n        }\n        else {\n            if (!this.wasScrolled_) {\n                this.adapter_.addClass(cssClasses.FIXED_SCROLLED_CLASS);\n                this.wasScrolled_ = true;\n            }\n        }\n    };\n    return MDCFixedTopAppBarFoundation;\n}(MDCTopAppBarFoundation));\nexport { MDCFixedTopAppBarFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCFixedTopAppBarFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { MDCFoundation } from '@material/base/foundation';\nimport { cssClasses, numbers, strings } from './constants';\nvar MDCTopAppBarBaseFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTopAppBarBaseFoundation, _super);\n    /* istanbul ignore next: optional argument is not a branch statement */\n    function MDCTopAppBarBaseFoundation(adapter) {\n        return _super.call(this, tslib_1.__assign({}, MDCTopAppBarBaseFoundation.defaultAdapter, adapter)) || this;\n    }\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"strings\", {\n        get: function () {\n            return strings;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"cssClasses\", {\n        get: function () {\n            return cssClasses;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"numbers\", {\n        get: function () {\n            return numbers;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    Object.defineProperty(MDCTopAppBarBaseFoundation, \"defaultAdapter\", {\n        /**\n         * See {@link MDCTopAppBarAdapter} for typing information on parameters and return types.\n         */\n        get: function () {\n            // tslint:disable:object-literal-sort-keys Methods should be in the same order as the adapter interface.\n            return {\n                addClass: function () { return undefined; },\n                removeClass: function () { return undefined; },\n                hasClass: function () { return false; },\n                setStyle: function () { return undefined; },\n                getTopAppBarHeight: function () { return 0; },\n                notifyNavigationIconClicked: function () { return undefined; },\n                getViewportScrollY: function () { return 0; },\n                getTotalActionItems: function () { return 0; },\n            };\n            // tslint:enable:object-literal-sort-keys\n        },\n        enumerable: true,\n        configurable: true\n    });\n    /** Other variants of TopAppBar foundation overrides this method */\n    MDCTopAppBarBaseFoundation.prototype.handleTargetScroll = function () { }; // tslint:disable-line:no-empty\n    /** Other variants of TopAppBar foundation overrides this method */\n    MDCTopAppBarBaseFoundation.prototype.handleWindowResize = function () { }; // tslint:disable-line:no-empty\n    MDCTopAppBarBaseFoundation.prototype.handleNavigationClick = function () {\n        this.adapter_.notifyNavigationIconClicked();\n    };\n    return MDCTopAppBarBaseFoundation;\n}(MDCFoundation));\nexport { MDCTopAppBarBaseFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTopAppBarBaseFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2019 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nexport * from './component';\nexport * from './constants';\nexport * from './foundation';\nexport * from './fixed/foundation';\nexport * from './short/foundation';\nexport * from './standard/foundation';\n//# sourceMappingURL=index.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { cssClasses } from '../constants';\nimport { MDCTopAppBarBaseFoundation } from '../foundation';\nvar MDCShortTopAppBarFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCShortTopAppBarFoundation, _super);\n    /* istanbul ignore next: optional argument is not a branch statement */\n    function MDCShortTopAppBarFoundation(adapter) {\n        var _this = _super.call(this, adapter) || this;\n        _this.isCollapsed_ = false;\n        _this.isAlwaysCollapsed_ = false;\n        return _this;\n    }\n    Object.defineProperty(MDCShortTopAppBarFoundation.prototype, \"isCollapsed\", {\n        // Public visibility for backward compatibility.\n        get: function () {\n            return this.isCollapsed_;\n        },\n        enumerable: true,\n        configurable: true\n    });\n    MDCShortTopAppBarFoundation.prototype.init = function () {\n        _super.prototype.init.call(this);\n        if (this.adapter_.getTotalActionItems() > 0) {\n            this.adapter_.addClass(cssClasses.SHORT_HAS_ACTION_ITEM_CLASS);\n        }\n        // If initialized with SHORT_COLLAPSED_CLASS, the bar should always be collapsed\n        this.setAlwaysCollapsed(this.adapter_.hasClass(cssClasses.SHORT_COLLAPSED_CLASS));\n    };\n    /**\n     * Set if the short top app bar should always be collapsed.\n     *\n     * @param value When `true`, bar will always be collapsed. When `false`, bar may collapse or expand based on scroll.\n     */\n    MDCShortTopAppBarFoundation.prototype.setAlwaysCollapsed = function (value) {\n        this.isAlwaysCollapsed_ = !!value;\n        if (this.isAlwaysCollapsed_) {\n            this.collapse_();\n        }\n        else {\n            // let maybeCollapseBar_ determine if the bar should be collapsed\n            this.maybeCollapseBar_();\n        }\n    };\n    MDCShortTopAppBarFoundation.prototype.getAlwaysCollapsed = function () {\n        return this.isAlwaysCollapsed_;\n    };\n    /**\n     * Scroll handler for applying/removing the collapsed modifier class on the short top app bar.\n     * @override\n     */\n    MDCShortTopAppBarFoundation.prototype.handleTargetScroll = function () {\n        this.maybeCollapseBar_();\n    };\n    MDCShortTopAppBarFoundation.prototype.maybeCollapseBar_ = function () {\n        if (this.isAlwaysCollapsed_) {\n            return;\n        }\n        var currentScroll = this.adapter_.getViewportScrollY();\n        if (currentScroll <= 0) {\n            if (this.isCollapsed_) {\n                this.uncollapse_();\n            }\n        }\n        else {\n            if (!this.isCollapsed_) {\n                this.collapse_();\n            }\n        }\n    };\n    MDCShortTopAppBarFoundation.prototype.uncollapse_ = function () {\n        this.adapter_.removeClass(cssClasses.SHORT_COLLAPSED_CLASS);\n        this.isCollapsed_ = false;\n    };\n    MDCShortTopAppBarFoundation.prototype.collapse_ = function () {\n        this.adapter_.addClass(cssClasses.SHORT_COLLAPSED_CLASS);\n        this.isCollapsed_ = true;\n    };\n    return MDCShortTopAppBarFoundation;\n}(MDCTopAppBarBaseFoundation));\nexport { MDCShortTopAppBarFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCShortTopAppBarFoundation;\n//# sourceMappingURL=foundation.js.map","/**\n * @license\n * Copyright 2018 Google Inc.\n *\n * Permission is hereby granted, free of charge, to any person obtaining a copy\n * of this software and associated documentation files (the \"Software\"), to deal\n * in the Software without restriction, including without limitation the rights\n * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n * copies of the Software, and to permit persons to whom the Software is\n * furnished to do so, subject to the following conditions:\n *\n * The above copyright notice and this permission notice shall be included in\n * all copies or substantial portions of the Software.\n *\n * THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n * THE SOFTWARE.\n */\nimport * as tslib_1 from \"tslib\";\nimport { numbers } from '../constants';\nimport { MDCTopAppBarBaseFoundation } from '../foundation';\nvar INITIAL_VALUE = 0;\nvar MDCTopAppBarFoundation = /** @class */ (function (_super) {\n    tslib_1.__extends(MDCTopAppBarFoundation, _super);\n    /* istanbul ignore next: optional argument is not a branch statement */\n    function MDCTopAppBarFoundation(adapter) {\n        var _this = _super.call(this, adapter) || this;\n        /**\n         * Indicates if the top app bar was docked in the previous scroll handler iteration.\n         */\n        _this.wasDocked_ = true;\n        /**\n         * Indicates if the top app bar is docked in the fully shown position.\n         */\n        _this.isDockedShowing_ = true;\n        /**\n         * Variable for current scroll position of the top app bar\n         */\n        _this.currentAppBarOffsetTop_ = 0;\n        /**\n         * Used to prevent the top app bar from being scrolled out of view during resize events\n         */\n        _this.isCurrentlyBeingResized_ = false;\n        /**\n         * The timeout that's used to throttle the resize events\n         */\n        _this.resizeThrottleId_ = INITIAL_VALUE;\n        /**\n         * The timeout that's used to debounce toggling the isCurrentlyBeingResized_ variable after a resize\n         */\n        _this.resizeDebounceId_ = INITIAL_VALUE;\n        _this.lastScrollPosition_ = _this.adapter_.getViewportScrollY();\n        _this.topAppBarHeight_ = _this.adapter_.getTopAppBarHeight();\n        return _this;\n    }\n    MDCTopAppBarFoundation.prototype.destroy = function () {\n        _super.prototype.destroy.call(this);\n        this.adapter_.setStyle('top', '');\n    };\n    /**\n     * Scroll handler for the default scroll behavior of the top app bar.\n     * @override\n     */\n    MDCTopAppBarFoundation.prototype.handleTargetScroll = function () {\n        var currentScrollPosition = Math.max(this.adapter_.getViewportScrollY(), 0);\n        var diff = currentScrollPosition - this.lastScrollPosition_;\n        this.lastScrollPosition_ = currentScrollPosition;\n        // If the window is being resized the lastScrollPosition_ needs to be updated but the\n        // current scroll of the top app bar should stay in the same position.\n        if (!this.isCurrentlyBeingResized_) {\n            this.currentAppBarOffsetTop_ -= diff;\n            if (this.currentAppBarOffsetTop_ > 0) {\n                this.currentAppBarOffsetTop_ = 0;\n            }\n            else if (Math.abs(this.currentAppBarOffsetTop_) > this.topAppBarHeight_) {\n                this.currentAppBarOffsetTop_ = -this.topAppBarHeight_;\n            }\n            this.moveTopAppBar_();\n        }\n    };\n    /**\n     * Top app bar resize handler that throttle/debounce functions that execute updates.\n     * @override\n     */\n    MDCTopAppBarFoundation.prototype.handleWindowResize = function () {\n        var _this = this;\n        // Throttle resize events 10 p/s\n        if (!this.resizeThrottleId_) {\n            this.resizeThrottleId_ = setTimeout(function () {\n                _this.resizeThrottleId_ = INITIAL_VALUE;\n                _this.throttledResizeHandler_();\n            }, numbers.DEBOUNCE_THROTTLE_RESIZE_TIME_MS);\n        }\n        this.isCurrentlyBeingResized_ = true;\n        if (this.resizeDebounceId_) {\n            clearTimeout(this.resizeDebounceId_);\n        }\n        this.resizeDebounceId_ = setTimeout(function () {\n            _this.handleTargetScroll();\n            _this.isCurrentlyBeingResized_ = false;\n            _this.resizeDebounceId_ = INITIAL_VALUE;\n        }, numbers.DEBOUNCE_THROTTLE_RESIZE_TIME_MS);\n    };\n    /**\n     * Function to determine if the DOM needs to update.\n     */\n    MDCTopAppBarFoundation.prototype.checkForUpdate_ = function () {\n        var offscreenBoundaryTop = -this.topAppBarHeight_;\n        var hasAnyPixelsOffscreen = this.currentAppBarOffsetTop_ < 0;\n        var hasAnyPixelsOnscreen = this.currentAppBarOffsetTop_ > offscreenBoundaryTop;\n        var partiallyShowing = hasAnyPixelsOffscreen && hasAnyPixelsOnscreen;\n        // If it's partially showing, it can't be docked.\n        if (partiallyShowing) {\n            this.wasDocked_ = false;\n        }\n        else {\n            // Not previously docked and not partially showing, it's now docked.\n            if (!this.wasDocked_) {\n                this.wasDocked_ = true;\n                return true;\n            }\n            else if (this.isDockedShowing_ !== hasAnyPixelsOnscreen) {\n                this.isDockedShowing_ = hasAnyPixelsOnscreen;\n                return true;\n            }\n        }\n        return partiallyShowing;\n    };\n    /**\n     * Function to move the top app bar if needed.\n     */\n    MDCTopAppBarFoundation.prototype.moveTopAppBar_ = function () {\n        if (this.checkForUpdate_()) {\n            // Once the top app bar is fully hidden we use the max potential top app bar height as our offset\n            // so the top app bar doesn't show if the window resizes and the new height > the old height.\n            var offset = this.currentAppBarOffsetTop_;\n            if (Math.abs(offset) >= this.topAppBarHeight_) {\n                offset = -numbers.MAX_TOP_APP_BAR_HEIGHT;\n            }\n            this.adapter_.setStyle('top', offset + 'px');\n        }\n    };\n    /**\n     * Throttled function that updates the top app bar scrolled values if the\n     * top app bar height changes.\n     */\n    MDCTopAppBarFoundation.prototype.throttledResizeHandler_ = function () {\n        var currentHeight = this.adapter_.getTopAppBarHeight();\n        if (this.topAppBarHeight_ !== currentHeight) {\n            this.wasDocked_ = false;\n            // Since the top app bar has a different height depending on the screen width, this\n            // will ensure that the top app bar remains in the correct location if\n            // completely hidden and a resize makes the top app bar a different height.\n            this.currentAppBarOffsetTop_ -= this.topAppBarHeight_ - currentHeight;\n            this.topAppBarHeight_ = currentHeight;\n        }\n        this.handleTargetScroll();\n    };\n    return MDCTopAppBarFoundation;\n}(MDCTopAppBarBaseFoundation));\nexport { MDCTopAppBarFoundation };\n// tslint:disable-next-line:no-default-export Needed for backward compatibility with MDC Web v0.44.0 and earlier.\nexport default MDCTopAppBarFoundation;\n//# sourceMappingURL=foundation.js.map","(function(f){if(typeof exports===\"object\"&&typeof module!==\"undefined\"){module.exports=f()}else if(typeof define===\"function\"&&define.amd){define([],f)}else{var g;if(typeof window!==\"undefined\"){g=window}else if(typeof global!==\"undefined\"){g=global}else if(typeof self!==\"undefined\"){g=self}else{g=this}g.Parallax = f()}})(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){\n/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n\n},{}],2:[function(require,module,exports){\n(function (process){\n// Generated by CoffeeScript 1.12.2\n(function() {\n  var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - nodeLoadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    moduleLoadTime = getNanoSeconds();\n    upTime = process.uptime() * 1e9;\n    nodeLoadTime = moduleLoadTime - upTime;\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n\n\n\n}).call(this,require('_process'))\n\n},{\"_process\":3}],3:[function(require,module,exports){\n// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n\n},{}],4:[function(require,module,exports){\n(function (global){\nvar now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n\n}).call(this,typeof global !== \"undefined\" ? global : typeof self !== \"undefined\" ? self : typeof window !== \"undefined\" ? window : {})\n\n},{\"performance-now\":2}],5:[function(require,module,exports){\n'use strict';\n\nvar _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\n/**\n* Parallax.js\n* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org\n* @description Creates a parallax effect between an array of layers,\n*              driving the motion from the gyroscope output of a smartdevice.\n*              If no gyroscope is available, the cursor position is used.\n*/\n\nvar rqAnFr = require('raf');\nvar objectAssign = require('object-assign');\n\nvar helpers = {\n  propertyCache: {},\n  vendors: [null, ['-webkit-', 'webkit'], ['-moz-', 'Moz'], ['-o-', 'O'], ['-ms-', 'ms']],\n\n  clamp: function clamp(value, min, max) {\n    return min < max ? value < min ? min : value > max ? max : value : value < max ? max : value > min ? min : value;\n  },\n  data: function data(element, name) {\n    return helpers.deserialize(element.getAttribute('data-' + name));\n  },\n  deserialize: function deserialize(value) {\n    if (value === 'true') {\n      return true;\n    } else if (value === 'false') {\n      return false;\n    } else if (value === 'null') {\n      return null;\n    } else if (!isNaN(parseFloat(value)) && isFinite(value)) {\n      return parseFloat(value);\n    } else {\n      return value;\n    }\n  },\n  camelCase: function camelCase(value) {\n    return value.replace(/-+(.)?/g, function (match, character) {\n      return character ? character.toUpperCase() : '';\n    });\n  },\n  accelerate: function accelerate(element) {\n    helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)');\n    helpers.css(element, 'transform-style', 'preserve-3d');\n    helpers.css(element, 'backface-visibility', 'hidden');\n  },\n  transformSupport: function transformSupport(value) {\n    var element = document.createElement('div'),\n        propertySupport = false,\n        propertyValue = null,\n        featureSupport = false,\n        cssProperty = null,\n        jsProperty = null;\n    for (var i = 0, l = helpers.vendors.length; i < l; i++) {\n      if (helpers.vendors[i] !== null) {\n        cssProperty = helpers.vendors[i][0] + 'transform';\n        jsProperty = helpers.vendors[i][1] + 'Transform';\n      } else {\n        cssProperty = 'transform';\n        jsProperty = 'transform';\n      }\n      if (element.style[jsProperty] !== undefined) {\n        propertySupport = true;\n        break;\n      }\n    }\n    switch (value) {\n      case '2D':\n        featureSupport = propertySupport;\n        break;\n      case '3D':\n        if (propertySupport) {\n          var body = document.body || document.createElement('body'),\n              documentElement = document.documentElement,\n              documentOverflow = documentElement.style.overflow,\n              isCreatedBody = false;\n\n          if (!document.body) {\n            isCreatedBody = true;\n            documentElement.style.overflow = 'hidden';\n            documentElement.appendChild(body);\n            body.style.overflow = 'hidden';\n            body.style.background = '';\n          }\n\n          body.appendChild(element);\n          element.style[jsProperty] = 'translate3d(1px,1px,1px)';\n          propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty);\n          featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none';\n          documentElement.style.overflow = documentOverflow;\n          body.removeChild(element);\n\n          if (isCreatedBody) {\n            body.removeAttribute('style');\n            body.parentNode.removeChild(body);\n          }\n        }\n        break;\n    }\n    return featureSupport;\n  },\n  css: function css(element, property, value) {\n    var jsProperty = helpers.propertyCache[property];\n    if (!jsProperty) {\n      for (var i = 0, l = helpers.vendors.length; i < l; i++) {\n        if (helpers.vendors[i] !== null) {\n          jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property);\n        } else {\n          jsProperty = property;\n        }\n        if (element.style[jsProperty] !== undefined) {\n          helpers.propertyCache[property] = jsProperty;\n          break;\n        }\n      }\n    }\n    element.style[jsProperty] = value;\n  }\n};\n\nvar MAGIC_NUMBER = 30,\n    DEFAULTS = {\n  relativeInput: false,\n  clipRelativeInput: false,\n  inputElement: null,\n  hoverOnly: false,\n  calibrationThreshold: 100,\n  calibrationDelay: 500,\n  supportDelay: 500,\n  calibrateX: false,\n  calibrateY: true,\n  invertX: true,\n  invertY: true,\n  limitX: false,\n  limitY: false,\n  scalarX: 10.0,\n  scalarY: 10.0,\n  frictionX: 0.1,\n  frictionY: 0.1,\n  originX: 0.5,\n  originY: 0.5,\n  pointerEvents: false,\n  precision: 1,\n  onReady: null,\n  selector: null\n};\n\nvar Parallax = function () {\n  function Parallax(element, options) {\n    _classCallCheck(this, Parallax);\n\n    this.element = element;\n\n    var data = {\n      calibrateX: helpers.data(this.element, 'calibrate-x'),\n      calibrateY: helpers.data(this.element, 'calibrate-y'),\n      invertX: helpers.data(this.element, 'invert-x'),\n      invertY: helpers.data(this.element, 'invert-y'),\n      limitX: helpers.data(this.element, 'limit-x'),\n      limitY: helpers.data(this.element, 'limit-y'),\n      scalarX: helpers.data(this.element, 'scalar-x'),\n      scalarY: helpers.data(this.element, 'scalar-y'),\n      frictionX: helpers.data(this.element, 'friction-x'),\n      frictionY: helpers.data(this.element, 'friction-y'),\n      originX: helpers.data(this.element, 'origin-x'),\n      originY: helpers.data(this.element, 'origin-y'),\n      pointerEvents: helpers.data(this.element, 'pointer-events'),\n      precision: helpers.data(this.element, 'precision'),\n      relativeInput: helpers.data(this.element, 'relative-input'),\n      clipRelativeInput: helpers.data(this.element, 'clip-relative-input'),\n      hoverOnly: helpers.data(this.element, 'hover-only'),\n      inputElement: document.querySelector(helpers.data(this.element, 'input-element')),\n      selector: helpers.data(this.element, 'selector')\n    };\n\n    for (var key in data) {\n      if (data[key] === null) {\n        delete data[key];\n      }\n    }\n\n    objectAssign(this, DEFAULTS, data, options);\n\n    if (!this.inputElement) {\n      this.inputElement = this.element;\n    }\n\n    this.calibrationTimer = null;\n    this.calibrationFlag = true;\n    this.enabled = false;\n    this.depthsX = [];\n    this.depthsY = [];\n    this.raf = null;\n\n    this.bounds = null;\n    this.elementPositionX = 0;\n    this.elementPositionY = 0;\n    this.elementWidth = 0;\n    this.elementHeight = 0;\n\n    this.elementCenterX = 0;\n    this.elementCenterY = 0;\n\n    this.elementRangeX = 0;\n    this.elementRangeY = 0;\n\n    this.calibrationX = 0;\n    this.calibrationY = 0;\n\n    this.inputX = 0;\n    this.inputY = 0;\n\n    this.motionX = 0;\n    this.motionY = 0;\n\n    this.velocityX = 0;\n    this.velocityY = 0;\n\n    this.onMouseMove = this.onMouseMove.bind(this);\n    this.onDeviceOrientation = this.onDeviceOrientation.bind(this);\n    this.onDeviceMotion = this.onDeviceMotion.bind(this);\n    this.onOrientationTimer = this.onOrientationTimer.bind(this);\n    this.onMotionTimer = this.onMotionTimer.bind(this);\n    this.onCalibrationTimer = this.onCalibrationTimer.bind(this);\n    this.onAnimationFrame = this.onAnimationFrame.bind(this);\n    this.onWindowResize = this.onWindowResize.bind(this);\n\n    this.windowWidth = null;\n    this.windowHeight = null;\n    this.windowCenterX = null;\n    this.windowCenterY = null;\n    this.windowRadiusX = null;\n    this.windowRadiusY = null;\n    this.portrait = false;\n    this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i);\n    this.motionSupport = !!window.DeviceMotionEvent && !this.desktop;\n    this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop;\n    this.orientationStatus = 0;\n    this.motionStatus = 0;\n\n    this.initialise();\n  }\n\n  _createClass(Parallax, [{\n    key: 'initialise',\n    value: function initialise() {\n      if (this.transform2DSupport === undefined) {\n        this.transform2DSupport = helpers.transformSupport('2D');\n        this.transform3DSupport = helpers.transformSupport('3D');\n      }\n\n      // Configure Context Styles\n      if (this.transform3DSupport) {\n        helpers.accelerate(this.element);\n      }\n\n      var style = window.getComputedStyle(this.element);\n      if (style.getPropertyValue('position') === 'static') {\n        this.element.style.position = 'relative';\n      }\n\n      // Pointer events\n      if (!this.pointerEvents) {\n        this.element.style.pointerEvents = 'none';\n      }\n\n      // Setup\n      this.updateLayers();\n      this.updateDimensions();\n      this.enable();\n      this.queueCalibration(this.calibrationDelay);\n    }\n  }, {\n    key: 'doReadyCallback',\n    value: function doReadyCallback() {\n      if (this.onReady) {\n        this.onReady();\n      }\n    }\n  }, {\n    key: 'updateLayers',\n    value: function updateLayers() {\n      if (this.selector) {\n        this.layers = this.element.querySelectorAll(this.selector);\n      } else {\n        this.layers = this.element.children;\n      }\n\n      if (!this.layers.length) {\n        console.warn('ParallaxJS: Your scene does not have any layers.');\n      }\n\n      this.depthsX = [];\n      this.depthsY = [];\n\n      for (var index = 0; index < this.layers.length; index++) {\n        var layer = this.layers[index];\n\n        if (this.transform3DSupport) {\n          helpers.accelerate(layer);\n        }\n\n        layer.style.position = index ? 'absolute' : 'relative';\n        layer.style.display = 'block';\n        layer.style.left = 0;\n        layer.style.top = 0;\n\n        var depth = helpers.data(layer, 'depth') || 0;\n        this.depthsX.push(helpers.data(layer, 'depth-x') || depth);\n        this.depthsY.push(helpers.data(layer, 'depth-y') || depth);\n      }\n    }\n  }, {\n    key: 'updateDimensions',\n    value: function updateDimensions() {\n      this.windowWidth = window.innerWidth;\n      this.windowHeight = window.innerHeight;\n      this.windowCenterX = this.windowWidth * this.originX;\n      this.windowCenterY = this.windowHeight * this.originY;\n      this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX);\n      this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY);\n    }\n  }, {\n    key: 'updateBounds',\n    value: function updateBounds() {\n      this.bounds = this.inputElement.getBoundingClientRect();\n      this.elementPositionX = this.bounds.left;\n      this.elementPositionY = this.bounds.top;\n      this.elementWidth = this.bounds.width;\n      this.elementHeight = this.bounds.height;\n      this.elementCenterX = this.elementWidth * this.originX;\n      this.elementCenterY = this.elementHeight * this.originY;\n      this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX);\n      this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY);\n    }\n  }, {\n    key: 'queueCalibration',\n    value: function queueCalibration(delay) {\n      clearTimeout(this.calibrationTimer);\n      this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay);\n    }\n  }, {\n    key: 'enable',\n    value: function enable() {\n      if (this.enabled) {\n        return;\n      }\n      this.enabled = true;\n\n      if (this.orientationSupport) {\n        this.portrait = false;\n        window.addEventListener('deviceorientation', this.onDeviceOrientation);\n        this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay);\n      } else if (this.motionSupport) {\n        this.portrait = false;\n        window.addEventListener('devicemotion', this.onDeviceMotion);\n        this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay);\n      } else {\n        this.calibrationX = 0;\n        this.calibrationY = 0;\n        this.portrait = false;\n        window.addEventListener('mousemove', this.onMouseMove);\n        this.doReadyCallback();\n      }\n\n      window.addEventListener('resize', this.onWindowResize);\n      this.raf = rqAnFr(this.onAnimationFrame);\n    }\n  }, {\n    key: 'disable',\n    value: function disable() {\n      if (!this.enabled) {\n        return;\n      }\n      this.enabled = false;\n\n      if (this.orientationSupport) {\n        window.removeEventListener('deviceorientation', this.onDeviceOrientation);\n      } else if (this.motionSupport) {\n        window.removeEventListener('devicemotion', this.onDeviceMotion);\n      } else {\n        window.removeEventListener('mousemove', this.onMouseMove);\n      }\n\n      window.removeEventListener('resize', this.onWindowResize);\n      rqAnFr.cancel(this.raf);\n    }\n  }, {\n    key: 'calibrate',\n    value: function calibrate(x, y) {\n      this.calibrateX = x === undefined ? this.calibrateX : x;\n      this.calibrateY = y === undefined ? this.calibrateY : y;\n    }\n  }, {\n    key: 'invert',\n    value: function invert(x, y) {\n      this.invertX = x === undefined ? this.invertX : x;\n      this.invertY = y === undefined ? this.invertY : y;\n    }\n  }, {\n    key: 'friction',\n    value: function friction(x, y) {\n      this.frictionX = x === undefined ? this.frictionX : x;\n      this.frictionY = y === undefined ? this.frictionY : y;\n    }\n  }, {\n    key: 'scalar',\n    value: function scalar(x, y) {\n      this.scalarX = x === undefined ? this.scalarX : x;\n      this.scalarY = y === undefined ? this.scalarY : y;\n    }\n  }, {\n    key: 'limit',\n    value: function limit(x, y) {\n      this.limitX = x === undefined ? this.limitX : x;\n      this.limitY = y === undefined ? this.limitY : y;\n    }\n  }, {\n    key: 'origin',\n    value: function origin(x, y) {\n      this.originX = x === undefined ? this.originX : x;\n      this.originY = y === undefined ? this.originY : y;\n    }\n  }, {\n    key: 'setInputElement',\n    value: function setInputElement(element) {\n      this.inputElement = element;\n      this.updateDimensions();\n    }\n  }, {\n    key: 'setPosition',\n    value: function setPosition(element, x, y) {\n      x = x.toFixed(this.precision) + 'px';\n      y = y.toFixed(this.precision) + 'px';\n      if (this.transform3DSupport) {\n        helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)');\n      } else if (this.transform2DSupport) {\n        helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')');\n      } else {\n        element.style.left = x;\n        element.style.top = y;\n      }\n    }\n  }, {\n    key: 'onOrientationTimer',\n    value: function onOrientationTimer() {\n      if (this.orientationSupport && this.orientationStatus === 0) {\n        this.disable();\n        this.orientationSupport = false;\n        this.enable();\n      } else {\n        this.doReadyCallback();\n      }\n    }\n  }, {\n    key: 'onMotionTimer',\n    value: function onMotionTimer() {\n      if (this.motionSupport && this.motionStatus === 0) {\n        this.disable();\n        this.motionSupport = false;\n        this.enable();\n      } else {\n        this.doReadyCallback();\n      }\n    }\n  }, {\n    key: 'onCalibrationTimer',\n    value: function onCalibrationTimer() {\n      this.calibrationFlag = true;\n    }\n  }, {\n    key: 'onWindowResize',\n    value: function onWindowResize() {\n      this.updateDimensions();\n    }\n  }, {\n    key: 'onAnimationFrame',\n    value: function onAnimationFrame() {\n      this.updateBounds();\n      var calibratedInputX = this.inputX - this.calibrationX,\n          calibratedInputY = this.inputY - this.calibrationY;\n      if (Math.abs(calibratedInputX) > this.calibrationThreshold || Math.abs(calibratedInputY) > this.calibrationThreshold) {\n        this.queueCalibration(0);\n      }\n      if (this.portrait) {\n        this.motionX = this.calibrateX ? calibratedInputY : this.inputY;\n        this.motionY = this.calibrateY ? calibratedInputX : this.inputX;\n      } else {\n        this.motionX = this.calibrateX ? calibratedInputX : this.inputX;\n        this.motionY = this.calibrateY ? calibratedInputY : this.inputY;\n      }\n      this.motionX *= this.elementWidth * (this.scalarX / 100);\n      this.motionY *= this.elementHeight * (this.scalarY / 100);\n      if (!isNaN(parseFloat(this.limitX))) {\n        this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX);\n      }\n      if (!isNaN(parseFloat(this.limitY))) {\n        this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY);\n      }\n      this.velocityX += (this.motionX - this.velocityX) * this.frictionX;\n      this.velocityY += (this.motionY - this.velocityY) * this.frictionY;\n      for (var index = 0; index < this.layers.length; index++) {\n        var layer = this.layers[index],\n            depthX = this.depthsX[index],\n            depthY = this.depthsY[index],\n            xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)),\n            yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1));\n        this.setPosition(layer, xOffset, yOffset);\n      }\n      this.raf = rqAnFr(this.onAnimationFrame);\n    }\n  }, {\n    key: 'rotate',\n    value: function rotate(beta, gamma) {\n      // Extract Rotation\n      var x = (beta || 0) / MAGIC_NUMBER,\n          //  -90 :: 90\n      y = (gamma || 0) / MAGIC_NUMBER; // -180 :: 180\n\n      // Detect Orientation Change\n      var portrait = this.windowHeight > this.windowWidth;\n      if (this.portrait !== portrait) {\n        this.portrait = portrait;\n        this.calibrationFlag = true;\n      }\n\n      if (this.calibrationFlag) {\n        this.calibrationFlag = false;\n        this.calibrationX = x;\n        this.calibrationY = y;\n      }\n\n      this.inputX = x;\n      this.inputY = y;\n    }\n  }, {\n    key: 'onDeviceOrientation',\n    value: function onDeviceOrientation(event) {\n      var beta = event.beta;\n      var gamma = event.gamma;\n      if (beta !== null && gamma !== null) {\n        this.orientationStatus = 1;\n        this.rotate(beta, gamma);\n      }\n    }\n  }, {\n    key: 'onDeviceMotion',\n    value: function onDeviceMotion(event) {\n      var beta = event.rotationRate.beta;\n      var gamma = event.rotationRate.gamma;\n      if (beta !== null && gamma !== null) {\n        this.motionStatus = 1;\n        this.rotate(beta, gamma);\n      }\n    }\n  }, {\n    key: 'onMouseMove',\n    value: function onMouseMove(event) {\n      var clientX = event.clientX,\n          clientY = event.clientY;\n\n      // reset input to center if hoverOnly is set and we're not hovering the element\n      if (this.hoverOnly && (clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth || clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight)) {\n        this.inputX = 0;\n        this.inputY = 0;\n        return;\n      }\n\n      if (this.relativeInput) {\n        // Clip mouse coordinates inside element bounds.\n        if (this.clipRelativeInput) {\n          clientX = Math.max(clientX, this.elementPositionX);\n          clientX = Math.min(clientX, this.elementPositionX + this.elementWidth);\n          clientY = Math.max(clientY, this.elementPositionY);\n          clientY = Math.min(clientY, this.elementPositionY + this.elementHeight);\n        }\n        // Calculate input relative to the element.\n        if (this.elementRangeX && this.elementRangeY) {\n          this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX;\n          this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY;\n        }\n      } else {\n        // Calculate input relative to the window.\n        if (this.windowRadiusX && this.windowRadiusY) {\n          this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX;\n          this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY;\n        }\n      }\n    }\n  }, {\n    key: 'destroy',\n    value: function destroy() {\n      this.disable();\n\n      clearTimeout(this.calibrationTimer);\n      clearTimeout(this.detectionTimer);\n\n      this.element.removeAttribute('style');\n      for (var index = 0; index < this.layers.length; index++) {\n        this.layers[index].removeAttribute('style');\n      }\n\n      delete this.element;\n      delete this.layers;\n    }\n  }, {\n    key: 'version',\n    value: function version() {\n      return '3.1.0';\n    }\n  }]);\n\n  return Parallax;\n}();\n\nmodule.exports = Parallax;\n\n},{\"object-assign\":1,\"raf\":4}]},{},[5])(5)\n});\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["node_modules/browser-pack/_prelude.js","node_modules/object-assign/index.js","node_modules/performance-now/lib/performance-now.js","node_modules/process/browser.js","node_modules/raf/index.js","src/parallax.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AC1FA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;ACpCA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;ACxLA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;ACxEA;;;;;;;;AAQA,IAAM,SAAS,QAAQ,KAAR,CAAf;AACA,IAAM,eAAe,QAAQ,eAAR,CAArB;;AAEA,IAAM,UAAU;AACd,iBAAe,EADD;AAEd,WAAS,CAAC,IAAD,EAAO,CAAC,UAAD,EAAY,QAAZ,CAAP,EAA8B,CAAC,OAAD,EAAS,KAAT,CAA9B,EAA+C,CAAC,KAAD,EAAO,GAAP,CAA/C,EAA4D,CAAC,MAAD,EAAQ,IAAR,CAA5D,CAFK;;AAId,OAJc,iBAIR,KAJQ,EAID,GAJC,EAII,GAJJ,EAIS;AACrB,WAAO,MAAM,GAAN,GACF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,KADtC,GAEF,QAAQ,GAAR,GAAc,GAAd,GAAoB,QAAQ,GAAR,GAAc,GAAd,GAAoB,KAF7C;AAGD,GARa;AAUd,MAVc,gBAUT,OAVS,EAUA,IAVA,EAUM;AAClB,WAAO,QAAQ,WAAR,CAAoB,QAAQ,YAAR,CAAqB,UAAQ,IAA7B,CAApB,CAAP;AACD,GAZa;AAcd,aAdc,uBAcF,KAdE,EAcK;AACjB,QAAI,UAAU,MAAd,EAAsB;AACpB,aAAO,IAAP;AACD,KAFD,MAEO,IAAI,UAAU,OAAd,EAAuB;AAC5B,aAAO,KAAP;AACD,KAFM,MAEA,IAAI,UAAU,MAAd,EAAsB;AAC3B,aAAO,IAAP;AACD,KAFM,MAEA,IAAI,CAAC,MAAM,WAAW,KAAX,CAAN,CAAD,IAA6B,SAAS,KAAT,CAAjC,EAAkD;AACvD,aAAO,WAAW,KAAX,CAAP;AACD,KAFM,MAEA;AACL,aAAO,KAAP;AACD;AACF,GA1Ba;AA4Bd,WA5Bc,qBA4BJ,KA5BI,EA4BG;AACf,WAAO,MAAM,OAAN,CAAc,SAAd,EAAyB,UAAC,KAAD,EAAQ,SAAR,EAAsB;AACpD,aAAO,YAAY,UAAU,WAAV,EAAZ,GAAsC,EAA7C;AACD,KAFM,CAAP;AAGD,GAhCa;AAkCd,YAlCc,sBAkCH,OAlCG,EAkCM;AAClB,YAAQ,GAAR,CAAY,OAAZ,EAAqB,WAArB,EAAkC,sCAAlC;AACA,YAAQ,GAAR,CAAY,OAAZ,EAAqB,iBAArB,EAAwC,aAAxC;AACA,YAAQ,GAAR,CAAY,OAAZ,EAAqB,qBAArB,EAA4C,QAA5C;AACD,GAtCa;AAwCd,kBAxCc,4BAwCG,KAxCH,EAwCU;AACtB,QAAI,UAAU,SAAS,aAAT,CAAuB,KAAvB,CAAd;AAAA,QACI,kBAAkB,KADtB;AAAA,QAEI,gBAAgB,IAFpB;AAAA,QAGI,iBAAiB,KAHrB;AAAA,QAII,cAAc,IAJlB;AAAA,QAKI,aAAa,IALjB;AAMA,SAAK,IAAI,IAAI,CAAR,EAAW,IAAI,QAAQ,OAAR,CAAgB,MAApC,EAA4C,IAAI,CAAhD,EAAmD,GAAnD,EAAwD;AACtD,UAAI,QAAQ,OAAR,CAAgB,CAAhB,MAAuB,IAA3B,EAAiC;AAC/B,sBAAc,QAAQ,OAAR,CAAgB,CAAhB,EAAmB,CAAnB,IAAwB,WAAtC;AACA,qBAAa,QAAQ,OAAR,CAAgB,CAAhB,EAAmB,CAAnB,IAAwB,WAArC;AACD,OAHD,MAGO;AACL,sBAAc,WAAd;AACA,qBAAa,WAAb;AACD;AACD,UAAI,QAAQ,KAAR,CAAc,UAAd,MAA8B,SAAlC,EAA6C;AAC3C,0BAAkB,IAAlB;AACA;AACD;AACF;AACD,YAAO,KAAP;AACE,WAAK,IAAL;AACE,yBAAiB,eAAjB;AACA;AACF,WAAK,IAAL;AACE,YAAI,eAAJ,EAAqB;AACnB,cAAI,OAAO,SAAS,IAAT,IAAiB,SAAS,aAAT,CAAuB,MAAvB,CAA5B;AAAA,cACI,kBAAkB,SAAS,eAD/B;AAAA,cAEI,mBAAmB,gBAAgB,KAAhB,CAAsB,QAF7C;AAAA,cAGI,gBAAgB,KAHpB;;AAKA,cAAI,CAAC,SAAS,IAAd,EAAoB;AAClB,4BAAgB,IAAhB;AACA,4BAAgB,KAAhB,CAAsB,QAAtB,GAAiC,QAAjC;AACA,4BAAgB,WAAhB,CAA4B,IAA5B;AACA,iBAAK,KAAL,CAAW,QAAX,GAAsB,QAAtB;AACA,iBAAK,KAAL,CAAW,UAAX,GAAwB,EAAxB;AACD;;AAED,eAAK,WAAL,CAAiB,OAAjB;AACA,kBAAQ,KAAR,CAAc,UAAd,IAA4B,0BAA5B;AACA,0BAAgB,OAAO,gBAAP,CAAwB,OAAxB,EAAiC,gBAAjC,CAAkD,WAAlD,CAAhB;AACA,2BAAiB,kBAAkB,SAAlB,IAA+B,cAAc,MAAd,GAAuB,CAAtD,IAA2D,kBAAkB,MAA9F;AACA,0BAAgB,KAAhB,CAAsB,QAAtB,GAAiC,gBAAjC;AACA,eAAK,WAAL,CAAiB,OAAjB;;AAEA,cAAK,aAAL,EAAqB;AACnB,iBAAK,eAAL,CAAqB,OAArB;AACA,iBAAK,UAAL,CAAgB,WAAhB,CAA4B,IAA5B;AACD;AACF;AACD;AA/BJ;AAiCA,WAAO,cAAP;AACD,GA9Fa;AAgGd,KAhGc,eAgGV,OAhGU,EAgGD,QAhGC,EAgGS,KAhGT,EAgGgB;AAC5B,QAAI,aAAa,QAAQ,aAAR,CAAsB,QAAtB,CAAjB;AACA,QAAI,CAAC,UAAL,EAAiB;AACf,WAAK,IAAI,IAAI,CAAR,EAAW,IAAI,QAAQ,OAAR,CAAgB,MAApC,EAA4C,IAAI,CAAhD,EAAmD,GAAnD,EAAwD;AACtD,YAAI,QAAQ,OAAR,CAAgB,CAAhB,MAAuB,IAA3B,EAAiC;AAC/B,uBAAa,QAAQ,SAAR,CAAkB,QAAQ,OAAR,CAAgB,CAAhB,EAAmB,CAAnB,IAAwB,GAAxB,GAA8B,QAAhD,CAAb;AACD,SAFD,MAEO;AACL,uBAAa,QAAb;AACD;AACD,YAAI,QAAQ,KAAR,CAAc,UAAd,MAA8B,SAAlC,EAA6C;AAC3C,kBAAQ,aAAR,CAAsB,QAAtB,IAAkC,UAAlC;AACA;AACD;AACF;AACF;AACD,YAAQ,KAAR,CAAc,UAAd,IAA4B,KAA5B;AACD;AAhHa,CAAhB;;AAoHA,IAAM,eAAe,EAArB;AAAA,IACM,WAAW;AACT,iBAAe,KADN;AAET,qBAAmB,KAFV;AAGT,gBAAc,IAHL;AAIT,aAAW,KAJF;AAKT,wBAAsB,GALb;AAMT,oBAAkB,GANT;AAOT,gBAAc,GAPL;AAQT,cAAY,KARH;AAST,cAAY,IATH;AAUT,WAAS,IAVA;AAWT,WAAS,IAXA;AAYT,UAAQ,KAZC;AAaT,UAAQ,KAbC;AAcT,WAAS,IAdA;AAeT,WAAS,IAfA;AAgBT,aAAW,GAhBF;AAiBT,aAAW,GAjBF;AAkBT,WAAS,GAlBA;AAmBT,WAAS,GAnBA;AAoBT,iBAAe,KApBN;AAqBT,aAAW,CArBF;AAsBT,WAAS,IAtBA;AAuBT,YAAU;AAvBD,CADjB;;IA2BM,Q;AACJ,oBAAY,OAAZ,EAAqB,OAArB,EAA8B;AAAA;;AAE5B,SAAK,OAAL,GAAe,OAAf;;AAEA,QAAM,OAAO;AACX,kBAAY,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,aAA3B,CADD;AAEX,kBAAY,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,aAA3B,CAFD;AAGX,eAAS,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,UAA3B,CAHE;AAIX,eAAS,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,UAA3B,CAJE;AAKX,cAAQ,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,SAA3B,CALG;AAMX,cAAQ,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,SAA3B,CANG;AAOX,eAAS,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,UAA3B,CAPE;AAQX,eAAS,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,UAA3B,CARE;AASX,iBAAW,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,YAA3B,CATA;AAUX,iBAAW,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,YAA3B,CAVA;AAWX,eAAS,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,UAA3B,CAXE;AAYX,eAAS,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,UAA3B,CAZE;AAaX,qBAAe,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,gBAA3B,CAbJ;AAcX,iBAAW,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,WAA3B,CAdA;AAeX,qBAAe,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,gBAA3B,CAfJ;AAgBX,yBAAmB,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,qBAA3B,CAhBR;AAiBX,iBAAW,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,YAA3B,CAjBA;AAkBX,oBAAc,SAAS,aAAT,CAAuB,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,eAA3B,CAAvB,CAlBH;AAmBX,gBAAU,QAAQ,IAAR,CAAa,KAAK,OAAlB,EAA2B,UAA3B;AAnBC,KAAb;;AAsBA,SAAK,IAAI,GAAT,IAAgB,IAAhB,EAAsB;AACpB,UAAI,KAAK,GAAL,MAAc,IAAlB,EAAwB;AACtB,eAAO,KAAK,GAAL,CAAP;AACD;AACF;;AAED,iBAAa,IAAb,EAAmB,QAAnB,EAA6B,IAA7B,EAAmC,OAAnC;;AAEA,QAAG,CAAC,KAAK,YAAT,EAAuB;AACrB,WAAK,YAAL,GAAoB,KAAK,OAAzB;AACD;;AAED,SAAK,gBAAL,GAAwB,IAAxB;AACA,SAAK,eAAL,GAAuB,IAAvB;AACA,SAAK,OAAL,GAAe,KAAf;AACA,SAAK,OAAL,GAAe,EAAf;AACA,SAAK,OAAL,GAAe,EAAf;AACA,SAAK,GAAL,GAAW,IAAX;;AAEA,SAAK,MAAL,GAAc,IAAd;AACA,SAAK,gBAAL,GAAwB,CAAxB;AACA,SAAK,gBAAL,GAAwB,CAAxB;AACA,SAAK,YAAL,GAAoB,CAApB;AACA,SAAK,aAAL,GAAqB,CAArB;;AAEA,SAAK,cAAL,GAAsB,CAAtB;AACA,SAAK,cAAL,GAAsB,CAAtB;;AAEA,SAAK,aAAL,GAAqB,CAArB;AACA,SAAK,aAAL,GAAqB,CAArB;;AAEA,SAAK,YAAL,GAAoB,CAApB;AACA,SAAK,YAAL,GAAoB,CAApB;;AAEA,SAAK,MAAL,GAAc,CAAd;AACA,SAAK,MAAL,GAAc,CAAd;;AAEA,SAAK,OAAL,GAAe,CAAf;AACA,SAAK,OAAL,GAAe,CAAf;;AAEA,SAAK,SAAL,GAAiB,CAAjB;AACA,SAAK,SAAL,GAAiB,CAAjB;;AAEA,SAAK,WAAL,GAAmB,KAAK,WAAL,CAAiB,IAAjB,CAAsB,IAAtB,CAAnB;AACA,SAAK,mBAAL,GAA2B,KAAK,mBAAL,CAAyB,IAAzB,CAA8B,IAA9B,CAA3B;AACA,SAAK,cAAL,GAAsB,KAAK,cAAL,CAAoB,IAApB,CAAyB,IAAzB,CAAtB;AACA,SAAK,kBAAL,GAA0B,KAAK,kBAAL,CAAwB,IAAxB,CAA6B,IAA7B,CAA1B;AACA,SAAK,aAAL,GAAqB,KAAK,aAAL,CAAmB,IAAnB,CAAwB,IAAxB,CAArB;AACA,SAAK,kBAAL,GAA0B,KAAK,kBAAL,CAAwB,IAAxB,CAA6B,IAA7B,CAA1B;AACA,SAAK,gBAAL,GAAwB,KAAK,gBAAL,CAAsB,IAAtB,CAA2B,IAA3B,CAAxB;AACA,SAAK,cAAL,GAAsB,KAAK,cAAL,CAAoB,IAApB,CAAyB,IAAzB,CAAtB;;AAEA,SAAK,WAAL,GAAmB,IAAnB;AACA,SAAK,YAAL,GAAoB,IAApB;AACA,SAAK,aAAL,GAAqB,IAArB;AACA,SAAK,aAAL,GAAqB,IAArB;AACA,SAAK,aAAL,GAAqB,IAArB;AACA,SAAK,aAAL,GAAqB,IAArB;AACA,SAAK,QAAL,GAAgB,KAAhB;AACA,SAAK,OAAL,GAAe,CAAC,UAAU,SAAV,CAAoB,KAApB,CAA0B,4EAA1B,CAAhB;AACA,SAAK,aAAL,GAAqB,CAAC,CAAC,OAAO,iBAAT,IAA8B,CAAC,KAAK,OAAzD;AACA,SAAK,kBAAL,GAA0B,CAAC,CAAC,OAAO,sBAAT,IAAmC,CAAC,KAAK,OAAnE;AACA,SAAK,iBAAL,GAAyB,CAAzB;AACA,SAAK,YAAL,GAAoB,CAApB;;AAEA,SAAK,UAAL;AACD;;;;iCAEY;AACX,UAAI,KAAK,kBAAL,KAA4B,SAAhC,EAA2C;AACzC,aAAK,kBAAL,GAA0B,QAAQ,gBAAR,CAAyB,IAAzB,CAA1B;AACA,aAAK,kBAAL,GAA0B,QAAQ,gBAAR,CAAyB,IAAzB,CAA1B;AACD;;AAED;AACA,UAAI,KAAK,kBAAT,EAA6B;AAC3B,gBAAQ,UAAR,CAAmB,KAAK,OAAxB;AACD;;AAED,UAAI,QAAQ,OAAO,gBAAP,CAAwB,KAAK,OAA7B,CAAZ;AACA,UAAI,MAAM,gBAAN,CAAuB,UAAvB,MAAuC,QAA3C,EAAqD;AACnD,aAAK,OAAL,CAAa,KAAb,CAAmB,QAAnB,GAA8B,UAA9B;AACD;;AAED;AACA,UAAG,CAAC,KAAK,aAAT,EAAwB;AACtB,aAAK,OAAL,CAAa,KAAb,CAAmB,aAAnB,GAAmC,MAAnC;AACD;;AAED;AACA,WAAK,YAAL;AACA,WAAK,gBAAL;AACA,WAAK,MAAL;AACA,WAAK,gBAAL,CAAsB,KAAK,gBAA3B;AACD;;;sCAEiB;AAChB,UAAG,KAAK,OAAR,EAAiB;AACf,aAAK,OAAL;AACD;AACF;;;mCAEc;AACb,UAAG,KAAK,QAAR,EAAkB;AAChB,aAAK,MAAL,GAAc,KAAK,OAAL,CAAa,gBAAb,CAA8B,KAAK,QAAnC,CAAd;AACD,OAFD,MAEO;AACL,aAAK,MAAL,GAAc,KAAK,OAAL,CAAa,QAA3B;AACD;;AAED,UAAG,CAAC,KAAK,MAAL,CAAY,MAAhB,EAAwB;AACtB,gBAAQ,IAAR,CAAa,kDAAb;AACD;;AAED,WAAK,OAAL,GAAe,EAAf;AACA,WAAK,OAAL,GAAe,EAAf;;AAEA,WAAK,IAAI,QAAQ,CAAjB,EAAoB,QAAQ,KAAK,MAAL,CAAY,MAAxC,EAAgD,OAAhD,EAAyD;AACvD,YAAI,QAAQ,KAAK,MAAL,CAAY,KAAZ,CAAZ;;AAEA,YAAI,KAAK,kBAAT,EAA6B;AAC3B,kBAAQ,UAAR,CAAmB,KAAnB;AACD;;AAED,cAAM,KAAN,CAAY,QAAZ,GAAuB,QAAQ,UAAR,GAAqB,UAA5C;AACA,cAAM,KAAN,CAAY,OAAZ,GAAsB,OAAtB;AACA,cAAM,KAAN,CAAY,IAAZ,GAAmB,CAAnB;AACA,cAAM,KAAN,CAAY,GAAZ,GAAkB,CAAlB;;AAEA,YAAI,QAAQ,QAAQ,IAAR,CAAa,KAAb,EAAoB,OAApB,KAAgC,CAA5C;AACA,aAAK,OAAL,CAAa,IAAb,CAAkB,QAAQ,IAAR,CAAa,KAAb,EAAoB,SAApB,KAAkC,KAApD;AACA,aAAK,OAAL,CAAa,IAAb,CAAkB,QAAQ,IAAR,CAAa,KAAb,EAAoB,SAApB,KAAkC,KAApD;AACD;AACF;;;uCAEkB;AACjB,WAAK,WAAL,GAAmB,OAAO,UAA1B;AACA,WAAK,YAAL,GAAoB,OAAO,WAA3B;AACA,WAAK,aAAL,GAAqB,KAAK,WAAL,GAAmB,KAAK,OAA7C;AACA,WAAK,aAAL,GAAqB,KAAK,YAAL,GAAoB,KAAK,OAA9C;AACA,WAAK,aAAL,GAAqB,KAAK,GAAL,CAAS,KAAK,aAAd,EAA6B,KAAK,WAAL,GAAmB,KAAK,aAArD,CAArB;AACA,WAAK,aAAL,GAAqB,KAAK,GAAL,CAAS,KAAK,aAAd,EAA6B,KAAK,YAAL,GAAoB,KAAK,aAAtD,CAArB;AACD;;;mCAEc;AACb,WAAK,MAAL,GAAc,KAAK,YAAL,CAAkB,qBAAlB,EAAd;AACA,WAAK,gBAAL,GAAwB,KAAK,MAAL,CAAY,IAApC;AACA,WAAK,gBAAL,GAAwB,KAAK,MAAL,CAAY,GAApC;AACA,WAAK,YAAL,GAAoB,KAAK,MAAL,CAAY,KAAhC;AACA,WAAK,aAAL,GAAqB,KAAK,MAAL,CAAY,MAAjC;AACA,WAAK,cAAL,GAAsB,KAAK,YAAL,GAAoB,KAAK,OAA/C;AACA,WAAK,cAAL,GAAsB,KAAK,aAAL,GAAqB,KAAK,OAAhD;AACA,WAAK,aAAL,GAAqB,KAAK,GAAL,CAAS,KAAK,cAAd,EAA8B,KAAK,YAAL,GAAoB,KAAK,cAAvD,CAArB;AACA,WAAK,aAAL,GAAqB,KAAK,GAAL,CAAS,KAAK,cAAd,EAA8B,KAAK,aAAL,GAAqB,KAAK,cAAxD,CAArB;AACD;;;qCAEgB,K,EAAO;AACtB,mBAAa,KAAK,gBAAlB;AACA,WAAK,gBAAL,GAAwB,WAAW,KAAK,kBAAhB,EAAoC,KAApC,CAAxB;AACD;;;6BAEQ;AACP,UAAI,KAAK,OAAT,EAAkB;AAChB;AACD;AACD,WAAK,OAAL,GAAe,IAAf;;AAEA,UAAI,KAAK,kBAAT,EAA6B;AAC3B,aAAK,QAAL,GAAgB,KAAhB;AACA,eAAO,gBAAP,CAAwB,mBAAxB,EAA6C,KAAK,mBAAlD;AACA,aAAK,cAAL,GAAsB,WAAW,KAAK,kBAAhB,EAAoC,KAAK,YAAzC,CAAtB;AACD,OAJD,MAIO,IAAI,KAAK,aAAT,EAAwB;AAC7B,aAAK,QAAL,GAAgB,KAAhB;AACA,eAAO,gBAAP,CAAwB,cAAxB,EAAwC,KAAK,cAA7C;AACA,aAAK,cAAL,GAAsB,WAAW,KAAK,aAAhB,EAA+B,KAAK,YAApC,CAAtB;AACD,OAJM,MAIA;AACL,aAAK,YAAL,GAAoB,CAApB;AACA,aAAK,YAAL,GAAoB,CAApB;AACA,aAAK,QAAL,GAAgB,KAAhB;AACA,eAAO,gBAAP,CAAwB,WAAxB,EAAqC,KAAK,WAA1C;AACA,aAAK,eAAL;AACD;;AAED,aAAO,gBAAP,CAAwB,QAAxB,EAAkC,KAAK,cAAvC;AACA,WAAK,GAAL,GAAW,OAAO,KAAK,gBAAZ,CAAX;AACD;;;8BAES;AACR,UAAI,CAAC,KAAK,OAAV,EAAmB;AACjB;AACD;AACD,WAAK,OAAL,GAAe,KAAf;;AAEA,UAAI,KAAK,kBAAT,EAA6B;AAC3B,eAAO,mBAAP,CAA2B,mBAA3B,EAAgD,KAAK,mBAArD;AACD,OAFD,MAEO,IAAI,KAAK,aAAT,EAAwB;AAC7B,eAAO,mBAAP,CAA2B,cAA3B,EAA2C,KAAK,cAAhD;AACD,OAFM,MAEA;AACL,eAAO,mBAAP,CAA2B,WAA3B,EAAwC,KAAK,WAA7C;AACD;;AAED,aAAO,mBAAP,CAA2B,QAA3B,EAAqC,KAAK,cAA1C;AACA,aAAO,MAAP,CAAc,KAAK,GAAnB;AACD;;;8BAES,C,EAAG,C,EAAG;AACd,WAAK,UAAL,GAAkB,MAAM,SAAN,GAAkB,KAAK,UAAvB,GAAoC,CAAtD;AACA,WAAK,UAAL,GAAkB,MAAM,SAAN,GAAkB,KAAK,UAAvB,GAAoC,CAAtD;AACD;;;2BAEM,C,EAAG,C,EAAG;AACX,WAAK,OAAL,GAAe,MAAM,SAAN,GAAkB,KAAK,OAAvB,GAAiC,CAAhD;AACA,WAAK,OAAL,GAAe,MAAM,SAAN,GAAkB,KAAK,OAAvB,GAAiC,CAAhD;AACD;;;6BAEQ,C,EAAG,C,EAAG;AACb,WAAK,SAAL,GAAiB,MAAM,SAAN,GAAkB,KAAK,SAAvB,GAAmC,CAApD;AACA,WAAK,SAAL,GAAiB,MAAM,SAAN,GAAkB,KAAK,SAAvB,GAAmC,CAApD;AACD;;;2BAEM,C,EAAG,C,EAAG;AACX,WAAK,OAAL,GAAe,MAAM,SAAN,GAAkB,KAAK,OAAvB,GAAiC,CAAhD;AACA,WAAK,OAAL,GAAe,MAAM,SAAN,GAAkB,KAAK,OAAvB,GAAiC,CAAhD;AACD;;;0BAEK,C,EAAG,C,EAAG;AACV,WAAK,MAAL,GAAc,MAAM,SAAN,GAAkB,KAAK,MAAvB,GAAgC,CAA9C;AACA,WAAK,MAAL,GAAc,MAAM,SAAN,GAAkB,KAAK,MAAvB,GAAgC,CAA9C;AACD;;;2BAEM,C,EAAG,C,EAAG;AACX,WAAK,OAAL,GAAe,MAAM,SAAN,GAAkB,KAAK,OAAvB,GAAiC,CAAhD;AACA,WAAK,OAAL,GAAe,MAAM,SAAN,GAAkB,KAAK,OAAvB,GAAiC,CAAhD;AACD;;;oCAEe,O,EAAS;AACvB,WAAK,YAAL,GAAoB,OAApB;AACA,WAAK,gBAAL;AACD;;;gCAEW,O,EAAS,C,EAAG,C,EAAG;AACzB,UAAI,EAAE,OAAF,CAAU,KAAK,SAAf,IAA4B,IAAhC;AACA,UAAI,EAAE,OAAF,CAAU,KAAK,SAAf,IAA4B,IAAhC;AACA,UAAI,KAAK,kBAAT,EAA6B;AAC3B,gBAAQ,GAAR,CAAY,OAAZ,EAAqB,WAArB,EAAkC,iBAAiB,CAAjB,GAAqB,GAArB,GAA2B,CAA3B,GAA+B,KAAjE;AACD,OAFD,MAEO,IAAI,KAAK,kBAAT,EAA6B;AAClC,gBAAQ,GAAR,CAAY,OAAZ,EAAqB,WAArB,EAAkC,eAAe,CAAf,GAAmB,GAAnB,GAAyB,CAAzB,GAA6B,GAA/D;AACD,OAFM,MAEA;AACL,gBAAQ,KAAR,CAAc,IAAd,GAAqB,CAArB;AACA,gBAAQ,KAAR,CAAc,GAAd,GAAoB,CAApB;AACD;AACF;;;yCAEoB;AACnB,UAAI,KAAK,kBAAL,IAA2B,KAAK,iBAAL,KAA2B,CAA1D,EAA6D;AAC3D,aAAK,OAAL;AACA,aAAK,kBAAL,GAA0B,KAA1B;AACA,aAAK,MAAL;AACD,OAJD,MAIO;AACL,aAAK,eAAL;AACD;AACF;;;oCAEe;AACd,UAAI,KAAK,aAAL,IAAsB,KAAK,YAAL,KAAsB,CAAhD,EAAmD;AACjD,aAAK,OAAL;AACA,aAAK,aAAL,GAAqB,KAArB;AACA,aAAK,MAAL;AACD,OAJD,MAIO;AACL,aAAK,eAAL;AACD;AACF;;;yCAEoB;AACnB,WAAK,eAAL,GAAuB,IAAvB;AACD;;;qCAEgB;AACf,WAAK,gBAAL;AACD;;;uCAEkB;AACjB,WAAK,YAAL;AACA,UAAI,mBAAmB,KAAK,MAAL,GAAc,KAAK,YAA1C;AAAA,UACI,mBAAmB,KAAK,MAAL,GAAc,KAAK,YAD1C;AAEA,UAAK,KAAK,GAAL,CAAS,gBAAT,IAA6B,KAAK,oBAAnC,IAA6D,KAAK,GAAL,CAAS,gBAAT,IAA6B,KAAK,oBAAnG,EAA0H;AACxH,aAAK,gBAAL,CAAsB,CAAtB;AACD;AACD,UAAI,KAAK,QAAT,EAAmB;AACjB,aAAK,OAAL,GAAe,KAAK,UAAL,GAAkB,gBAAlB,GAAqC,KAAK,MAAzD;AACA,aAAK,OAAL,GAAe,KAAK,UAAL,GAAkB,gBAAlB,GAAqC,KAAK,MAAzD;AACD,OAHD,MAGO;AACL,aAAK,OAAL,GAAe,KAAK,UAAL,GAAkB,gBAAlB,GAAqC,KAAK,MAAzD;AACA,aAAK,OAAL,GAAe,KAAK,UAAL,GAAkB,gBAAlB,GAAqC,KAAK,MAAzD;AACD;AACD,WAAK,OAAL,IAAgB,KAAK,YAAL,IAAqB,KAAK,OAAL,GAAe,GAApC,CAAhB;AACA,WAAK,OAAL,IAAgB,KAAK,aAAL,IAAsB,KAAK,OAAL,GAAe,GAArC,CAAhB;AACA,UAAI,CAAC,MAAM,WAAW,KAAK,MAAhB,CAAN,CAAL,EAAqC;AACnC,aAAK,OAAL,GAAe,QAAQ,KAAR,CAAc,KAAK,OAAnB,EAA4B,CAAC,KAAK,MAAlC,EAA0C,KAAK,MAA/C,CAAf;AACD;AACD,UAAI,CAAC,MAAM,WAAW,KAAK,MAAhB,CAAN,CAAL,EAAqC;AACnC,aAAK,OAAL,GAAe,QAAQ,KAAR,CAAc,KAAK,OAAnB,EAA4B,CAAC,KAAK,MAAlC,EAA0C,KAAK,MAA/C,CAAf;AACD;AACD,WAAK,SAAL,IAAkB,CAAC,KAAK,OAAL,GAAe,KAAK,SAArB,IAAkC,KAAK,SAAzD;AACA,WAAK,SAAL,IAAkB,CAAC,KAAK,OAAL,GAAe,KAAK,SAArB,IAAkC,KAAK,SAAzD;AACA,WAAK,IAAI,QAAQ,CAAjB,EAAoB,QAAQ,KAAK,MAAL,CAAY,MAAxC,EAAgD,OAAhD,EAAyD;AACvD,YAAI,QAAQ,KAAK,MAAL,CAAY,KAAZ,CAAZ;AAAA,YACI,SAAS,KAAK,OAAL,CAAa,KAAb,CADb;AAAA,YAEI,SAAS,KAAK,OAAL,CAAa,KAAb,CAFb;AAAA,YAGI,UAAU,KAAK,SAAL,IAAkB,UAAU,KAAK,OAAL,GAAe,CAAC,CAAhB,GAAoB,CAA9B,CAAlB,CAHd;AAAA,YAII,UAAU,KAAK,SAAL,IAAkB,UAAU,KAAK,OAAL,GAAe,CAAC,CAAhB,GAAoB,CAA9B,CAAlB,CAJd;AAKA,aAAK,WAAL,CAAiB,KAAjB,EAAwB,OAAxB,EAAiC,OAAjC;AACD;AACD,WAAK,GAAL,GAAW,OAAO,KAAK,gBAAZ,CAAX;AACD;;;2BAEM,I,EAAM,K,EAAM;AACjB;AACA,UAAI,IAAI,CAAC,QAAQ,CAAT,IAAc,YAAtB;AAAA,UAAoC;AAChC,UAAI,CAAC,SAAS,CAAV,IAAe,YADvB,CAFiB,CAGmB;;AAEpC;AACA,UAAI,WAAW,KAAK,YAAL,GAAoB,KAAK,WAAxC;AACA,UAAI,KAAK,QAAL,KAAkB,QAAtB,EAAgC;AAC9B,aAAK,QAAL,GAAgB,QAAhB;AACA,aAAK,eAAL,GAAuB,IAAvB;AACD;;AAED,UAAI,KAAK,eAAT,EAA0B;AACxB,aAAK,eAAL,GAAuB,KAAvB;AACA,aAAK,YAAL,GAAoB,CAApB;AACA,aAAK,YAAL,GAAoB,CAApB;AACD;;AAED,WAAK,MAAL,GAAc,CAAd;AACA,WAAK,MAAL,GAAc,CAAd;AACD;;;wCAEmB,K,EAAO;AACzB,UAAI,OAAO,MAAM,IAAjB;AACA,UAAI,QAAQ,MAAM,KAAlB;AACA,UAAI,SAAS,IAAT,IAAiB,UAAU,IAA/B,EAAqC;AACnC,aAAK,iBAAL,GAAyB,CAAzB;AACA,aAAK,MAAL,CAAY,IAAZ,EAAkB,KAAlB;AACD;AACF;;;mCAEc,K,EAAO;AACpB,UAAI,OAAO,MAAM,YAAN,CAAmB,IAA9B;AACA,UAAI,QAAQ,MAAM,YAAN,CAAmB,KAA/B;AACA,UAAI,SAAS,IAAT,IAAiB,UAAU,IAA/B,EAAqC;AACnC,aAAK,YAAL,GAAoB,CAApB;AACA,aAAK,MAAL,CAAY,IAAZ,EAAkB,KAAlB;AACD;AACF;;;gCAEW,K,EAAO;AACjB,UAAI,UAAU,MAAM,OAApB;AAAA,UACI,UAAU,MAAM,OADpB;;AAGA;AACA,UAAG,KAAK,SAAL,KACC,UAAU,KAAK,gBAAf,IAAmC,UAAU,KAAK,gBAAL,GAAwB,KAAK,YAA3E,IACA,UAAU,KAAK,gBAAf,IAAmC,UAAU,KAAK,gBAAL,GAAwB,KAAK,aAF1E,CAAH,EAE8F;AAC1F,aAAK,MAAL,GAAc,CAAd;AACA,aAAK,MAAL,GAAc,CAAd;AACA;AACD;;AAEH,UAAI,KAAK,aAAT,EAAwB;AACtB;AACA,YAAI,KAAK,iBAAT,EAA4B;AAC1B,oBAAU,KAAK,GAAL,CAAS,OAAT,EAAkB,KAAK,gBAAvB,CAAV;AACA,oBAAU,KAAK,GAAL,CAAS,OAAT,EAAkB,KAAK,gBAAL,GAAwB,KAAK,YAA/C,CAAV;AACA,oBAAU,KAAK,GAAL,CAAS,OAAT,EAAkB,KAAK,gBAAvB,CAAV;AACA,oBAAU,KAAK,GAAL,CAAS,OAAT,EAAkB,KAAK,gBAAL,GAAwB,KAAK,aAA/C,CAAV;AACD;AACD;AACA,YAAG,KAAK,aAAL,IAAsB,KAAK,aAA9B,EAA6C;AAC3C,eAAK,MAAL,GAAc,CAAC,UAAU,KAAK,gBAAf,GAAkC,KAAK,cAAxC,IAA0D,KAAK,aAA7E;AACA,eAAK,MAAL,GAAc,CAAC,UAAU,KAAK,gBAAf,GAAkC,KAAK,cAAxC,IAA0D,KAAK,aAA7E;AACD;AACF,OAbD,MAaO;AACL;AACA,YAAG,KAAK,aAAL,IAAsB,KAAK,aAA9B,EAA6C;AAC3C,eAAK,MAAL,GAAc,CAAC,UAAU,KAAK,aAAhB,IAAiC,KAAK,aAApD;AACA,eAAK,MAAL,GAAc,CAAC,UAAU,KAAK,aAAhB,IAAiC,KAAK,aAApD;AACD;AACF;AACF;;;8BAES;AACR,WAAK,OAAL;;AAEA,mBAAa,KAAK,gBAAlB;AACA,mBAAa,KAAK,cAAlB;;AAEA,WAAK,OAAL,CAAa,eAAb,CAA6B,OAA7B;AACA,WAAK,IAAI,QAAQ,CAAjB,EAAoB,QAAQ,KAAK,MAAL,CAAY,MAAxC,EAAgD,OAAhD,EAAyD;AACvD,aAAK,MAAL,CAAY,KAAZ,EAAmB,eAAnB,CAAmC,OAAnC;AACD;;AAED,aAAO,KAAK,OAAZ;AACA,aAAO,KAAK,MAAZ;AACD;;;8BAES;AACR,aAAO,OAAP;AACD;;;;;;AAIH,OAAO,OAAP,GAAiB,QAAjB","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n'use strict';\n/* eslint-disable no-unused-vars */\nvar getOwnPropertySymbols = Object.getOwnPropertySymbols;\nvar hasOwnProperty = Object.prototype.hasOwnProperty;\nvar propIsEnumerable = Object.prototype.propertyIsEnumerable;\n\nfunction toObject(val) {\n\tif (val === null || val === undefined) {\n\t\tthrow new TypeError('Object.assign cannot be called with null or undefined');\n\t}\n\n\treturn Object(val);\n}\n\nfunction shouldUseNative() {\n\ttry {\n\t\tif (!Object.assign) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// Detect buggy property enumeration order in older V8 versions.\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=4118\n\t\tvar test1 = new String('abc');  // eslint-disable-line no-new-wrappers\n\t\ttest1[5] = 'de';\n\t\tif (Object.getOwnPropertyNames(test1)[0] === '5') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test2 = {};\n\t\tfor (var i = 0; i < 10; i++) {\n\t\t\ttest2['_' + String.fromCharCode(i)] = i;\n\t\t}\n\t\tvar order2 = Object.getOwnPropertyNames(test2).map(function (n) {\n\t\t\treturn test2[n];\n\t\t});\n\t\tif (order2.join('') !== '0123456789') {\n\t\t\treturn false;\n\t\t}\n\n\t\t// https://bugs.chromium.org/p/v8/issues/detail?id=3056\n\t\tvar test3 = {};\n\t\t'abcdefghijklmnopqrst'.split('').forEach(function (letter) {\n\t\t\ttest3[letter] = letter;\n\t\t});\n\t\tif (Object.keys(Object.assign({}, test3)).join('') !==\n\t\t\t\t'abcdefghijklmnopqrst') {\n\t\t\treturn false;\n\t\t}\n\n\t\treturn true;\n\t} catch (err) {\n\t\t// We don't expect any of the above to throw, but better to be safe.\n\t\treturn false;\n\t}\n}\n\nmodule.exports = shouldUseNative() ? Object.assign : function (target, source) {\n\tvar from;\n\tvar to = toObject(target);\n\tvar symbols;\n\n\tfor (var s = 1; s < arguments.length; s++) {\n\t\tfrom = Object(arguments[s]);\n\n\t\tfor (var key in from) {\n\t\t\tif (hasOwnProperty.call(from, key)) {\n\t\t\t\tto[key] = from[key];\n\t\t\t}\n\t\t}\n\n\t\tif (getOwnPropertySymbols) {\n\t\t\tsymbols = getOwnPropertySymbols(from);\n\t\t\tfor (var i = 0; i < symbols.length; i++) {\n\t\t\t\tif (propIsEnumerable.call(from, symbols[i])) {\n\t\t\t\t\tto[symbols[i]] = from[symbols[i]];\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\treturn to;\n};\n","// Generated by CoffeeScript 1.12.2\n(function() {\n  var getNanoSeconds, hrtime, loadTime, moduleLoadTime, nodeLoadTime, upTime;\n\n  if ((typeof performance !== \"undefined\" && performance !== null) && performance.now) {\n    module.exports = function() {\n      return performance.now();\n    };\n  } else if ((typeof process !== \"undefined\" && process !== null) && process.hrtime) {\n    module.exports = function() {\n      return (getNanoSeconds() - nodeLoadTime) / 1e6;\n    };\n    hrtime = process.hrtime;\n    getNanoSeconds = function() {\n      var hr;\n      hr = hrtime();\n      return hr[0] * 1e9 + hr[1];\n    };\n    moduleLoadTime = getNanoSeconds();\n    upTime = process.uptime() * 1e9;\n    nodeLoadTime = moduleLoadTime - upTime;\n  } else if (Date.now) {\n    module.exports = function() {\n      return Date.now() - loadTime;\n    };\n    loadTime = Date.now();\n  } else {\n    module.exports = function() {\n      return new Date().getTime() - loadTime;\n    };\n    loadTime = new Date().getTime();\n  }\n\n}).call(this);\n\n//# sourceMappingURL=performance-now.js.map\n","// shim for using process in browser\nvar process = module.exports = {};\n\n// cached from whatever global is present so that test runners that stub it\n// don't break things.  But we need to wrap it in a try catch in case it is\n// wrapped in strict mode code which doesn't define any globals.  It's inside a\n// function because try/catches deoptimize in certain engines.\n\nvar cachedSetTimeout;\nvar cachedClearTimeout;\n\nfunction defaultSetTimout() {\n    throw new Error('setTimeout has not been defined');\n}\nfunction defaultClearTimeout () {\n    throw new Error('clearTimeout has not been defined');\n}\n(function () {\n    try {\n        if (typeof setTimeout === 'function') {\n            cachedSetTimeout = setTimeout;\n        } else {\n            cachedSetTimeout = defaultSetTimout;\n        }\n    } catch (e) {\n        cachedSetTimeout = defaultSetTimout;\n    }\n    try {\n        if (typeof clearTimeout === 'function') {\n            cachedClearTimeout = clearTimeout;\n        } else {\n            cachedClearTimeout = defaultClearTimeout;\n        }\n    } catch (e) {\n        cachedClearTimeout = defaultClearTimeout;\n    }\n} ())\nfunction runTimeout(fun) {\n    if (cachedSetTimeout === setTimeout) {\n        //normal enviroments in sane situations\n        return setTimeout(fun, 0);\n    }\n    // if setTimeout wasn't available but was latter defined\n    if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) {\n        cachedSetTimeout = setTimeout;\n        return setTimeout(fun, 0);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedSetTimeout(fun, 0);\n    } catch(e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally\n            return cachedSetTimeout.call(null, fun, 0);\n        } catch(e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error\n            return cachedSetTimeout.call(this, fun, 0);\n        }\n    }\n\n\n}\nfunction runClearTimeout(marker) {\n    if (cachedClearTimeout === clearTimeout) {\n        //normal enviroments in sane situations\n        return clearTimeout(marker);\n    }\n    // if clearTimeout wasn't available but was latter defined\n    if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) {\n        cachedClearTimeout = clearTimeout;\n        return clearTimeout(marker);\n    }\n    try {\n        // when when somebody has screwed with setTimeout but no I.E. maddness\n        return cachedClearTimeout(marker);\n    } catch (e){\n        try {\n            // When we are in I.E. but the script has been evaled so I.E. doesn't  trust the global object when called normally\n            return cachedClearTimeout.call(null, marker);\n        } catch (e){\n            // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error.\n            // Some versions of I.E. have different rules for clearTimeout vs setTimeout\n            return cachedClearTimeout.call(this, marker);\n        }\n    }\n\n\n\n}\nvar queue = [];\nvar draining = false;\nvar currentQueue;\nvar queueIndex = -1;\n\nfunction cleanUpNextTick() {\n    if (!draining || !currentQueue) {\n        return;\n    }\n    draining = false;\n    if (currentQueue.length) {\n        queue = currentQueue.concat(queue);\n    } else {\n        queueIndex = -1;\n    }\n    if (queue.length) {\n        drainQueue();\n    }\n}\n\nfunction drainQueue() {\n    if (draining) {\n        return;\n    }\n    var timeout = runTimeout(cleanUpNextTick);\n    draining = true;\n\n    var len = queue.length;\n    while(len) {\n        currentQueue = queue;\n        queue = [];\n        while (++queueIndex < len) {\n            if (currentQueue) {\n                currentQueue[queueIndex].run();\n            }\n        }\n        queueIndex = -1;\n        len = queue.length;\n    }\n    currentQueue = null;\n    draining = false;\n    runClearTimeout(timeout);\n}\n\nprocess.nextTick = function (fun) {\n    var args = new Array(arguments.length - 1);\n    if (arguments.length > 1) {\n        for (var i = 1; i < arguments.length; i++) {\n            args[i - 1] = arguments[i];\n        }\n    }\n    queue.push(new Item(fun, args));\n    if (queue.length === 1 && !draining) {\n        runTimeout(drainQueue);\n    }\n};\n\n// v8 likes predictible objects\nfunction Item(fun, array) {\n    this.fun = fun;\n    this.array = array;\n}\nItem.prototype.run = function () {\n    this.fun.apply(null, this.array);\n};\nprocess.title = 'browser';\nprocess.browser = true;\nprocess.env = {};\nprocess.argv = [];\nprocess.version = ''; // empty string to avoid regexp issues\nprocess.versions = {};\n\nfunction noop() {}\n\nprocess.on = noop;\nprocess.addListener = noop;\nprocess.once = noop;\nprocess.off = noop;\nprocess.removeListener = noop;\nprocess.removeAllListeners = noop;\nprocess.emit = noop;\nprocess.prependListener = noop;\nprocess.prependOnceListener = noop;\n\nprocess.listeners = function (name) { return [] }\n\nprocess.binding = function (name) {\n    throw new Error('process.binding is not supported');\n};\n\nprocess.cwd = function () { return '/' };\nprocess.chdir = function (dir) {\n    throw new Error('process.chdir is not supported');\n};\nprocess.umask = function() { return 0; };\n","var now = require('performance-now')\n  , root = typeof window === 'undefined' ? global : window\n  , vendors = ['moz', 'webkit']\n  , suffix = 'AnimationFrame'\n  , raf = root['request' + suffix]\n  , caf = root['cancel' + suffix] || root['cancelRequest' + suffix]\n\nfor(var i = 0; !raf && i < vendors.length; i++) {\n  raf = root[vendors[i] + 'Request' + suffix]\n  caf = root[vendors[i] + 'Cancel' + suffix]\n      || root[vendors[i] + 'CancelRequest' + suffix]\n}\n\n// Some versions of FF have rAF but not cAF\nif(!raf || !caf) {\n  var last = 0\n    , id = 0\n    , queue = []\n    , frameDuration = 1000 / 60\n\n  raf = function(callback) {\n    if(queue.length === 0) {\n      var _now = now()\n        , next = Math.max(0, frameDuration - (_now - last))\n      last = next + _now\n      setTimeout(function() {\n        var cp = queue.slice(0)\n        // Clear queue here to prevent\n        // callbacks from appending listeners\n        // to the current frame's queue\n        queue.length = 0\n        for(var i = 0; i < cp.length; i++) {\n          if(!cp[i].cancelled) {\n            try{\n              cp[i].callback(last)\n            } catch(e) {\n              setTimeout(function() { throw e }, 0)\n            }\n          }\n        }\n      }, Math.round(next))\n    }\n    queue.push({\n      handle: ++id,\n      callback: callback,\n      cancelled: false\n    })\n    return id\n  }\n\n  caf = function(handle) {\n    for(var i = 0; i < queue.length; i++) {\n      if(queue[i].handle === handle) {\n        queue[i].cancelled = true\n      }\n    }\n  }\n}\n\nmodule.exports = function(fn) {\n  // Wrap in a new function to prevent\n  // `cancel` potentially being assigned\n  // to the native rAF function\n  return raf.call(root, fn)\n}\nmodule.exports.cancel = function() {\n  caf.apply(root, arguments)\n}\nmodule.exports.polyfill = function() {\n  root.requestAnimationFrame = raf\n  root.cancelAnimationFrame = caf\n}\n","/**\n* Parallax.js\n* @author Matthew Wagerfield - @wagerfield, René Roth - mail@reneroth.org\n* @description Creates a parallax effect between an array of layers,\n*              driving the motion from the gyroscope output of a smartdevice.\n*              If no gyroscope is available, the cursor position is used.\n*/\n\nconst rqAnFr = require('raf')\nconst objectAssign = require('object-assign')\n\nconst helpers = {\n  propertyCache: {},\n  vendors: [null, ['-webkit-','webkit'], ['-moz-','Moz'], ['-o-','O'], ['-ms-','ms']],\n\n  clamp(value, min, max) {\n    return min < max\n      ? (value < min ? min : value > max ? max : value)\n      : (value < max ? max : value > min ? min : value)\n  },\n\n  data(element, name) {\n    return helpers.deserialize(element.getAttribute('data-'+name))\n  },\n\n  deserialize(value) {\n    if (value === 'true') {\n      return true\n    } else if (value === 'false') {\n      return false\n    } else if (value === 'null') {\n      return null\n    } else if (!isNaN(parseFloat(value)) && isFinite(value)) {\n      return parseFloat(value)\n    } else {\n      return value\n    }\n  },\n\n  camelCase(value) {\n    return value.replace(/-+(.)?/g, (match, character) => {\n      return character ? character.toUpperCase() : ''\n    })\n  },\n\n  accelerate(element) {\n    helpers.css(element, 'transform', 'translate3d(0,0,0) rotate(0.0001deg)')\n    helpers.css(element, 'transform-style', 'preserve-3d')\n    helpers.css(element, 'backface-visibility', 'hidden')\n  },\n\n  transformSupport(value) {\n    let element = document.createElement('div'),\n        propertySupport = false,\n        propertyValue = null,\n        featureSupport = false,\n        cssProperty = null,\n        jsProperty = null\n    for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n      if (helpers.vendors[i] !== null) {\n        cssProperty = helpers.vendors[i][0] + 'transform'\n        jsProperty = helpers.vendors[i][1] + 'Transform'\n      } else {\n        cssProperty = 'transform'\n        jsProperty = 'transform'\n      }\n      if (element.style[jsProperty] !== undefined) {\n        propertySupport = true\n        break\n      }\n    }\n    switch(value) {\n      case '2D':\n        featureSupport = propertySupport\n        break\n      case '3D':\n        if (propertySupport) {\n          let body = document.body || document.createElement('body'),\n              documentElement = document.documentElement,\n              documentOverflow = documentElement.style.overflow,\n              isCreatedBody = false\n\n          if (!document.body) {\n            isCreatedBody = true\n            documentElement.style.overflow = 'hidden'\n            documentElement.appendChild(body)\n            body.style.overflow = 'hidden'\n            body.style.background = ''\n          }\n\n          body.appendChild(element)\n          element.style[jsProperty] = 'translate3d(1px,1px,1px)'\n          propertyValue = window.getComputedStyle(element).getPropertyValue(cssProperty)\n          featureSupport = propertyValue !== undefined && propertyValue.length > 0 && propertyValue !== 'none'\n          documentElement.style.overflow = documentOverflow\n          body.removeChild(element)\n\n          if ( isCreatedBody ) {\n            body.removeAttribute('style')\n            body.parentNode.removeChild(body)\n          }\n        }\n        break\n    }\n    return featureSupport\n  },\n\n  css(element, property, value) {\n    let jsProperty = helpers.propertyCache[property]\n    if (!jsProperty) {\n      for (let i = 0, l = helpers.vendors.length; i < l; i++) {\n        if (helpers.vendors[i] !== null) {\n          jsProperty = helpers.camelCase(helpers.vendors[i][1] + '-' + property)\n        } else {\n          jsProperty = property\n        }\n        if (element.style[jsProperty] !== undefined) {\n          helpers.propertyCache[property] = jsProperty\n          break\n        }\n      }\n    }\n    element.style[jsProperty] = value\n  }\n\n}\n\nconst MAGIC_NUMBER = 30,\n      DEFAULTS = {\n        relativeInput: false,\n        clipRelativeInput: false,\n        inputElement: null,\n        hoverOnly: false,\n        calibrationThreshold: 100,\n        calibrationDelay: 500,\n        supportDelay: 500,\n        calibrateX: false,\n        calibrateY: true,\n        invertX: true,\n        invertY: true,\n        limitX: false,\n        limitY: false,\n        scalarX: 10.0,\n        scalarY: 10.0,\n        frictionX: 0.1,\n        frictionY: 0.1,\n        originX: 0.5,\n        originY: 0.5,\n        pointerEvents: false,\n        precision: 1,\n        onReady: null,\n        selector: null\n      }\n\nclass Parallax {\n  constructor(element, options) {\n\n    this.element = element\n\n    const data = {\n      calibrateX: helpers.data(this.element, 'calibrate-x'),\n      calibrateY: helpers.data(this.element, 'calibrate-y'),\n      invertX: helpers.data(this.element, 'invert-x'),\n      invertY: helpers.data(this.element, 'invert-y'),\n      limitX: helpers.data(this.element, 'limit-x'),\n      limitY: helpers.data(this.element, 'limit-y'),\n      scalarX: helpers.data(this.element, 'scalar-x'),\n      scalarY: helpers.data(this.element, 'scalar-y'),\n      frictionX: helpers.data(this.element, 'friction-x'),\n      frictionY: helpers.data(this.element, 'friction-y'),\n      originX: helpers.data(this.element, 'origin-x'),\n      originY: helpers.data(this.element, 'origin-y'),\n      pointerEvents: helpers.data(this.element, 'pointer-events'),\n      precision: helpers.data(this.element, 'precision'),\n      relativeInput: helpers.data(this.element, 'relative-input'),\n      clipRelativeInput: helpers.data(this.element, 'clip-relative-input'),\n      hoverOnly: helpers.data(this.element, 'hover-only'),\n      inputElement: document.querySelector(helpers.data(this.element, 'input-element')),\n      selector: helpers.data(this.element, 'selector')\n    }\n\n    for (let key in data) {\n      if (data[key] === null) {\n        delete data[key]\n      }\n    }\n\n    objectAssign(this, DEFAULTS, data, options)\n\n    if(!this.inputElement) {\n      this.inputElement = this.element\n    }\n\n    this.calibrationTimer = null\n    this.calibrationFlag = true\n    this.enabled = false\n    this.depthsX = []\n    this.depthsY = []\n    this.raf = null\n\n    this.bounds = null\n    this.elementPositionX = 0\n    this.elementPositionY = 0\n    this.elementWidth = 0\n    this.elementHeight = 0\n\n    this.elementCenterX = 0\n    this.elementCenterY = 0\n\n    this.elementRangeX = 0\n    this.elementRangeY = 0\n\n    this.calibrationX = 0\n    this.calibrationY = 0\n\n    this.inputX = 0\n    this.inputY = 0\n\n    this.motionX = 0\n    this.motionY = 0\n\n    this.velocityX = 0\n    this.velocityY = 0\n\n    this.onMouseMove = this.onMouseMove.bind(this)\n    this.onDeviceOrientation = this.onDeviceOrientation.bind(this)\n    this.onDeviceMotion = this.onDeviceMotion.bind(this)\n    this.onOrientationTimer = this.onOrientationTimer.bind(this)\n    this.onMotionTimer = this.onMotionTimer.bind(this)\n    this.onCalibrationTimer = this.onCalibrationTimer.bind(this)\n    this.onAnimationFrame = this.onAnimationFrame.bind(this)\n    this.onWindowResize = this.onWindowResize.bind(this)\n\n    this.windowWidth = null\n    this.windowHeight = null\n    this.windowCenterX = null\n    this.windowCenterY = null\n    this.windowRadiusX = null\n    this.windowRadiusY = null\n    this.portrait = false\n    this.desktop = !navigator.userAgent.match(/(iPhone|iPod|iPad|Android|BlackBerry|BB10|mobi|tablet|opera mini|nexus 7)/i)\n    this.motionSupport = !!window.DeviceMotionEvent && !this.desktop\n    this.orientationSupport = !!window.DeviceOrientationEvent && !this.desktop\n    this.orientationStatus = 0\n    this.motionStatus = 0\n\n    this.initialise()\n  }\n\n  initialise() {\n    if (this.transform2DSupport === undefined) {\n      this.transform2DSupport = helpers.transformSupport('2D')\n      this.transform3DSupport = helpers.transformSupport('3D')\n    }\n\n    // Configure Context Styles\n    if (this.transform3DSupport) {\n      helpers.accelerate(this.element)\n    }\n\n    let style = window.getComputedStyle(this.element)\n    if (style.getPropertyValue('position') === 'static') {\n      this.element.style.position = 'relative'\n    }\n\n    // Pointer events\n    if(!this.pointerEvents) {\n      this.element.style.pointerEvents = 'none'\n    }\n\n    // Setup\n    this.updateLayers()\n    this.updateDimensions()\n    this.enable()\n    this.queueCalibration(this.calibrationDelay)\n  }\n\n  doReadyCallback() {\n    if(this.onReady) {\n      this.onReady()\n    }\n  }\n\n  updateLayers() {\n    if(this.selector) {\n      this.layers = this.element.querySelectorAll(this.selector)\n    } else {\n      this.layers = this.element.children\n    }\n\n    if(!this.layers.length) {\n      console.warn('ParallaxJS: Your scene does not have any layers.')\n    }\n\n    this.depthsX = []\n    this.depthsY = []\n\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index]\n\n      if (this.transform3DSupport) {\n        helpers.accelerate(layer)\n      }\n\n      layer.style.position = index ? 'absolute' : 'relative'\n      layer.style.display = 'block'\n      layer.style.left = 0\n      layer.style.top = 0\n\n      let depth = helpers.data(layer, 'depth') || 0\n      this.depthsX.push(helpers.data(layer, 'depth-x') || depth)\n      this.depthsY.push(helpers.data(layer, 'depth-y') || depth)\n    }\n  }\n\n  updateDimensions() {\n    this.windowWidth = window.innerWidth\n    this.windowHeight = window.innerHeight\n    this.windowCenterX = this.windowWidth * this.originX\n    this.windowCenterY = this.windowHeight * this.originY\n    this.windowRadiusX = Math.max(this.windowCenterX, this.windowWidth - this.windowCenterX)\n    this.windowRadiusY = Math.max(this.windowCenterY, this.windowHeight - this.windowCenterY)\n  }\n\n  updateBounds() {\n    this.bounds = this.inputElement.getBoundingClientRect()\n    this.elementPositionX = this.bounds.left\n    this.elementPositionY = this.bounds.top\n    this.elementWidth = this.bounds.width\n    this.elementHeight = this.bounds.height\n    this.elementCenterX = this.elementWidth * this.originX\n    this.elementCenterY = this.elementHeight * this.originY\n    this.elementRangeX = Math.max(this.elementCenterX, this.elementWidth - this.elementCenterX)\n    this.elementRangeY = Math.max(this.elementCenterY, this.elementHeight - this.elementCenterY)\n  }\n\n  queueCalibration(delay) {\n    clearTimeout(this.calibrationTimer)\n    this.calibrationTimer = setTimeout(this.onCalibrationTimer, delay)\n  }\n\n  enable() {\n    if (this.enabled) {\n      return\n    }\n    this.enabled = true\n\n    if (this.orientationSupport) {\n      this.portrait = false\n      window.addEventListener('deviceorientation', this.onDeviceOrientation)\n      this.detectionTimer = setTimeout(this.onOrientationTimer, this.supportDelay)\n    } else if (this.motionSupport) {\n      this.portrait = false\n      window.addEventListener('devicemotion', this.onDeviceMotion)\n      this.detectionTimer = setTimeout(this.onMotionTimer, this.supportDelay)\n    } else {\n      this.calibrationX = 0\n      this.calibrationY = 0\n      this.portrait = false\n      window.addEventListener('mousemove', this.onMouseMove)\n      this.doReadyCallback()\n    }\n\n    window.addEventListener('resize', this.onWindowResize)\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  disable() {\n    if (!this.enabled) {\n      return\n    }\n    this.enabled = false\n\n    if (this.orientationSupport) {\n      window.removeEventListener('deviceorientation', this.onDeviceOrientation)\n    } else if (this.motionSupport) {\n      window.removeEventListener('devicemotion', this.onDeviceMotion)\n    } else {\n      window.removeEventListener('mousemove', this.onMouseMove)\n    }\n\n    window.removeEventListener('resize', this.onWindowResize)\n    rqAnFr.cancel(this.raf)\n  }\n\n  calibrate(x, y) {\n    this.calibrateX = x === undefined ? this.calibrateX : x\n    this.calibrateY = y === undefined ? this.calibrateY : y\n  }\n\n  invert(x, y) {\n    this.invertX = x === undefined ? this.invertX : x\n    this.invertY = y === undefined ? this.invertY : y\n  }\n\n  friction(x, y) {\n    this.frictionX = x === undefined ? this.frictionX : x\n    this.frictionY = y === undefined ? this.frictionY : y\n  }\n\n  scalar(x, y) {\n    this.scalarX = x === undefined ? this.scalarX : x\n    this.scalarY = y === undefined ? this.scalarY : y\n  }\n\n  limit(x, y) {\n    this.limitX = x === undefined ? this.limitX : x\n    this.limitY = y === undefined ? this.limitY : y\n  }\n\n  origin(x, y) {\n    this.originX = x === undefined ? this.originX : x\n    this.originY = y === undefined ? this.originY : y\n  }\n\n  setInputElement(element) {\n    this.inputElement = element\n    this.updateDimensions()\n  }\n\n  setPosition(element, x, y) {\n    x = x.toFixed(this.precision) + 'px'\n    y = y.toFixed(this.precision) + 'px'\n    if (this.transform3DSupport) {\n      helpers.css(element, 'transform', 'translate3d(' + x + ',' + y + ',0)')\n    } else if (this.transform2DSupport) {\n      helpers.css(element, 'transform', 'translate(' + x + ',' + y + ')')\n    } else {\n      element.style.left = x\n      element.style.top = y\n    }\n  }\n\n  onOrientationTimer() {\n    if (this.orientationSupport && this.orientationStatus === 0) {\n      this.disable()\n      this.orientationSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onMotionTimer() {\n    if (this.motionSupport && this.motionStatus === 0) {\n      this.disable()\n      this.motionSupport = false\n      this.enable()\n    } else {\n      this.doReadyCallback()\n    }\n  }\n\n  onCalibrationTimer() {\n    this.calibrationFlag = true\n  }\n\n  onWindowResize() {\n    this.updateDimensions()\n  }\n\n  onAnimationFrame() {\n    this.updateBounds()\n    let calibratedInputX = this.inputX - this.calibrationX,\n        calibratedInputY = this.inputY - this.calibrationY\n    if ((Math.abs(calibratedInputX) > this.calibrationThreshold) || (Math.abs(calibratedInputY) > this.calibrationThreshold)) {\n      this.queueCalibration(0)\n    }\n    if (this.portrait) {\n      this.motionX = this.calibrateX ? calibratedInputY : this.inputY\n      this.motionY = this.calibrateY ? calibratedInputX : this.inputX\n    } else {\n      this.motionX = this.calibrateX ? calibratedInputX : this.inputX\n      this.motionY = this.calibrateY ? calibratedInputY : this.inputY\n    }\n    this.motionX *= this.elementWidth * (this.scalarX / 100)\n    this.motionY *= this.elementHeight * (this.scalarY / 100)\n    if (!isNaN(parseFloat(this.limitX))) {\n      this.motionX = helpers.clamp(this.motionX, -this.limitX, this.limitX)\n    }\n    if (!isNaN(parseFloat(this.limitY))) {\n      this.motionY = helpers.clamp(this.motionY, -this.limitY, this.limitY)\n    }\n    this.velocityX += (this.motionX - this.velocityX) * this.frictionX\n    this.velocityY += (this.motionY - this.velocityY) * this.frictionY\n    for (let index = 0; index < this.layers.length; index++) {\n      let layer = this.layers[index],\n          depthX = this.depthsX[index],\n          depthY = this.depthsY[index],\n          xOffset = this.velocityX * (depthX * (this.invertX ? -1 : 1)),\n          yOffset = this.velocityY * (depthY * (this.invertY ? -1 : 1))\n      this.setPosition(layer, xOffset, yOffset)\n    }\n    this.raf = rqAnFr(this.onAnimationFrame)\n  }\n\n  rotate(beta, gamma){\n    // Extract Rotation\n    let x = (beta || 0) / MAGIC_NUMBER, //  -90 :: 90\n        y = (gamma || 0) / MAGIC_NUMBER // -180 :: 180\n\n    // Detect Orientation Change\n    let portrait = this.windowHeight > this.windowWidth\n    if (this.portrait !== portrait) {\n      this.portrait = portrait\n      this.calibrationFlag = true\n    }\n\n    if (this.calibrationFlag) {\n      this.calibrationFlag = false\n      this.calibrationX = x\n      this.calibrationY = y\n    }\n\n    this.inputX = x\n    this.inputY = y\n  }\n\n  onDeviceOrientation(event) {\n    let beta = event.beta\n    let gamma = event.gamma\n    if (beta !== null && gamma !== null) {\n      this.orientationStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onDeviceMotion(event) {\n    let beta = event.rotationRate.beta\n    let gamma = event.rotationRate.gamma\n    if (beta !== null && gamma !== null) {\n      this.motionStatus = 1\n      this.rotate(beta, gamma)\n    }\n  }\n\n  onMouseMove(event) {\n    let clientX = event.clientX,\n        clientY = event.clientY\n\n    // reset input to center if hoverOnly is set and we're not hovering the element\n    if(this.hoverOnly &&\n      ((clientX < this.elementPositionX || clientX > this.elementPositionX + this.elementWidth) ||\n      (clientY < this.elementPositionY || clientY > this.elementPositionY + this.elementHeight))) {\n        this.inputX = 0\n        this.inputY = 0\n        return\n      }\n\n    if (this.relativeInput) {\n      // Clip mouse coordinates inside element bounds.\n      if (this.clipRelativeInput) {\n        clientX = Math.max(clientX, this.elementPositionX)\n        clientX = Math.min(clientX, this.elementPositionX + this.elementWidth)\n        clientY = Math.max(clientY, this.elementPositionY)\n        clientY = Math.min(clientY, this.elementPositionY + this.elementHeight)\n      }\n      // Calculate input relative to the element.\n      if(this.elementRangeX && this.elementRangeY) {\n        this.inputX = (clientX - this.elementPositionX - this.elementCenterX) / this.elementRangeX\n        this.inputY = (clientY - this.elementPositionY - this.elementCenterY) / this.elementRangeY\n      }\n    } else {\n      // Calculate input relative to the window.\n      if(this.windowRadiusX && this.windowRadiusY) {\n        this.inputX = (clientX - this.windowCenterX) / this.windowRadiusX\n        this.inputY = (clientY - this.windowCenterY) / this.windowRadiusY\n      }\n    }\n  }\n\n  destroy() {\n    this.disable()\n\n    clearTimeout(this.calibrationTimer)\n    clearTimeout(this.detectionTimer)\n\n    this.element.removeAttribute('style')\n    for (let index = 0; index < this.layers.length; index++) {\n      this.layers[index].removeAttribute('style')\n    }\n\n    delete this.element\n    delete this.layers\n  }\n\n  version() {\n    return '3.1.0'\n  }\n\n}\n\nmodule.exports = Parallax\n"]}\n","/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation. All rights reserved.\r\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not use\r\nthis file except in compliance with the License. You may obtain a copy of the\r\nLicense at http://www.apache.org/licenses/LICENSE-2.0\r\n\r\nTHIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\r\nKIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\r\nWARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\r\nMERCHANTABLITY OR NON-INFRINGEMENT.\r\n\r\nSee the Apache Version 2.0 License for specific language governing permissions\r\nand limitations under the License.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n    extendStatics = Object.setPrototypeOf ||\r\n        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };\r\n    return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n    extendStatics(d, b);\r\n    function __() { this.constructor = d; }\r\n    d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n    __assign = Object.assign || function __assign(t) {\r\n        for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n            s = arguments[i];\r\n            for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n        }\r\n        return t;\r\n    }\r\n    return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n    var t = {};\r\n    for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n        t[p] = s[p];\r\n    if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n        for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n            if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n                t[p[i]] = s[p[i]];\r\n        }\r\n    return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n    var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n    if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n    else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n    return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n    return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n    if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n    return new (P || (P = Promise))(function (resolve, reject) {\r\n        function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n        function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n        function step(result) { result.done ? resolve(result.value) : new P(function (resolve) { resolve(result.value); }).then(fulfilled, rejected); }\r\n        step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n    });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n    var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n    return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n    function verb(n) { return function (v) { return step([n, v]); }; }\r\n    function step(op) {\r\n        if (f) throw new TypeError(\"Generator is already executing.\");\r\n        while (_) try {\r\n            if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n            if (y = 0, t) op = [op[0] & 2, t.value];\r\n            switch (op[0]) {\r\n                case 0: case 1: t = op; break;\r\n                case 4: _.label++; return { value: op[1], done: false };\r\n                case 5: _.label++; y = op[1]; op = [0]; continue;\r\n                case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n                default:\r\n                    if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n                    if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n                    if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n                    if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n                    if (t[2]) _.ops.pop();\r\n                    _.trys.pop(); continue;\r\n            }\r\n            op = body.call(thisArg, _);\r\n        } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n        if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n    }\r\n}\r\n\r\nexport function __exportStar(m, exports) {\r\n    for (var p in m) if (!exports.hasOwnProperty(p)) exports[p] = m[p];\r\n}\r\n\r\nexport function __values(o) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator], i = 0;\r\n    if (m) return m.call(o);\r\n    return {\r\n        next: function () {\r\n            if (o && i >= o.length) o = void 0;\r\n            return { value: o && o[i++], done: !o };\r\n        }\r\n    };\r\n}\r\n\r\nexport function __read(o, n) {\r\n    var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n    if (!m) return o;\r\n    var i = m.call(o), r, ar = [], e;\r\n    try {\r\n        while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n    }\r\n    catch (error) { e = { error: error }; }\r\n    finally {\r\n        try {\r\n            if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n        }\r\n        finally { if (e) throw e.error; }\r\n    }\r\n    return ar;\r\n}\r\n\r\nexport function __spread() {\r\n    for (var ar = [], i = 0; i < arguments.length; i++)\r\n        ar = ar.concat(__read(arguments[i]));\r\n    return ar;\r\n}\r\n\r\nexport function __spreadArrays() {\r\n    for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n    for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n        for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n            r[k] = a[j];\r\n    return r;\r\n};\r\n\r\nexport function __await(v) {\r\n    return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n    return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n    function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n    function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n    function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n    function fulfill(value) { resume(\"next\", value); }\r\n    function reject(value) { resume(\"throw\", value); }\r\n    function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n    var i, p;\r\n    return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n    function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n    if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n    var m = o[Symbol.asyncIterator], i;\r\n    return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n    function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n    function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n    if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n    return cooked;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n    if (mod && mod.__esModule) return mod;\r\n    var result = {};\r\n    if (mod != null) for (var k in mod) if (Object.hasOwnProperty.call(mod, k)) result[k] = mod[k];\r\n    result.default = mod;\r\n    return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n    return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","module.exports = __webpack_public_path__ + \"bundle.css\";","/**\r\n * Copyright 2019 Mashiro\r\n * @description material-components initial configuration\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\n\r\nimport { MDCRipple } from '@material/ripple';\r\nimport { MDCTextField } from '@material/textfield';\r\nimport { MDCTopAppBar } from '@material/top-app-bar';\r\n\r\nconst Conf = [\r\n    ['.mdc-top-app-bar', MDCTopAppBar],\r\n    ['.mdc-text-field', MDCTextField],\r\n    [\r\n        [\r\n            '.mdc-button',\r\n            '.primary-action',\r\n        ],\r\n        MDCRipple\r\n    ],\r\n]\r\n\r\nexport default Conf","/**\r\n * Copyright 2019 Mashiro\r\n * @description material-components initial handler\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\nimport mdcConf from \"./mdcConf\"\r\n\r\nconst Conf = mdcConf\r\n\r\n/** \r\n * Initial [material-components-web](https://github.com/material-components/material-components-web/) \r\n * through configuration in `mdcConf.ts``.\r\n * See <https://git.io/JegHJ>\r\n */\r\nexport default function () {\r\n    let components = []\r\n    for (const i of Conf) {\r\n        if (typeof (i[0]) == 'string') {\r\n            const component = i[0]\r\n            const constructor = i[1]\r\n            components.map.call(document.querySelectorAll(component), function (e: any) {\r\n                return new constructor(e)\r\n            })\r\n        } else if (typeof (i[0]) == 'object') {\r\n            const component = i[0].join(',')\r\n            const constructor = i[1]\r\n            components.map.call(document.querySelectorAll(component), function (e: any) {\r\n                return new constructor(e)\r\n            })\r\n        }\r\n    }\r\n}","/**\r\n * Copyright 2019 Mashiro\r\n * @description Main\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\n\r\nimport coverImgIni from \"./modules/coverImgInit\"\r\nimport headerBarScrollHandler from \"./modules/headerBarScrollHandler\"\r\nimport mdcInit from \"./components/mdcInit\"\r\n\r\n\r\nwindow.onscroll = function () {\r\n  headerBarScrollHandler()\r\n}\r\n\r\nwindow.onload = function () {\r\n  coverImgIni()\r\n  mdcInit()\r\n\r\n}","/**\r\n * Copyright 2019 Mashiro\r\n * @description Sakura theme module\r\n * @author Mashiro\r\n * @license MIT\r\n */\r\n\r\nimport Parallax from 'parallax-js'\r\n\r\n/**\r\n * Initial index cover image and image box.\r\n * Include Parallax box initial and `#cover-img-container` size initial.\r\n */\r\nexport default function () {\r\n    let coverImgContainer = <HTMLElement>document.querySelector(\"#cover-img-container\")\r\n    coverImgContainer.style.height = `${window.innerHeight}px`\r\n    let headerTopAfter = <HTMLElement>document.querySelector(\"#header-top-after\")\r\n    headerTopAfter.style.height = `${window.innerHeight}px`\r\n\r\n    interface LooseObject {\r\n        [key: string]: any\r\n    }\r\n\r\n    /**\r\n     * cover: `img#cover-img`\r\n     */\r\n    let coverImg: LooseObject = {}\r\n    /**\r\n     * mark: `figure#cover-img-container`\r\n     */\r\n    let coverBox: LooseObject = {}\r\n    /**\r\n     * layer: `div#img-view`\r\n     */\r\n    let coverView: LooseObject = {}\r\n\r\n    coverImg.e = <HTMLImageElement>document.querySelector(\"#cover-img\")\r\n    coverImg.w = <number>coverImg.e.naturalWidth\r\n    coverImg.h = <number>coverImg.e.naturalHeight\r\n\r\n    coverBox.e = <HTMLImageElement>document.querySelector(\"#cover-img-container\")\r\n    coverBox.w = <number>coverBox.e.offsetWidth\r\n    coverBox.h = <number>coverBox.e.offsetHeight\r\n\r\n    coverView.e = <HTMLImageElement>document.querySelector(\"#img-view\")\r\n\r\n    coverBox.e.style.height = `${window.innerHeight}px`\r\n\r\n    coverBox.f = (coverBox.w >= 1000 || coverBox.h >= 1000) ? 1000 : 500\r\n    if (coverBox.w >= coverBox.h) {\r\n        coverBox.i = coverBox.w / coverBox.f * 50;\r\n        coverBox.y = coverBox.i;\r\n        coverBox.x = coverBox.i * coverBox.w / coverBox.h;\r\n    } else {\r\n        coverBox.i = coverBox.h / coverBox.f * 50;\r\n        coverBox.x = coverBox.i;\r\n        coverBox.y = coverBox.i * coverBox.h / coverBox.w;\r\n    }\r\n\r\n    coverView.e.style.cssText = `\r\n        width: ${coverBox.w + coverBox.x}px; \r\n        height: ${coverBox.h + coverBox.y}px; \r\n        margin-left: ${-0.5 * coverBox.x}px; \r\n        margin-top: ${-0.5 * coverBox.y}px`\r\n\r\n    coverImg.e.style.cssText = `\r\n        width: ${coverView.w + coverView.x}px;\r\n        height: ${coverView.h + coverView.y}px`\r\n\r\n    if (!coverImg.w) {\r\n        coverImg.w = coverImg.e.offsetWidth\r\n        coverImg.h = coverImg.e.offsetHeight;\r\n    }\r\n\r\n    coverImg._w = coverImg.e.parentElement.offsetWidth\r\n    coverImg._h = coverImg.e.parentElement.offsetHeight\r\n    coverImg.ratio = coverImg.h / coverImg.w\r\n\r\n    if (coverImg._h / coverImg._w > coverImg.ratio) {\r\n        coverImg.e.style.height = coverImg._h + 'px';\r\n        coverImg.e.style.width = coverImg._h / coverImg.ratio + 'px';\r\n    } else {\r\n        coverImg.e.style.width = coverImg._w + 'px';\r\n        coverImg.e.style.height = coverImg._w * coverImg.ratio + 'px';\r\n    }\r\n\r\n    coverImg.e.style.left = (coverImg._w - parseInt(coverImg.e.style.width)) / 2 + 'px';\r\n    coverImg.e.style.top = (coverImg._h - parseInt(coverImg.e.style.height)) / 2 + 'px';\r\n\r\n    let scene = document.querySelector('#cover-img-container')\r\n    let parallaxInstance = new Parallax(scene);\r\n}","/**\r\n * @description Sakura theme module\r\n * @author Mashiro\r\n * @since 19/10/31\r\n * @license MIT\r\n */\r\n\r\nimport scrollDirection from \"./scrollDirection\"\r\n\r\n/**\r\n * Site top bar handler when page scroll\r\n */\r\nexport default function () {\r\n    let ele: HTMLElement = document.querySelector(\"#nav-header\")\r\n    if (scrollDirection('y') == 'down') {\r\n        ele.style.top = `-120px`\r\n    }\r\n    else if (scrollDirection('y') == 'up') {\r\n        ele.style.top = `0px`\r\n    }\r\n}","/**\r\n * @description Sakura theme module\r\n * @author Mashiro\r\n * @since 19/10/31\r\n * @license MIT\r\n */\r\n\r\nlet scrollAction: {\r\n    x: number,\r\n    y: number,\r\n    d: string\r\n} = {\r\n    x: undefined,\r\n    y: undefined,\r\n    d: undefined\r\n}\r\n\r\n/**\r\n * Detect window scroll direction\r\n * @param  {string}  direction  option: `Y`/`y` - horizontal; `X`/`x` - vertical\r\n * @return {string}             return window scroll direction\r\n */\r\nexport default function (direction: string) {\r\n    if (scrollAction.x == undefined) {\r\n        scrollAction.x = window.pageXOffset\r\n        scrollAction.y = window.pageYOffset\r\n    }\r\n    let diffX = scrollAction.x - window.pageXOffset\r\n    let diffY = scrollAction.y - window.pageYOffset\r\n    if (direction == 'x' || direction == 'X' ) {\r\n        if (diffX < 0) {\r\n            scrollAction.d = 'right'\r\n        } else if (diffX > 0) {\r\n            scrollAction.d = 'left'\r\n        }\r\n    } else {\r\n        if (diffY < 0) {\r\n            scrollAction.d = 'down'\r\n        } else if (diffY > 0) {\r\n            scrollAction.d = 'up'\r\n        }\r\n    }\r\n    scrollAction.x = window.pageXOffset\r\n    scrollAction.y = window.pageYOffset\r\n    return scrollAction.d\r\n}"],"sourceRoot":""} \ No newline at end of file