Skip to content

Instantly share code, notes, and snippets.

@hermesalvesbr
Created August 23, 2023 10:11
Show Gist options
  • Save hermesalvesbr/fd59edc24bdbd3403630417067b12391 to your computer and use it in GitHub Desktop.
Save hermesalvesbr/fd59edc24bdbd3403630417067b12391 to your computer and use it in GitHub Desktop.
window.VLibras = (function (n) {
var e = {}
function t(r) {
if (e[r]) return e[r].exports
var s = (e[r] = { i: r, l: !1, exports: {} })
return n[r].call(s.exports, s, s.exports, t), (s.l = !0), s.exports
}
return (
(t.m = n),
(t.c = e),
(t.d = function (n, e, r) {
t.o(n, e) || Object.defineProperty(n, e, { enumerable: !0, get: r })
}),
(t.r = function (n) {
'undefined' != typeof Symbol &&
Symbol.toStringTag &&
Object.defineProperty(n, Symbol.toStringTag, {
value: 'Module',
}),
Object.defineProperty(n, '__esModule', { value: !0 })
}),
(t.t = function (n, e) {
if ((1 & e && (n = t(n)), 8 & e)) return n
if (4 & e && 'object' == typeof n && n && n.__esModule) return n
var r = Object.create(null)
if (
(t.r(r),
Object.defineProperty(r, 'default', {
enumerable: !0,
value: n,
}),
2 & e && 'string' != typeof n)
)
for (var s in n)
t.d(
r,
s,
function (e) {
return n[e]
}.bind(null, s)
)
return r
}),
(t.n = function (n) {
var e =
n && n.__esModule
? function () {
return n.default
}
: function () {
return n
}
return t.d(e, 'a', e), e
}),
(t.o = function (n, e) {
return Object.prototype.hasOwnProperty.call(n, e)
}),
(t.p = ''),
t((t.s = './widget/src/index.js'))
)
})({
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./node_modules/nouislider/distribute/nouislider.min.css':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "/*! nouislider - 8.5.1 - 2016-04-24 16:00:30 */\\n.noUi-target, .noUi-target * {\\n -webkit-touch-callout: none;\\n -webkit-user-select: none;\\n -ms-touch-action: none;\\n touch-action: none;\\n -ms-user-select: none;\\n -moz-user-select: none;\\n user-select: none;\\n -moz-box-sizing: border-box;\\n box-sizing: border-box; }\\n\\n.noUi-target {\\n position: relative;\\n direction: ltr; }\\n\\n.noUi-base {\\n width: 100%;\\n height: 100%;\\n position: relative;\\n z-index: 1; }\\n\\n.noUi-origin {\\n position: absolute;\\n right: 0;\\n top: 0;\\n left: 0;\\n bottom: 0; }\\n\\n.noUi-handle {\\n position: relative;\\n z-index: 1; }\\n\\n.noUi-stacking .noUi-handle {\\n z-index: 10; }\\n\\n.noUi-state-tap .noUi-origin {\\n -webkit-transition: left .3s,top .3s;\\n transition: left .3s,top .3s; }\\n\\n.noUi-state-drag * {\\n cursor: inherit !important; }\\n\\n.noUi-base, .noUi-handle {\\n -webkit-transform: translate3d(0, 0, 0);\\n transform: translate3d(0, 0, 0); }\\n\\n.noUi-horizontal {\\n height: 18px; }\\n\\n.noUi-horizontal .noUi-handle {\\n width: 34px;\\n height: 28px;\\n left: -17px;\\n top: -6px; }\\n\\n.noUi-vertical {\\n width: 18px; }\\n\\n.noUi-vertical .noUi-handle {\\n width: 28px;\\n height: 34px;\\n left: -6px;\\n top: -17px; }\\n\\n.noUi-background {\\n background: #FAFAFA;\\n box-shadow: inset 0 1px 1px #f0f0f0; }\\n\\n.noUi-connect {\\n background: #3FB8AF;\\n box-shadow: inset 0 0 3px rgba(51, 51, 51, 0.45);\\n -webkit-transition: background 450ms;\\n transition: background 450ms; }\\n\\n.noUi-origin {\\n border-radius: 2px; }\\n\\n.noUi-target {\\n border-radius: 4px;\\n border: 1px solid #D3D3D3;\\n box-shadow: inset 0 1px 1px #F0F0F0,0 3px 6px -5px #BBB; }\\n\\n.noUi-target.noUi-connect {\\n box-shadow: inset 0 0 3px rgba(51, 51, 51, 0.45), 0 3px 6px -5px #BBB; }\\n\\n.noUi-draggable {\\n cursor: w-resize; }\\n\\n.noUi-vertical .noUi-draggable {\\n cursor: n-resize; }\\n\\n.noUi-handle {\\n border: 1px solid #D9D9D9;\\n border-radius: 3px;\\n background: #FFF;\\n cursor: default;\\n box-shadow: inset 0 0 1px #FFF,inset 0 1px 7px #EBEBEB,0 3px 6px -3px #BBB; }\\n\\n.noUi-active {\\n box-shadow: inset 0 0 1px #FFF,inset 0 1px 7px #DDD,0 3px 6px -3px #BBB; }\\n\\n.noUi-handle:after, .noUi-handle:before {\\n content: \\"\\";\\n display: block;\\n position: absolute;\\n height: 14px;\\n width: 1px;\\n background: #E8E7E6;\\n left: 14px;\\n top: 6px; }\\n\\n.noUi-handle:after {\\n left: 17px; }\\n\\n.noUi-vertical .noUi-handle:after, .noUi-vertical .noUi-handle:before {\\n width: 14px;\\n height: 1px;\\n left: 6px;\\n top: 14px; }\\n\\n.noUi-vertical .noUi-handle:after {\\n top: 17px; }\\n\\n[disabled] .noUi-connect, [disabled].noUi-connect {\\n background: #B8B8B8; }\\n\\n[disabled] .noUi-handle, [disabled].noUi-origin {\\n cursor: not-allowed; }\\n\\n.noUi-pips, .noUi-pips * {\\n -moz-box-sizing: border-box;\\n box-sizing: border-box; }\\n\\n.noUi-pips {\\n position: absolute;\\n color: #999; }\\n\\n.noUi-value {\\n position: absolute;\\n text-align: center; }\\n\\n.noUi-value-sub {\\n color: #ccc;\\n font-size: 10px; }\\n\\n.noUi-marker {\\n position: absolute;\\n background: #CCC; }\\n\\n.noUi-marker-large, .noUi-marker-sub {\\n background: #AAA; }\\n\\n.noUi-pips-horizontal {\\n padding: 10px 0;\\n height: 80px;\\n top: 100%;\\n left: 0;\\n width: 100%; }\\n\\n.noUi-value-horizontal {\\n -webkit-transform: translate3d(-50%, 50%, 0);\\n transform: translate3d(-50%, 50%, 0); }\\n\\n.noUi-marker-horizontal.noUi-marker {\\n margin-left: -1px;\\n width: 2px;\\n height: 5px; }\\n\\n.noUi-marker-horizontal.noUi-marker-sub {\\n height: 10px; }\\n\\n.noUi-marker-horizontal.noUi-marker-large {\\n height: 15px; }\\n\\n.noUi-pips-vertical {\\n padding: 0 10px;\\n height: 100%;\\n top: 0;\\n left: 100%; }\\n\\n.noUi-value-vertical {\\n -webkit-transform: translate3d(0, -50%, 0);\\n transform: translate3d(0, -50%, 0);\\n padding-left: 25px; }\\n\\n.noUi-marker-vertical.noUi-marker {\\n width: 5px;\\n height: 2px;\\n margin-top: -1px; }\\n\\n.noUi-marker-vertical.noUi-marker-sub {\\n width: 10px; }\\n\\n.noUi-marker-vertical.noUi-marker-large {\\n width: 15px; }\\n\\n.noUi-tooltip {\\n display: block;\\n position: absolute;\\n border: 1px solid #D9D9D9;\\n border-radius: 3px;\\n background: #fff;\\n padding: 5px;\\n text-align: center; }\\n\\n.noUi-horizontal .noUi-handle-lower .noUi-tooltip {\\n top: -32px; }\\n\\n.noUi-horizontal .noUi-handle-upper .noUi-tooltip {\\n bottom: -32px; }\\n\\n.noUi-vertical .noUi-handle-lower .noUi-tooltip {\\n left: 120%; }\\n\\n.noUi-vertical .noUi-handle-upper .noUi-tooltip {\\n right: 120%; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./node_modules/nouislider/distribute/nouislider.min.css?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] [vp-change-avatar] {\\n justify-content: start;\\n align-items: center;\\n flex-direction: row;\\n gap: 10px;\\n position: absolute;\\n z-index: 2;\\n display: none;\\n max-width: 100%;\\n opacity: 1;\\n left: 14px;\\n top: 50px;\\n height: 36px;\\n width: 36px;\\n overflow: hidden;\\n transition: all .3s ease-in-out; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar {\\n display: flex;\\n justify-content: center;\\n align-items: center;\\n cursor: pointer;\\n background: #838890;\\n border-radius: 50px;\\n width: 32px;\\n height: 32px;\\n min-width: 32px;\\n border: 2px solid transparent;\\n outline: 2px solid transparent;\\n padding: 0 !important;\\n z-index: -1;\\n opacity: 0;\\n transition: all .3s ease-in-out; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar svg {\\n width: 20px;\\n height: 20px;\\n fill: #FFFFFF; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar::after {\\n content: attr(avatar-name);\\n display: none;\\n align-items: center;\\n justify-content: center;\\n top: 38px;\\n background-color: #363636;\\n padding: 0 10px;\\n height: 28px;\\n padding-bottom: 4px;\\n align-items: center;\\n justify-content: center;\\n position: absolute;\\n border-radius: 0 20px 20px 20px;\\n transform: translateX(60%);\\n color: #FDFDFD;\\n font-size: .9rem;\\n font-weight: 500; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar:hover {\\n outline-color: rgba(131, 136, 144, 0.3); }\\n [vp] [vp-change-avatar] .vp-button-change-avatar:hover::after {\\n display: flex; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar.vp-selected {\\n display: flex !important;\\n background-color: #3885F9;\\n outline-color: #3885F9;\\n border-color: #e0e0e0;\\n position: absolute;\\n left: 2px;\\n z-index: 1;\\n opacity: 1; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar.vp-selected::after {\\n display: none; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar.vp-selected:hover {\\n outline-color: rgba(56, 133, 249, 0.5); }\\n [vp] [vp-change-avatar] .vp-button-change-avatar .active {\\n display: block; }\\n @media (max-width: 450px) {\\n [vp] [vp-change-avatar] .vp-button-change-avatar {\\n width: 28px;\\n height: 28px;\\n min-width: 28px; } }\\n [vp] [vp-change-avatar].vp-change-avatar-openned {\\n padding-left: 42px;\\n width: 120px;\\n overflow: visible; }\\n [vp] [vp-change-avatar].vp-change-avatar-openned button {\\n opacity: 1; }\\n [vp] [vp-change-avatar].active {\\n display: flex; }\\n @media (max-width: 450px) {\\n [vp] [vp-change-avatar] {\\n left: 8px; }\\n [vp] [vp-change-avatar] .vp-button-change-avatar::after {\\n top: 32px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] [vp-translator-screen] {\\n overflow: hidden;\\n position: absolute;\\n right: 0;\\n left: 0;\\n height: 0;\\n bottom: 0;\\n width: 100%;\\n padding: 0;\\n background-color: white;\\n z-index: 5;\\n border-radius: 10px 10px 0 0;\\n transition: all .3s ease;\\n /* Track */\\n /* Handle */\\n /* Handle on hover */ }\\n [vp] [vp-translator-screen] ::-webkit-scrollbar {\\n width: 10px; }\\n [vp] [vp-translator-screen] ::-webkit-scrollbar-track {\\n background: #d1d1d1f1 !important; }\\n [vp] [vp-translator-screen] ::-webkit-scrollbar-thumb {\\n background: #8b8b99; }\\n [vp] [vp-translator-screen] ::-webkit-scrollbar-thumb:hover {\\n background: #555; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header {\\n width: 100%;\\n height: 48px;\\n border-bottom: 1px solid #D8D9DB;\\n display: flex;\\n padding: 16px;\\n align-items: center;\\n justify-content: space-between; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header span {\\n font-size: 14px;\\n font-weight: 600; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54;\\n transition: transform .3s; }\\n @media (max-width: 450px) {\\n [vp] [vp-translator-screen] .vp-translator-screen-header button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button svg * {\\n fill: #0F2B54; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button.speed-button {\\n width: 40px; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button:hover {\\n background-color: #E8E9EA; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button:activesvg > * {\\n fill: #0F2B54; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] [vp-translator-screen] .vp-translator-screen-header button svg > * {\\n fill: #0F2B54; }\\n @media (max-width: 450px) {\\n [vp] [vp-translator-screen] .vp-translator-screen-header {\\n height: 38px;\\n padding: 10px; } }\\n [vp] [vp-translator-screen] .vp-translator-screen-content {\\n display: flex;\\n align-items: center;\\n justify-content: start;\\n flex-direction: column;\\n gap: 10px;\\n width: 100%;\\n height: 100%;\\n padding: 16px; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-title {\\n width: 100%;\\n text-align: left;\\n font-weight: 700;\\n font-size: 14px;\\n color: #363636; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-text {\\n padding: 10px;\\n width: 100%;\\n resize: none;\\n border-radius: 5px;\\n border: 1px solid #D8D9DB;\\n height: 160px;\\n font-size: 1rem;\\n outline: none !important;\\n display: block !important; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-text:hover {\\n border-color: #838890; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-text:focus {\\n border: 1.6px solid #3885F9;\\n box-shadow: 0px 0px 15px rgba(86, 154, 255, 0.75); }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-translator-buttons-container {\\n width: 100%;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-direction: column;\\n gap: 10px; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-translator-buttons-container button {\\n width: 100% !important; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-translator-buttons-container .vp-visualize-signal-button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n height: 36px;\\n border-radius: 40px;\\n border: 1px solid #0D459D;\\n font-size: 14px;\\n font-weight: 600;\\n background-color: #0D459D;\\n color: #FDFDFD; }\\n @media (max-width: 450px) {\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-translator-buttons-container .vp-visualize-signal-button {\\n height: 28px;\\n font-size: 12px; } }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-translator-buttons-container .vp-visualize-signal-button:hover {\\n background-color: #3885F9;\\n border-color: #3885F9; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-translator-buttons-container .vp-visualize-signal-button:disabled {\\n background-color: #E8E9EA;\\n border-color: #D8D9DB;\\n cursor: not-allowed;\\n user-select: none;\\n color: #838890; }\\n [vp] [vp-translator-screen].vp-enabled {\\n height: calc(100% - 60px); }\\n @media (max-width: 450px) {\\n [vp] [vp-translator-screen] .vp-translator-screen-content {\\n gap: 6px;\\n padding: 10px; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-text {\\n height: 120px;\\n font-size: .8rem; }\\n [vp] [vp-translator-screen] .vp-translator-screen-content .vp-translator-buttons-container {\\n gap: 6px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/WidgetHelp/widget-help.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-tutorial {\\n display: none; }\\n [vp] .vpw-tutorial .vpw-tutorial__message {\\n color: #FDFDFD;\\n font-size: 1rem; }\\n [vp] .vpw-tutorial .vpw-tutorial__footer {\\n display: flex;\\n align-items: center;\\n justify-content: space-between;\\n flex-direction: row;\\n border-top: 1px solid #4C4C4C; }\\n [vp] .vpw-tutorial .vpw-tutorial__footer .vpw-tutorial__back-btn {\\n color: #FDFDFD;\\n outline-color: #FDFDFD;\\n color: #363636; }\\n [vp] .vpw-tutorial .vpw-tutorial__footer .vpw-tutorial__next-btn {\\n color: #363636;\\n background-color: #FDFDFD; }\\n [vp] .vpw-tutorial.vp-enabled {\\n display: flex; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/WidgetHelp/widget-help.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/additional-options.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] [vp-additional-options] {\\n justify-content: center;\\n flex-direction: column;\\n gap: 10px;\\n position: absolute;\\n z-index: 2;\\n display: none;\\n max-width: 100%;\\n opacity: 1;\\n transition: max-width 0s, visibility 0s, opacity 0.4s;\\n left: 16px;\\n top: 96px; }\\n [vp] [vp-additional-options] button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n width: 32px;\\n border-radius: 50%;\\n height: 32px;\\n cursor: pointer;\\n background-color: #838890;\\n border: 2px solid transparent;\\n outline: 2px solid transparent;\\n outline-offset: 0;\\n padding: 0 !important; }\\n @media (max-width: 450px) {\\n [vp] [vp-additional-options] button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] [vp-additional-options] button svg {\\n width: 18px;\\n height: 18px; }\\n [vp] [vp-additional-options] button svg * {\\n fill: #FFF; }\\n [vp] [vp-additional-options] button:hover {\\n outline-color: rgba(131, 136, 144, 0.3);\\n opacity: 1 !important; }\\n @media (hover: hover) {\\n [vp] [vp-additional-options] button[data-title]:hover::after {\\n content: attr(data-title);\\n background-color: #363636;\\n position: absolute;\\n border-radius: 20px;\\n color: #FFF;\\n font-size: .9rem;\\n font-weight: 500;\\n white-space: nowrap;\\n padding: 4px 10px;\\n left: 40px;\\n display: block; } }\\n [vp] [vp-additional-options].vp-enabled {\\n display: flex; }\\n @media (max-width: 450px) {\\n [vp] [vp-additional-options] {\\n left: 10px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/additional-options.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Box/box.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-box {\\n width: calc(100%);\\n height: 40px;\\n font-size: 1em;\\n color: #000;\\n opacity: 1;\\n position: relative;\\n background-color: #0D459D;\\n color: #ffffff;\\n background-size: 100% 100%;\\n z-index: 10; }\\n [vp] .vpw-box .vpw-mes {\\n position: absolute;\\n left: 50%;\\n top: 50%;\\n transform: translate(-50%, -50%);\\n font-size: 14px;\\n font-family: \'rawline\', sans-serif;\\n font-weight: bold; }\\n @media (max-width: 450px) {\\n [vp] .vpw-box .vpw-mes {\\n font-size: 10px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Box/box.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Controls/controls.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, ".vpw-fullscreen {\\n overflow: hidden !important; }\\n .vpw-fullscreen [vw] {\\n top: 0 !important;\\n left: 0 !important;\\n transform: none !important;\\n margin: 0 !important;\\n max-width: 100vw; }\\n .vpw-fullscreen [vw] [vw-plugin-wrapper].active {\\n width: 100vw !important;\\n height: 100vh !important;\\n border-radius: 0px;\\n -moz-border-radius: 0px;\\n -webkit-border-radius: 0px; }\\n .vpw-fullscreen [vp] .vpw-box .vpw-mes {\\n font-size: 14px; }\\n .vpw-fullscreen [vp] .vpw-options-container :last-child {\\n display: none; }\\n .vpw-fullscreen [vp] .vp-text {\\n height: 30vh !important; }\\n .vpw-fullscreen [vp] .vpw-logo-group {\\n flex-wrap: wrap;\\n align-items: center;\\n justify-content: start;\\n -webkit-flex-wrap: wrap;\\n -webkit-align-items: center;\\n -webkit-justify-content: start; }\\n .vpw-fullscreen [vp] .vpw-dict-container,\\n .vpw-fullscreen [vp] .vpw-recents-container {\\n height: 80% !important; }\\n .vpw-fullscreen [vp] .vpw-controls {\\n gap: 10px !important; }\\n .vpw-fullscreen [vp] .vpw-settings,\\n .vpw-fullscreen [vp] .vpw-info-screen {\\n max-width: 100vw !important; }\\n .vpw-fullscreen [vp] .vpw-settings-content {\\n height: 100% !important; }\\n .vpw-fullscreen [vp] .vpw-controls-slider {\\n width: 60% !important; }\\n .vpw-fullscreen [vp] .vp-visualize-signal-button,\\n .vpw-fullscreen [vp] .vp-send-button {\\n font-size: 14px !important;\\n height: 36px !important; }\\n @media (min-width: 600px) {\\n .vpw-fullscreen [vw-plugin-wrapper].active {\\n align-items: center !important; }\\n .vpw-fullscreen [vp] {\\n max-width: 600px; }\\n .vpw-fullscreen [vp] [vp-box],\\n .vpw-fullscreen [vp] .vpw-message-box {\\n border-radius: 0 0 10px 10px !important; }\\n .vpw-fullscreen [vp] [vp-controls] {\\n border-radius: 10px 10px 0 0 !important;\\n border: none !important; }\\n .vpw-fullscreen [vp] .vpw-logo-group {\\n justify-content: left !important;\\n -webkit-justify-content: left !important;\\n gap: 40px; }\\n .vpw-fullscreen [vp] .vpw-recents-container {\\n height: 75% !important; } }\\n\\n[vp] [vp-controls] {\\n position: absolute;\\n left: 50%;\\n border-top: 1px solid #D8D9DB;\\n transform: translateX(-50%);\\n bottom: 0%;\\n z-index: 5; }\\n @media (max-width: 450px) {\\n [vp] [vp-controls] {\\n gap: 0 !important;\\n padding: 0 10px !important; } }\\n\\n[vp] .vpw-controls {\\n display: flex;\\n flex-direction: row;\\n justify-content: space-between;\\n align-items: center;\\n width: calc(100% - 10px);\\n height: 48px;\\n padding: 8px 15px;\\n flex-direction: row;\\n gap: 10px;\\n background-size: 100% 100%;\\n background: white;\\n width: 100%; }\\n [vp] .vpw-controls.vpw-selectText {\\n background-color: #003F86 !important; }\\n [vp] .vpw-controls .vpw-selectTextLabel {\\n display: none;\\n align-items: center;\\n justify-content: center;\\n width: 100%;\\n height: 100%;\\n color: #FFFFFF;\\n text-align: center;\\n font-size: 12px;\\n font-weight: bold; }\\n @media only screen and (max-width: 480px) {\\n [vp] .vpw-controls .vpw-selectTextLabel {\\n padding: 0 10px;\\n align-items: center;\\n justify-content: center; } }\\n [vp] .vpw-controls.vpw-selectText .vpw-selectTextLabel {\\n display: flex; }\\n [vp] .vpw-controls.vpw-selectText .vpw-controls-button,\\n [vp] .vpw-controls.vpw-selectText .vpw-controls-slider,\\n [vp] .vpw-controls.vpw-selectText .vpw-button-speed,\\n [vp] .vpw-controls.vpw-selectText .vpw-controls-subtitles,\\n [vp] .vpw-controls.vpw-selectText .vpw-controls-fullscreen {\\n display: none; }\\n [vp] .vpw-controls .vpw-controls-button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54; }\\n @media (max-width: 450px) {\\n [vp] .vpw-controls .vpw-controls-button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-controls .vpw-controls-button span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-controls .vpw-controls-button svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-controls .vpw-controls-button svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-controls .vpw-controls-button.speed-button {\\n width: 40px; }\\n [vp] .vpw-controls .vpw-controls-button:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-controls .vpw-controls-button:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] .vpw-controls .vpw-controls-button:activesvg > * {\\n fill: #0F2B54; }\\n [vp] .vpw-controls .vpw-controls-button:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] .vpw-controls .vpw-controls-button:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-controls .vpw-controls-button.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] .vpw-controls .vpw-controls-button.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] .vpw-controls .vpw-controls-button.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] .vpw-controls .vpw-controls-button .vpw-component-pause,\\n [vp] .vpw-controls .vpw-controls-button .vpw-component-restart {\\n display: none; }\\n [vp] .vpw-controls.vpw-playing .vpw-controls-button .vpw-component-play,\\n [vp] .vpw-controls.vpw-playing .vpw-controls-button .vpw-component-restart {\\n display: none; }\\n [vp] .vpw-controls.vpw-playing .vpw-controls-button .vpw-component-pause {\\n display: flex; }\\n [vp] .vpw-controls.vpw-stopped .vpw-controls-button .vpw-component-play,\\n [vp] .vpw-controls.vpw-stopped .vpw-controls-button .vpw-component-pause {\\n display: none; }\\n [vp] .vpw-controls.vpw-stopped .vpw-controls-button .vpw-component-restart {\\n display: flex; }\\n [vp] .vpw-controls .vpw-controls-subtitles,\\n [vp] .vpw-controls .vpw-controls-fullscreen {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54; }\\n @media (max-width: 450px) {\\n [vp] .vpw-controls .vpw-controls-subtitles,\\n [vp] .vpw-controls .vpw-controls-fullscreen {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-controls .vpw-controls-subtitles span,\\n [vp] .vpw-controls .vpw-controls-fullscreen span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-controls .vpw-controls-subtitles svg,\\n [vp] .vpw-controls .vpw-controls-fullscreen svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-controls .vpw-controls-subtitles svg *,\\n [vp] .vpw-controls .vpw-controls-fullscreen svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-controls .vpw-controls-subtitles.speed-button,\\n [vp] .vpw-controls .vpw-controls-fullscreen.speed-button {\\n width: 40px; }\\n [vp] .vpw-controls .vpw-controls-subtitles:hover,\\n [vp] .vpw-controls .vpw-controls-fullscreen:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-controls .vpw-controls-subtitles:active,\\n [vp] .vpw-controls .vpw-controls-fullscreen:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] .vpw-controls .vpw-controls-subtitles:activesvg > *,\\n [vp] .vpw-controls .vpw-controls-fullscreen:activesvg > * {\\n fill: #0F2B54; }\\n [vp] .vpw-controls .vpw-controls-subtitles:focus,\\n [vp] .vpw-controls .vpw-controls-fullscreen:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] .vpw-controls .vpw-controls-subtitles:disabled,\\n [vp] .vpw-controls .vpw-controls-fullscreen:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-controls .vpw-controls-subtitles.actived-subtitle,\\n [vp] .vpw-controls .vpw-controls-fullscreen.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] .vpw-controls .vpw-controls-subtitles.actived-subtitle:hover,\\n [vp] .vpw-controls .vpw-controls-fullscreen.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] .vpw-controls .vpw-controls-subtitles.actived-subtitle svg > *,\\n [vp] .vpw-controls .vpw-controls-fullscreen.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] .vpw-controls .vpw-controls-fullscreen {\\n display: flex; }\\n\\n@-webkit-keyframes spin {\\n 0% {\\n -webkit-transform: rotate(0deg);\\n /* Chrome, Opera 15+, Safari 3.1+ */\\n -ms-transform: rotate(0deg);\\n /* IE 9 */\\n transform: rotate(0deg);\\n /* Firefox 16+, IE 10+, Opera */ }\\n 100% {\\n -webkit-transform: rotate(360deg);\\n /* Chrome, Opera 15+, Safari 3.1+ */\\n -ms-transform: rotate(360deg);\\n /* IE 9 */\\n transform: rotate(360deg);\\n /* Firefox 16+, IE 10+, Opera */ } }\\n\\n@keyframes spin {\\n 0% {\\n -webkit-transform: rotate(0deg);\\n /* Chrome, Opera 15+, Safari 3.1+ */\\n -ms-transform: rotate(0deg);\\n /* IE 9 */\\n transform: rotate(0deg);\\n /* Firefox 16+, IE 10+, Opera */ }\\n 100% {\\n -webkit-transform: rotate(360deg);\\n /* Chrome, Opera 15+, Safari 3.1+ */\\n -ms-transform: rotate(360deg);\\n /* IE 9 */\\n transform: rotate(360deg);\\n /* Firefox 16+, IE 10+, Opera */ } }\\n\\n[vp] .vpw-button-speed {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54;\\n width: 40px;\\n min-width: 40px;\\n font-weight: bold; }\\n @media (max-width: 450px) {\\n [vp] .vpw-button-speed {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-button-speed span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-button-speed svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-button-speed svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-button-speed.speed-button {\\n width: 40px; }\\n [vp] .vpw-button-speed:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-button-speed:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] .vpw-button-speed:activesvg > * {\\n fill: #0F2B54; }\\n [vp] .vpw-button-speed:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] .vpw-button-speed:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-button-speed.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] .vpw-button-speed.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] .vpw-button-speed.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n @media (max-width: 450px) {\\n [vp] .vpw-button-speed {\\n min-width: 34px;\\n max-width: 28px; } }\\n\\n[vp] .vpw-controls-slider {\\n appearance: none;\\n -webkit-appearance: none;\\n width: 100%;\\n border-radius: 10px;\\n overflow: hidden;\\n height: 5px;\\n background-color: transparent; }\\n [vp] .vpw-controls-slider .vpw-slider {\\n width: 100%;\\n height: 5px; }\\n [vp] .vpw-controls-slider .vpw-slider.noUi-target {\\n box-shadow: none;\\n border: 0; }\\n [vp] .vpw-controls-slider .vpw-slider.noUi-connect {\\n background-color: #003F86; }\\n [vp] .vpw-controls-slider .vpw-slider .noUi-background {\\n background-color: #B8B8B8;\\n box-shadow: none; }\\n [vp] .vpw-controls-slider .vpw-slider .noUi-origin {\\n border-radius: 1px; }\\n [vp] .vpw-controls-slider .vpw-slider .noUi-handle {\\n width: 0px;\\n height: 0px;\\n left: -8px;\\n top: -8px;\\n border-radius: 50%; }\\n [vp] .vpw-controls-slider .vpw-slider .noUi-handle:after,\\n [vp] .vpw-controls-slider .vpw-slider .noUi-handle:before {\\n display: none; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Controls/controls.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Dictionary/dictionary.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-dictionary {\\n display: none;\\n position: absolute;\\n top: 40px;\\n width: 100%;\\n height: calc(100% - 40px);\\n font-family: \'Rawline\', sans-serif;\\n background-color: white;\\n z-index: 6; }\\n [vp] .vpw-dictionary.active {\\n display: block; }\\n [vp] .vpw-dictionary .vpw-panel {\\n position: relative;\\n height: 100px;\\n background-color: white; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar {\\n height: 45px;\\n top: 0;\\n left: 0;\\n right: 0;\\n padding-left: 15px;\\n border-bottom: 1px solid #DDD;\\n display: flex;\\n align-items: center; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar {\\n height: 36px; } }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close.speed-button {\\n width: 40px; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close:activesvg > * {\\n fill: #0F2B54; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-btn-close svg * {\\n fill: #0D459D; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-title {\\n font-size: 16px;\\n font-weight: 600;\\n margin-left: 5px;\\n margin-bottom: 1px;\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .vpw-panel .vpw-bar .vpw-title {\\n font-size: 14px; } }\\n [vp] .vpw-dictionary .vpw-panel .vpw-search {\\n width: 100%;\\n padding: 0 10px; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-search input {\\n width: 100%;\\n height: 36px;\\n left: 33%;\\n font-size: 14px;\\n padding: 10px 10px 10px 10px;\\n margin-top: 10px;\\n border-radius: 5px;\\n border: 1px solid #DDD;\\n outline: none; }\\n [vp] .vpw-dictionary .vpw-panel .vpw-search input:focus {\\n border: 1px solid #003f86;\\n box-shadow: 0px 0px 15px rgba(86, 154, 255, 0.75); }\\n [vp] .vpw-dictionary .vpw-panel .vpw-search .vpw-icon {\\n display: flex;\\n position: absolute;\\n top: 57px;\\n right: 11px;\\n width: 32px;\\n height: 32px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .vpw-panel .vpw-search .vpw-icon {\\n top: 50px; } }\\n [vp] .vpw-dictionary .vpw-panel .vpw-search .vpw-icon svg > * {\\n fill: #363636; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .vpw-panel {\\n height: 91px; } }\\n [vp] .vpw-dictionary .buttons-container {\\n display: flex;\\n align-items: center;\\n flex-direction: row;\\n justify-content: start;\\n width: 100%;\\n border-top: 1px solid #DDD;\\n padding-top: 10px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .buttons-container {\\n height: 25px;\\n padding: 30px 0px 13px; } }\\n [vp] .vpw-dictionary .buttons-container button {\\n background: #FDFDFD;\\n outline: none;\\n height: 32px;\\n border: 1px solid #D8D9DB;\\n border-radius: 50px;\\n margin-left: 10px;\\n margin-bottom: 10px;\\n color: #838890;\\n padding: 0 16px;\\n font-size: 14px;\\n font-weight: 600;\\n cursor: pointer; }\\n [vp] .vpw-dictionary .buttons-container button:hover {\\n border: 1px solid #2470E0; }\\n [vp] .vpw-dictionary .buttons-container button.vp-selected {\\n background: #DDEBFF;\\n color: #2470E0;\\n border-color: #2470E0; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .buttons-container button {\\n height: 30px;\\n font-size: 12px; } }\\n [vp] .vpw-dictionary .vpw-dict-container,\\n [vp] .vpw-dictionary .vpw-recents-container {\\n visibility: hidden;\\n position: absolute;\\n width: 100%;\\n height: 70%;\\n left: 50%;\\n font-size: 18px;\\n transform: translateX(-50%); }\\n [vp] .vpw-dictionary .vpw-dict-container.enabled,\\n [vp] .vpw-dictionary .vpw-recents-container.enabled {\\n visibility: visible; }\\n [vp] .vpw-dictionary .vpw-dict-container ul,\\n [vp] .vpw-dictionary .vpw-recents-container ul {\\n height: 100%;\\n margin: 0;\\n padding: 0;\\n text-align: left;\\n overflow-y: scroll;\\n list-style-type: none; }\\n [vp] .vpw-dictionary .vpw-dict-container ul::-webkit-scrollbar,\\n [vp] .vpw-dictionary .vpw-recents-container ul::-webkit-scrollbar {\\n width: 8px; }\\n [vp] .vpw-dictionary .vpw-dict-container ul::-webkit-scrollbar-track,\\n [vp] .vpw-dictionary .vpw-recents-container ul::-webkit-scrollbar-track {\\n background-color: #DDD; }\\n [vp] .vpw-dictionary .vpw-dict-container ul::-webkit-scrollbar-thumb,\\n [vp] .vpw-dictionary .vpw-recents-container ul::-webkit-scrollbar-thumb {\\n background-color: #BCBCBC; }\\n [vp] .vpw-dictionary .vpw-dict-container ul li,\\n [vp] .vpw-dictionary .vpw-recents-container ul li {\\n font-size: 14px;\\n cursor: pointer; }\\n [vp] .vpw-dictionary .vpw-dict-container ul li:hover,\\n [vp] .vpw-dictionary .vpw-recents-container ul li:hover {\\n background-color: #EAEAEA;\\n -webkit-transition: brackground-color 0.3s;\\n transition: brackground-color 0.4s; }\\n [vp] .vpw-dictionary .vpw-dict-container ul li.margin,\\n [vp] .vpw-dictionary .vpw-recents-container ul li.margin {\\n height: 114px; }\\n [vp] .vpw-dictionary .vpw-dict-container ul li:not(.margin),\\n [vp] .vpw-dictionary .vpw-recents-container ul li:not(.margin) {\\n padding: 9px 10px 9px 10px; }\\n [vp] .vpw-dictionary .vpw-dict-container ul span,\\n [vp] .vpw-dictionary .vpw-recents-container ul span {\\n color: #999;\\n padding: 9px 10px 9px 10px; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary {\\n display: grid;\\n place-content: center;\\n width: 100%;\\n height: 100%;\\n position: absolute;\\n top: 0;\\n left: 0;\\n background-color: #FDFDFD;\\n z-index: 10; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary div {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-direction: column; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary div .vpw-loading__img {\\n width: 40px;\\n height: 40px;\\n animation: loading 1s infinite; }\\n\\n@keyframes loading {\\n to {\\n transform: rotate(0deg); }\\n from {\\n transform: rotate(-360deg); } }\\n [vp] .vpw-dictionary .vpw-loading-dictionary div span {\\n font-size: 14px;\\n font-weight: 700;\\n color: #0F2B54;\\n text-align: center; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary div .vpw-dict-msg--error {\\n display: none; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary div button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n height: 36px;\\n border-radius: 40px;\\n border: 1px solid #0D459D;\\n font-size: 14px;\\n font-weight: 600;\\n background-color: #FDFDFD;\\n color: #0D459D;\\n margin-top: 10px;\\n font-size: 12px;\\n max-height: 32px;\\n padding: 0 10px;\\n display: none; }\\n @media (max-width: 450px) {\\n [vp] .vpw-dictionary .vpw-loading-dictionary div button {\\n height: 28px;\\n font-size: 12px; } }\\n [vp] .vpw-dictionary .vpw-loading-dictionary div button:hover {\\n border-color: #838890;\\n background-color: #E8E9EA;\\n color: #0F2B54; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary div button:disabled {\\n background-color: #E8E9EA;\\n border-color: #D8D9DB;\\n cursor: not-allowed;\\n user-select: none;\\n color: #838890; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary.vpw-dict--error div img {\\n display: none; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary.vpw-dict--error div .vpw-dict-msg--loading {\\n display: none; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary.vpw-dict--error div .vpw-dict-msg--error {\\n display: inline; }\\n [vp] .vpw-dictionary .vpw-loading-dictionary.vpw-dict--error div button {\\n display: grid; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Dictionary/dictionary.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/InfoScreen/info-screen.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-info-screen {\\n position: absolute;\\n top: 40px;\\n padding: 1em;\\n width: 100%;\\n height: calc(100% - 40px);\\n z-index: 6;\\n background-color: white;\\n color: black;\\n font-family: \\"Rawline\\", sans-serif;\\n font-size: .14rem;\\n align-items: center;\\n -webkit-align-items: center;\\n font-size: 14px;\\n display: none;\\n -webkit-box-sizing: border-box;\\n -moz-box-sizing: border-box;\\n box-sizing: border-box; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen {\\n max-width: 210px; } }\\n [vp] .vpw-info-screen.active {\\n display: -webkit-flex;\\n display: flex; }\\n [vp] .vpw-info-screen .vpw-info-header {\\n position: absolute;\\n width: 100%;\\n height: 48px;\\n top: 0;\\n left: 0;\\n right: 0;\\n padding-left: 15px;\\n display: flex;\\n align-items: center;\\n border-bottom: 1px solid #DDD;\\n z-index: 1;\\n gap: 10px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen .vpw-info-header {\\n height: 36px; } }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button.speed-button {\\n width: 40px; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button:activesvg > * {\\n fill: #0F2B54; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] .vpw-info-screen .vpw-info-header .vpw-back-button svg * {\\n fill: #0D459D; }\\n [vp] .vpw-info-screen .vpw-info-header .text-black-header {\\n font-size: 16px;\\n color: #363636;\\n font-weight: 600; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen .vpw-info-header .text-black-header {\\n font-size: 14px; } }\\n [vp] .vpw-info-screen #vpw-info-main {\\n position: relative;\\n top: 0;\\n flex-grow: 4;\\n display: -webkit-flex;\\n display: flex;\\n flex-direction: column;\\n -webkit-flex-direction: column;\\n padding: 0;\\n height: 100%;\\n width: 100%;\\n align-items: center;\\n -webkit-align-items: center; }\\n [vp] .vpw-info-screen #vpw-text-svl p {\\n font-size: 14px;\\n margin-bottom: 10px; }\\n [vp] .vpw-info-screen .text-black {\\n text-decoration: none;\\n font-weight: 600;\\n font-size: 14px;\\n margin-bottom: 10px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen .text-black {\\n font-size: 12px; } }\\n [vp] .vpw-info-screen .format-text {\\n margin: 0px;\\n color: #555;\\n font-style: normal;\\n font-weight: 500;\\n font-size: 14px;\\n line-height: 19px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen .format-text {\\n font-size: 11px !important;\\n line-height: 15px; } }\\n [vp] .vpw-info-screen #vpw-info-main {\\n height: 100%;\\n width: 100%;\\n margin-top: 100px;\\n flex-direction: column;\\n align-items: stretch;\\n -webkit-flex-direction: column;\\n -webkit-align-items: stretch; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen #vpw-info-main {\\n margin-top: 50px; } }\\n [vp] .vpw-info-screen #vpw-info-main .vpw-info-realizadores {\\n flex-direction: column;\\n align-items: stretch;\\n -webkit-flex-direction: column;\\n -webkit-align-items: stretch; }\\n [vp] .vpw-info-screen #vpw-info-main.active {\\n display: flex;\\n align-content: center;\\n justify-content: center;\\n align-items: center;\\n gap: 10px; }\\n [vp] .vpw-info-screen #vpw-info-main .vpw-logo {\\n margin-top: -2px;\\n margin: 0.5em 0.35em;\\n max-width: 50%; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen #vpw-info-main .vpw-logo {\\n max-height: 25px; } }\\n [vp] .vpw-info-screen #vpw-info-main .vpw-logo-group {\\n display: flex;\\n flex-direction: row;\\n flex-wrap: nowrap;\\n align-items: center;\\n justify-content: space-around;\\n -webkit-flex-direction: row;\\n -webkit-flex-wrap: nowrap;\\n -webkit-align-items: center;\\n -webkit-justify-content: space-around; }\\n [vp] .vpw-info-screen .vpw-logo-networks {\\n display: flex;\\n align-items: center;\\n flex-direction: row;\\n gap: 10px; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54;\\n outline: 1px solid #D8D9DB;\\n border-radius: 4px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks.speed-button {\\n width: 40px; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks:activesvg > * {\\n fill: #0F2B54; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] .vpw-info-screen .vpw-logo-networks .vpw-networks.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] .vpw-info-screen .vpw-close-btn {\\n position: absolute;\\n top: 8px;\\n right: 6px;\\n z-index: 4; }\\n [vp] .vpw-info-screen .vpw-close-btn img.icon {\\n width: 34px;\\n height: 34px; }\\n [vp] .vpw-info-screen #vpw-info-footer {\\n margin-top: 20px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-info-screen #vpw-info-footer {\\n margin-top: 1px; } }\\n\\n@media only screen and (-moz-min-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2 / 1), only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2) {\\n [vp] #vpw-info-realizadores .vpw-logo {\\n margin: 0.5em 0.35em;\\n min-width: 10%;\\n max-width: 50%;\\n max-height: 18vh; } }\\n\\n@media only screen and (max-height: 450px) {\\n [vp] #vpw-info-main {\\n font-size: 0.84em; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/InfoScreen/info-screen.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/MessageBox/message-box.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-message-box {\\n top: -100px;\\n left: 0;\\n position: absolute;\\n width: 100%;\\n padding: 10px;\\n font-size: 13px;\\n word-wrap: break-word;\\n color: #000;\\n min-height: 40px;\\n opacity: 0;\\n overflow: hidden;\\n -moz-transition: all .15s ease .15s;\\n -webkit-transition: all .15s ease .15s;\\n transition: all .15s ease .15s;\\n text-align: center;\\n font-weight: 700; }\\n [vp] .vpw-message-box.active {\\n top: 0;\\n opacity: 1;\\n z-index: 10; }\\n [vp] .vpw-message-box.info {\\n background-color: #0D459D;\\n color: white; }\\n [vp] .vpw-message-box.warning {\\n background-color: #0D459D;\\n color: white; }\\n [vp] .vpw-message-box.success {\\n background-color: #0D459D;\\n color: white; }\\n [vp] .vpw-message-box.default {\\n background-color: #0D459D;\\n color: white; }\\n [vp] .vpw-message-box a {\\n color: inherit; }\\n @media (max-width: 450px) {\\n [vp] .vpw-message-box {\\n font-size: 12px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/MessageBox/message-box.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/RateBox/rate-box.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] [vp-rate-box] {\\n position: absolute;\\n width: 100%;\\n height: 0;\\n bottom: 0;\\n padding-bottom: 0;\\n z-index: 3;\\n visibility: hidden;\\n transition: height .5s;\\n background-color: #FDFDFD;\\n border-radius: 10px 10px 0 0;\\n overflow: hidden; }\\n [vp] [vp-rate-box] .vp-rate-box-header {\\n width: 100%;\\n height: 48px;\\n border-bottom: 1px solid #D8D9DB;\\n display: flex;\\n padding: 16px;\\n align-items: center;\\n justify-content: space-between; }\\n [vp] [vp-rate-box] .vp-rate-box-header span {\\n font-size: 14px;\\n font-weight: 600; }\\n [vp] [vp-rate-box] .vp-rate-box-header button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54;\\n transition: transform .3s; }\\n @media (max-width: 450px) {\\n [vp] [vp-rate-box] .vp-rate-box-header button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] [vp-rate-box] .vp-rate-box-header button span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] [vp-rate-box] .vp-rate-box-header button svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] [vp-rate-box] .vp-rate-box-header button svg * {\\n fill: #0F2B54; }\\n [vp] [vp-rate-box] .vp-rate-box-header button.speed-button {\\n width: 40px; }\\n [vp] [vp-rate-box] .vp-rate-box-header button:hover {\\n background-color: #E8E9EA; }\\n [vp] [vp-rate-box] .vp-rate-box-header button:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] [vp-rate-box] .vp-rate-box-header button:activesvg > * {\\n fill: #0F2B54; }\\n [vp] [vp-rate-box] .vp-rate-box-header button:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] [vp-rate-box] .vp-rate-box-header button:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] [vp-rate-box] .vp-rate-box-header button.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] [vp-rate-box] .vp-rate-box-header button.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] [vp-rate-box] .vp-rate-box-header button.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] [vp-rate-box] .vp-rate-box-header button svg > * {\\n fill: #0F2B54; }\\n [vp] [vp-rate-box] .vp-rate-box-header button.vp-expanded svg {\\n transform: rotate(180deg); }\\n [vp] [vp-rate-box] .vp-rate-box-content {\\n width: 100%;\\n position: relative;\\n height: calc(100% - 96px);\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-direction: column;\\n gap: 16px;\\n padding: 10px;\\n overflow: hidden; }\\n [vp] [vp-rate-box] .vp-rate-box-content span {\\n font-size: 16px;\\n font-weight: 600;\\n color: #363636; }\\n [vp] [vp-rate-box] .vp-rate-btns {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n gap: 10px; }\\n [vp] [vp-rate-box] .vp-rate-btns button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n gap: 6px;\\n flex-direction: column;\\n padding: 40px 12px 12px 12px;\\n border-radius: 4px;\\n color: #838890;\\n position: relative;\\n font-size: 12px;\\n font-weight: 500;\\n height: 70px !important;\\n background-color: #FDFDFD;\\n outline: 2px solid transparent;\\n outline-offset: -2px; }\\n [vp] [vp-rate-box] .vp-rate-btns button svg {\\n width: 24px;\\n position: absolute;\\n top: 12px; }\\n [vp] [vp-rate-box] .vp-rate-btns button svg * {\\n fill: #838890; }\\n [vp] [vp-rate-box] .vp-rate-btns button:hover {\\n background-color: #E8E9EA; }\\n [vp] [vp-rate-box] .vp-rate-btns button:active {\\n outline-color: #3885F9;\\n box-shadow: 0px 0px 15px rgba(86, 154, 255, 0.75); }\\n [vp] [vp-rate-box] .vp-rate-btns button svg {\\n width: 24px; }\\n [vp] [vp-rate-box] .vp-rate-btns button.vp-rate-btns--deslike svg {\\n transform: scaleY(-1); }\\n [vp] [vp-rate-box] .vp-rate-btns button :nth-child(1) * {\\n fill: #838890; }\\n [vp] [vp-rate-box] .vp-rate-btns button :nth-child(2) {\\n visibility: hidden; }\\n [vp] [vp-rate-box] .vp-rate-btns button :nth-child(2) * {\\n fill: #0D459D; }\\n [vp] [vp-rate-box] .vp-rate-btns button:hover :nth-child(1), [vp] [vp-rate-box] .vp-rate-btns button:focus :nth-child(1) {\\n width: 0; }\\n [vp] [vp-rate-box] .vp-rate-btns button:hover :nth-child(2), [vp] [vp-rate-box] .vp-rate-btns button:focus :nth-child(2) {\\n visibility: visible; }\\n [vp] [vp-rate-box].vp-enabled {\\n visibility: visible;\\n height: 96px; }\\n [vp] [vp-rate-box].vp-expanded {\\n height: 60% !important; }\\n [vp] [vp-rate-box].vp-expanded .vp-rate-box-header button svg {\\n transform: rotate(180deg); }\\n @media (max-width: 450px) {\\n [vp] [vp-rate-box].vp-enabled {\\n visibility: visible;\\n height: 86px; }\\n [vp] [vp-rate-box] .vp-rate-box-header {\\n height: 38px; }\\n [vp] [vp-rate-box] .vp-rate-box-content {\\n height: calc(100% - 86px); }\\n [vp] [vp-rate-box] .vp-rate-box-content span {\\n font-size: 12px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/RateBox/rate-box.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Settings/regionalism.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-regions-container {\\n overflow-y: scroll;\\n height: calc(100% - 48px);\\n display: none;\\n align-items: center;\\n flex-direction: column;\\n justify-content: start;\\n padding-bottom: 10px;\\n gap: 4px;\\n position: relative;\\n padding-top: 40px;\\n width: 100%;\\n position: absolute;\\n top: 48px;\\n background-color: #FDFDFD;\\n z-index: 10; }\\n [vp] .vpw-regions-container .vpw-region {\\n display: flex;\\n align-items: center;\\n justify-content: start;\\n gap: 10px;\\n flex-direction: row;\\n width: 100%;\\n padding: 0 16px;\\n cursor: pointer;\\n height: 40px;\\n min-height: 40px;\\n position: relative; }\\n [vp] .vpw-regions-container .vpw-region:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-regions-container .vpw-region img {\\n border-radius: 4px;\\n height: 28px; }\\n [vp] .vpw-regions-container .vpw-region span {\\n font-size: 14px;\\n font-weight: 600;\\n color: #0F2B54; }\\n [vp] .vpw-regions-container .vpw-region .vpw-radio {\\n position: absolute;\\n width: 18px;\\n height: 18px;\\n border-radius: 18px;\\n outline: 1px solid #838890;\\n outline-offset: -1px;\\n right: 16px;\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-regions-container .vpw-region .vpw-radio::after {\\n border-radius: 10px;\\n position: absolute;\\n content: \\"\\";\\n width: 10px;\\n height: 10px;\\n background-color: #3885F9;\\n visibility: hidden; }\\n [vp] .vpw-regions-container .vpw-region.selected {\\n position: absolute;\\n top: 0; }\\n [vp] .vpw-regions-container .vpw-region.selected .vpw-radio {\\n outline-color: #3885F9;\\n outline-width: 2px; }\\n [vp] .vpw-regions-container .vpw-region.selected .vpw-radio::after {\\n visibility: visible; }\\n [vp] .vpw-regions-container.active {\\n display: flex; }\\n\\n@media (max-width: 450px) {\\n [vp] .vpw-regions-container {\\n padding-top: 28px !important;\\n top: 36px;\\n height: calc(100% - 36px); }\\n [vp] .vpw-region {\\n height: 28px !important;\\n min-height: 28px !important;\\n padding: 0 10px !important; }\\n [vp] .vpw-region img {\\n height: 20px !important; }\\n [vp] .vpw-region span {\\n font-size: 10px !important; }\\n [vp] .vpw-region .vpw-radio {\\n width: 14px !important;\\n height: 14px !important; }\\n [vp] .vpw-region .vpw-radio::after {\\n width: 8px !important;\\n height: 8px !important; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/regionalism.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Settings/settings.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-settings {\\n position: absolute;\\n top: 40px;\\n width: 100%;\\n height: calc(100% - 40px);\\n z-index: 10;\\n display: none;\\n border-radius: 0 0 10px 10px;\\n overflow: hidden; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings {\\n max-width: 210px; } }\\n [vp] .vpw-settings.active {\\n display: block; }\\n [vp] .vpw-settings .vpw-screen-header {\\n width: 100%;\\n background-color: #FDFDFD;\\n padding: 0 16px;\\n height: 48px;\\n display: flex;\\n align-items: center;\\n justify-content: start;\\n gap: 10px;\\n border-bottom: 1px solid #D8D9DB; }\\n [vp] .vpw-settings .vpw-screen-header button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings .vpw-screen-header button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-settings .vpw-screen-header button span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-settings .vpw-screen-header button svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-settings .vpw-screen-header button svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-settings .vpw-screen-header button.speed-button {\\n width: 40px; }\\n [vp] .vpw-settings .vpw-screen-header button:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-settings .vpw-screen-header button:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] .vpw-settings .vpw-screen-header button:activesvg > * {\\n fill: #0F2B54; }\\n [vp] .vpw-settings .vpw-screen-header button:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] .vpw-settings .vpw-screen-header button:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-settings .vpw-screen-header button.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] .vpw-settings .vpw-screen-header button.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] .vpw-settings .vpw-screen-header button.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] .vpw-settings .vpw-screen-header button svg * {\\n fill: #0F2B54; }\\n [vp] .vpw-settings .vpw-screen-header span {\\n font-weight: 600;\\n color: #363636;\\n font-size: 16px; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings .vpw-screen-header {\\n height: 36px !important;\\n padding: 0 10px; }\\n [vp] .vpw-settings .vpw-screen-header span {\\n font-size: 14px !important; } }\\n [vp] .vpw-settings .vpw-settings-content {\\n display: flex;\\n flex-direction: column;\\n justify-content: start;\\n width: 100%;\\n height: 100%;\\n position: relative;\\n background-color: #FDFDFD; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings .vpw-settings-content {\\n height: auto; } }\\n [vp] .vpw-settings .vpw-options-container {\\n width: 100%;\\n display: flex;\\n flex-direction: column;\\n gap: 16px;\\n padding: 16px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content {\\n color: #363636;\\n font-size: 14px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content:first-child > div {\\n display: flex !important; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content p {\\n font-weight: bold;\\n margin-bottom: 16px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div {\\n display: block;\\n flex-direction: row;\\n justify-content: space-between;\\n align-items: center;\\n position: relative; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div span {\\n font-weight: normal; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div .vpw-selected-region {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-direction: row;\\n padding: 4px;\\n border-radius: 4px;\\n position: absolute;\\n right: 0;\\n cursor: pointer; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div .vpw-selected-region img {\\n height: 26px;\\n border-radius: 4px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div .vpw-selected-region span {\\n font-weight: bold;\\n color: #0F2B54;\\n font-size: 16px;\\n margin: 0 6px;\\n line-height: 0; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div .vpw-selected-region:hover {\\n background-color: #E8E9EA; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div .vpw-selected-region img {\\n height: 22px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content div .vpw-selected-region span {\\n font-size: 14px; } }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box {\\n width: 128px;\\n height: 114px;\\n margin-top: 16px;\\n gap: 16px;\\n outline: 1px solid #D8D9DB;\\n display: grid;\\n grid-template-columns: 24px 24px 24px;\\n grid-template-rows: 24px 24px 24px;\\n padding: 6px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span {\\n width: 24px;\\n height: 24px;\\n cursor: pointer;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n position: relative; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span svg {\\n visibility: hidden;\\n position: absolute; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span::after {\\n content: \'\';\\n position: absolute;\\n width: 4px;\\n height: 4px;\\n background-color: #838890;\\n opacity: .5;\\n display: block; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span:hover {\\n background-color: #E8E9EA; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span.vpw-select-pos {\\n cursor: default; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span.vpw-select-pos::after {\\n display: none; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span.vpw-select-pos:hover {\\n background-color: transparent; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box span.vpw-select-pos svg {\\n visibility: visible; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-position-box {\\n width: 114px;\\n height: 88px;\\n gap: 2px;\\n padding: 6px; } }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-info {\\n display: flex;\\n flex-direction: row;\\n justify-content: space-between; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range {\\n position: relative;\\n height: 30px;\\n width: 100%;\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range input[type=\\"range\\"] {\\n cursor: pointer;\\n appearance: none;\\n -moz-appearance: none;\\n -webkit-appearance: none;\\n width: 100%;\\n height: 6px;\\n margin: 10px 0;\\n background: transparent !important;\\n border-radius: 10px;\\n margin: 10px 0;\\n z-index: 3;\\n position: absolute; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range input[type=\\"range\\"]::-webkit-slider-thumb {\\n appearance: none;\\n -moz-appearance: none;\\n -webkit-appearance: none;\\n background-color: #FDFDFD !important;\\n border: 3px solid #2470E0 !important;\\n width: 18px !important;\\n height: 18px !important;\\n border-radius: 16px;\\n margin-bottom: 4px;\\n box-sizing: border-box !important; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range input[type=\\"range\\"]::-ms-thumb {\\n appearance: none;\\n -moz-appearance: none;\\n -webkit-appearance: none;\\n background-color: #FDFDFD !important;\\n border: 3px solid #2470E0 !important;\\n width: 18px !important;\\n height: 18px !important;\\n border-radius: 16px;\\n margin-bottom: 4px;\\n box-sizing: border-box !important; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range input[type=\\"range\\"]::-moz-range-thumb {\\n appearance: none;\\n -moz-appearance: none;\\n -webkit-appearance: none;\\n background-color: #FDFDFD !important;\\n border: 3px solid #2470E0 !important;\\n width: 18px !important;\\n height: 18px !important;\\n border-radius: 16px;\\n margin-bottom: 4px;\\n box-sizing: border-box !important; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range vpw-slider,\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range span {\\n position: absolute;\\n top: 0;\\n margin-top: 10px;\\n height: 6px;\\n left: 0;\\n border-radius: 10px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range vpw-slider {\\n background-color: #2470E0;\\n z-index: 2;\\n width: 100%; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content .vpw-opacity-range span {\\n background-color: #D8D9DB;\\n width: 100%;\\n z-index: 1; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings .vpw-options-container {\\n padding: 10px;\\n gap: 10px; }\\n [vp] .vpw-settings .vpw-options-container .vpw-option-content {\\n font-size: 12px; } }\\n [vp] .vpw-settings.active {\\n visibility: visible; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/settings.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Settings/switch.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] {\\n /* Hide default HTML checkbox */\\n /* The slider */\\n /* Rounded sliders */ }\\n [vp] .vpw-switch {\\n position: relative;\\n display: inline-block;\\n width: 60px;\\n height: 21px;\\n float: right;\\n margin-top: -12px; }\\n [vp] .vpw-switch input {\\n opacity: 0;\\n width: 0;\\n height: 0; }\\n [vp] .vpw-slider-check {\\n position: absolute;\\n cursor: pointer;\\n top: 0;\\n left: 0;\\n right: 0;\\n bottom: 0;\\n background-color: #2196F3; }\\n [vp] .vpw-slider-check:before {\\n position: absolute;\\n content: \\"\\";\\n height: 26px;\\n width: 26px;\\n left: 4px;\\n bottom: 4px;\\n background-color: white; }\\n [vp] input:checked + .vpw-slider-check {\\n background-color: #2196F3; }\\n [vp] input:focus + .vpw-slider-check {\\n box-shadow: 0 0 1px #ccc; }\\n [vp] input:checked + .vpw-slider-check:before {\\n -webkit-transform: translateX(26px);\\n -ms-transform: translateX(26px);\\n transform: translateX(26px); }\\n [vp] .vpw-slider-check.vpw-round {\\n border-radius: 34px; }\\n [vp] .vpw-slider-check.vpw-round:before {\\n border-radius: 50%;\\n top: -3px; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/switch.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/SettingsBtn/settings-btn.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-settings-btn {\\n position: absolute;\\n z-index: 1;\\n height: 100%;\\n width: 100%;\\n display: flex;\\n padding: 0 16px;\\n align-items: center;\\n flex-direction: row;\\n justify-content: space-between; }\\n [vp] .vpw-settings-btn div {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-direction: row;\\n gap: 10px; }\\n [vp] .vpw-settings-btn div button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #0D459D;\\n color: #FFFFFF; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings-btn div button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] .vpw-settings-btn div button span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] .vpw-settings-btn div button svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] .vpw-settings-btn div button svg * {\\n fill: #FFFFFF; }\\n [vp] .vpw-settings-btn div button:hover {\\n background-color: #2470E0; }\\n [vp] .vpw-settings-btn div button:active {\\n background-color: #0F2B54; }\\n [vp] .vpw-settings-btn div button:activesvg > * {\\n fill: #3885F9; }\\n [vp] .vpw-settings-btn div button:focus {\\n background-color: #2470E0;\\n outline-color: #FDFDFD;\\n box-shadow: 0 0 12px 0 #569aff; }\\n [vp] .vpw-settings-btn div button:disabled {\\n background-color: #838890;\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] .vpw-settings-btn div button.selected {\\n background-color: #2470E0; }\\n [vp] .vpw-settings-btn .vpw-container-dict {\\n position: absolute;\\n left: 0;\\n top: 0; }\\n @media (max-width: 450px) {\\n [vp] .vpw-settings-btn {\\n padding: 0 10px; }\\n [vp] .vpw-settings-btn div {\\n gap: 4px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsBtn/settings-btn.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/SettingsCloseBtn/settings-close-btn.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] .vpw-btn-close {\\n position: absolute;\\n top: 0;\\n width: 100%;\\n height: 100%;\\n display: none;\\n z-index: 7;\\n cursor: pointer; }\\n [vp] .vpw-btn-close.active {\\n display: block; }\\n [vp] .vpw-btn-close .vpw-img {\\n position: absolute;\\n top: 50%;\\n transform: translateY(-50%);\\n width: 37.92px;\\n height: 37.92px;\\n right: 5px; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsCloseBtn/settings-close-btn.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/SuggestionScreen/suggestion-screen.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vp] [vp-suggestion-screen] {\\n overflow: hidden;\\n position: absolute;\\n right: 0;\\n left: 0;\\n height: 0;\\n bottom: 0;\\n width: 100%;\\n padding: 0;\\n background-color: white;\\n z-index: 5;\\n border-radius: 10px 10px 0 0;\\n transition: all .3s ease;\\n /* Track */\\n /* Handle */\\n /* Handle on hover */ }\\n [vp] [vp-suggestion-screen] ::-webkit-scrollbar {\\n width: 10px; }\\n [vp] [vp-suggestion-screen] ::-webkit-scrollbar-track {\\n background: #d1d1d1f1 !important; }\\n [vp] [vp-suggestion-screen] ::-webkit-scrollbar-thumb {\\n background: #8b8b99; }\\n [vp] [vp-suggestion-screen] ::-webkit-scrollbar-thumb:hover {\\n background: #555; }\\n [vp] [vp-suggestion-screen] .vp-dropdown-suggest {\\n display: none; }\\n [vp] [vp-suggestion-screen] .vp-dropdown-suggest.vp-enabled {\\n display: block;\\n position: absolute;\\n width: 120px;\\n height: 54px;\\n overflow: hidden auto;\\n color: white;\\n background: #003f86;\\n border-radius: 5px;\\n font-weight: 600;\\n list-style-type: none;\\n padding: 0px; }\\n [vp] [vp-suggestion-screen] .vp-dropdown-item {\\n cursor: pointer;\\n font-size: 12px;\\n margin: 5px 0px -4px 6px;\\n color: #FFFFFF; }\\n [vp] [vp-suggestion-screen] .vp-dropdown-item:hover {\\n color: #80b6f3; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header {\\n width: 100%;\\n height: 48px;\\n border-bottom: 1px solid #D8D9DB;\\n display: flex;\\n padding: 16px;\\n align-items: center;\\n justify-content: space-between; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header span {\\n font-size: 14px;\\n font-weight: 600; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n font-size: 14px;\\n font-style: normal;\\n line-height: 19px;\\n font-weight: 700;\\n text-align: center;\\n min-width: 32px;\\n min-height: 32px;\\n max-width: 32px;\\n max-height: 32px;\\n border-radius: 4px;\\n outline: 2px solid transparent;\\n outline-offset: -2px;\\n position: relative;\\n background-color: #FDFDFD;\\n color: #0F2B54;\\n transition: transform .3s; }\\n @media (max-width: 450px) {\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button {\\n min-width: 28px;\\n min-height: 28px;\\n max-width: 28px;\\n max-height: 28px; } }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button span {\\n display: flex;\\n align-items: center;\\n justify-content: center; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button svg {\\n width: 100%;\\n height: 100%;\\n position: absolute; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button svg * {\\n fill: #0F2B54; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button.speed-button {\\n width: 40px; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button:hover {\\n background-color: #E8E9EA; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button:active {\\n background-color: map -get((1: #FDFDFD, 2: #838890, 4: #D8D9DB, 5: #E8E9EA), 1); }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button:activesvg > * {\\n fill: #0F2B54; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button:focus {\\n background-color: #FDFDFD;\\n outline-color: #3885F9; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button:disabled {\\n cursor: not-allowed;\\n opacity: 0.3; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button.actived-subtitle {\\n background-color: #2470E0; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button.actived-subtitle:hover {\\n background-color: #3885F9; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button.actived-subtitle svg > * {\\n fill: #FDFDFD; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header button svg > * {\\n fill: #0F2B54; }\\n @media (max-width: 450px) {\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-header {\\n height: 38px;\\n padding: 10px; } }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-direction: column;\\n gap: 10px;\\n width: 100%;\\n padding: 16px; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-title {\\n width: 100%;\\n text-align: left;\\n font-weight: 700;\\n font-size: 14px;\\n color: #363636; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-text {\\n padding: 10px;\\n width: 100%;\\n resize: none;\\n border-radius: 5px;\\n border: 1px solid #D8D9DB;\\n height: 120px;\\n font-size: 1rem;\\n outline: none !important;\\n display: block !important;\\n min-height: auto !important; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-text:hover {\\n border-color: #838890; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-text:focus {\\n border: 1.6px solid #3885F9;\\n box-shadow: 0px 0px 15px rgba(86, 154, 255, 0.75); }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container {\\n width: 100%;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n flex-direction: column;\\n gap: 10px; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container button {\\n width: 100% !important; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-visualize-signal-button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n height: 36px;\\n border-radius: 40px;\\n border: 1px solid #0D459D;\\n font-size: 14px;\\n font-weight: 600;\\n background-color: #0D459D;\\n color: #FDFDFD; }\\n @media (max-width: 450px) {\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-visualize-signal-button {\\n height: 28px;\\n font-size: 12px; } }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-visualize-signal-button:hover {\\n background-color: #3885F9;\\n border-color: #3885F9; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-visualize-signal-button:disabled {\\n background-color: #E8E9EA;\\n border-color: #D8D9DB;\\n cursor: not-allowed;\\n user-select: none;\\n color: #838890; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-send-button {\\n border: none;\\n margin: 0;\\n padding: 0;\\n width: auto;\\n cursor: pointer;\\n overflow: visible;\\n outline: none;\\n background: transparent;\\n color: inherit;\\n font: inherit;\\n /* Normalize `line-height`. Cannot be changed from `normal` in Firefox 4+. */\\n line-height: normal;\\n /* Corrects font smoothing for webkit */\\n -webkit-font-smoothing: inherit;\\n -moz-osx-font-smoothing: inherit;\\n /* Corrects inability to style clickable `input` types in iOS */\\n -webkit-appearance: none;\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n height: 36px;\\n border-radius: 40px;\\n border: 1px solid #0D459D;\\n font-size: 14px;\\n font-weight: 600;\\n background-color: #FDFDFD;\\n color: #0D459D; }\\n @media (max-width: 450px) {\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-send-button {\\n height: 28px;\\n font-size: 12px; } }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-send-button:hover {\\n border-color: #838890;\\n background-color: #E8E9EA;\\n color: #0F2B54; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container .vp-send-button:disabled {\\n background-color: #E8E9EA;\\n border-color: #D8D9DB;\\n cursor: not-allowed;\\n user-select: none;\\n color: #838890; }\\n [vp] [vp-suggestion-screen].vp-enabled {\\n height: 96px; }\\n [vp] [vp-suggestion-screen].vp-enabled.vp-expanded {\\n height: calc(100% - 60px); }\\n [vp] [vp-suggestion-screen].vp-enabled.vp-expanded .vp-suggestion-screen-header button svg {\\n transform: rotate(180deg) !important; }\\n @media (max-width: 450px) {\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content {\\n gap: 6px;\\n padding: 10px; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-text {\\n height: 100px;\\n font-size: .8rem; }\\n [vp] [vp-suggestion-screen] .vp-suggestion-screen-content .vp-suggestion-buttons-container {\\n gap: 6px; } }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/SuggestionScreen/suggestion-screen.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/scss/styles.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\nexports.push([module.i, "@import url(https://fonts.cdnfonts.com/css/rawline);"]);\n// Module\nexports.push([module.i, "[vp] * {\\n box-sizing: border-box;\\n -webkit-box-sizing: border-box;\\n font-family: \'Rawline\', \'Open Sans\', sans-serif !important; }\\n\\n[vp] {\\n font-size: 16px;\\n height: 100%;\\n width: 100%;\\n position: relative; }\\n\\n[vp] [vp-blue-button] {\\n padding: 7px;\\n border-radius: 6px;\\n font-size: 12px;\\n text-align: center;\\n font-weight: bold;\\n color: white;\\n background-color: #003f86;\\n cursor: pointer;\\n margin: 10px 5px;\\n align-self: center; }\\n\\n[vp] [vp-visualize-signal-button] {\\n padding: 7px;\\n border-radius: 6px;\\n font-size: 12px;\\n text-align: center;\\n font-weight: bold;\\n color: #003f86;\\n background: white;\\n border: 1px solid #003f86;\\n cursor: pointer;\\n margin: 10px 5px;\\n align-self: center; }\\n\\n[vp] [vp-close-button] {\\n display: flex;\\n flex-direction: row;\\n justify-content: center;\\n align-items: center;\\n width: 28px;\\n height: 28px;\\n border-radius: 14px;\\n background-color: #b3b3b3;\\n cursor: pointer; }\\n [vp] [vp-close-button] img {\\n width: 100%; }\\n\\n#gameContainer {\\n background: #ebebeb !important; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./plugin/scss/styles.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/components/AccessButton/styles.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vw] [vw-access-button] {\\n display: none;\\n width: 160px;\\n text-align: center;\\n cursor: pointer;\\n margin: 0px 0px 0px -100px;\\n max-width: none; }\\n [vw] [vw-access-button].active {\\n display: block; }\\n [vw] [vw-access-button] .access-button {\\n width: 40px;\\n float: right; }\\n [vw] [vw-access-button] span {\\n font-size: 13px;\\n color: #004088; }\\n [vw] [vw-access-button] .access-button:hover + .pop-up {\\n width: calc(100% - 56px); }\\n [vw] [vw-access-button] .pop-up {\\n float: right;\\n width: 0%;\\n margin-right: 6px;\\n -webkit-transition: width 2s;\\n /* For Safari 3.1 to 6.0 */\\n transition: width 0.5s; }\\n [vw] [vw-access-button] .pop-up.left {\\n margin-right: -50px;\\n transform: translateX(100%); }\\n [vw] [vw-access-button] .access-button.left {\\n float: left !important;\\n margin-right: 6px; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./widget/src/components/AccessButton/styles.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/components/PluginWrapper/styles.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, ".vw-links {\\n top: -100px;\\n left: -100px;\\n position: absolute; }\\n .vw-links .vw-tooltip {\\n position: relative;\\n opacity: 1; }\\n .vw-links .vw-tooltip__item {\\n text-align: center;\\n position: absolute;\\n min-width: 123px;\\n padding: 8px;\\n visibility: hidden;\\n opacity: 0;\\n background: white;\\n transition: all 0.25s cubic-bezier(0, 0, 0.2, 1);\\n color: #484848;\\n border: 1px solid #cecece;\\n border-radius: 3px;\\n font-weight: 500;\\n box-shadow: 0 2px 1px #bcbcbc;\\n z-index: 4; }\\n .vw-links .vw-tooltip__item:after {\\n content: \\"\\";\\n display: block;\\n position: absolute;\\n width: 0;\\n height: 0;\\n border-style: solid; }\\n .vw-links .vw-tooltip__initiator {\\n cursor: pointer;\\n z-index: 5; }\\n .vw-links .vw-tooltip .vw-tooltip__item {\\n top: calc(100% + 1em);\\n left: 50%;\\n transform: translate3d(-50%, -15px, 0); }\\n .vw-links .vw-tooltip .vw-tooltip__item:after {\\n top: -0.5em;\\n left: 50%;\\n transform: translate3d(-50%, 0, 0);\\n border-width: 0 0.5em 0.5em 0.5em;\\n border-color: transparent transparent white transparent;\\n -webkit-filter: drop-shadow(1px 2px 1px #bcbcbc);\\n filter: drop-shadow(1px -1px 1px #bcbcbc); }\\n .vw-links .vw-tooltip.active > .vw-tooltip__item {\\n transform: translate3d(-50%, 0, 0);\\n visibility: visible;\\n opacity: 1; }\\n\\n[vw].maximize [vw-plugin-wrapper] {\\n width: 100%;\\n height: 100% !important;\\n max-height: initial !important; }\\n\\n[vw].left [vw-plugin-wrapper] {\\n float: left; }\\n\\n[vw] [vw-plugin-wrapper] {\\n position: relative;\\n display: none;\\n width: 300px;\\n height: 100%;\\n float: right;\\n overflow: hidden;\\n background: white;\\n -webkit-box-shadow: 0px 0px 9px 0px rgba(0, 0, 0, 0.15);\\n -moz-box-shadow: 0px 0px 9px 0px rgba(121, 76, 76, 0.15);\\n box-shadow: 0px 0px 9px 0px rgba(0, 0, 0, 0.15);\\n border-radius: 10px;\\n -moz-border-radius: 10px;\\n -webkit-border-radius: 10px;\\n overflow: hidden !important; }\\n [vw] [vw-plugin-wrapper].active {\\n display: -webkit-flex;\\n display: flex;\\n flex-direction: column;\\n -webkit-flex-direction: column;\\n height: 450px;\\n max-width: 100%;\\n overflow: hidden;\\n min-height: 100%; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./widget/src/components/PluginWrapper/styles.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/scss/reset.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "[vw] {\\n /* HTML5 display-role reset for older browsers */ }\\n [vw] html, [vw] body, [vw] div, [vw] span, [vw] applet, [vw] object, [vw] iframe,\\n [vw] h1, [vw] h2, [vw] h3, [vw] h4, [vw] h5, [vw] h6, [vw] p, [vw] blockquote, [vw] pre,\\n [vw] a, [vw] abbr, [vw] acronym, [vw] address, [vw] big, [vw] cite, [vw] code,\\n [vw] del, [vw] dfn, [vw] em, [vw] img, [vw] ins, [vw] kbd, [vw] q, [vw] s, [vw] samp,\\n [vw] small, [vw] strike, [vw] strong, [vw] sub, [vw] sup, [vw] tt, [vw] var,\\n [vw] b, [vw] u, [vw] i, [vw] center,\\n [vw] dl, [vw] dt, [vw] dd, [vw] ol, [vw] ul, [vw] li,\\n [vw] fieldset, [vw] form, [vw] label, [vw] legend,\\n [vw] table, [vw] caption, [vw] tbody, [vw] tfoot, [vw] thead, [vw] tr, [vw] th, [vw] td,\\n [vw] article, [vw] aside, [vw] canvas, [vw] details, [vw] embed,\\n [vw] figure, [vw] figcaption, [vw] footer, [vw] header, [vw] hgroup,\\n [vw] menu, [vw] nav, [vw] output, [vw] ruby, [vw] section, [vw] summary,\\n [vw] time, [vw] mark, [vw] audio, [vw] video {\\n margin: 0;\\n padding: 0;\\n border: 0;\\n font-size: 100%;\\n font: inherit;\\n vertical-align: baseline;\\n display: block; }\\n [vw] article, [vw] aside, [vw] details, [vw] figcaption, [vw] figure,\\n [vw] footer, [vw] header, [vw] hgroup, [vw] menu, [vw] nav, [vw] section {\\n display: block; }\\n [vw] img {\\n width: unset; }\\n [vw] body {\\n line-height: 1; }\\n [vw] ol, [vw] ul {\\n list-style: none; }\\n [vw] blockquote, [vw] q {\\n quotes: none; }\\n [vw] blockquote:before, [vw] blockquote:after,\\n [vw] q:before, [vw] q:after {\\n content: \'\';\\n content: none; }\\n [vw] table {\\n border-collapse: collapse;\\n border-spacing: 0; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./widget/src/scss/reset.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/scss/styles.scss':
function (module, exports, __webpack_require__) {
eval(
'// Imports\nvar ___CSS_LOADER_API_IMPORT___ = __webpack_require__(/*! ../../../node_modules/css-loader/dist/runtime/api.js */ "./node_modules/css-loader/dist/runtime/api.js");\nexports = ___CSS_LOADER_API_IMPORT___(false);\n// Module\nexports.push([module.i, "@media (max-width: 450px) {\\n div[vw] canvas {\\n min-height: unset !important;\\n min-width: unset !important;\\n -webkit-filter: blur(0px);\\n -moz-filter: blur(0px);\\n -ms-filter: blur(0px);\\n -o-filter: blur(0px);\\n filter: blur(0px);\\n min-height: calc(0.35 * 680px) !important;\\n min-width: calc(0.35 * 420px) !important; }\\n div[vw] [vw-plugin-wrapper].active {\\n height: 358px !important;\\n width: 210px !important; }\\n [vp] .vpw-controls-slider {\\n width: 30% !important; }\\n [vp] .vpw-settings-btn .vpw-settings-btn-close,\\n [vp] .vpw-btn-close .vpw-img {\\n right: 100px; }\\n [vp] [vp-rate-box].vp-enabled .vp-container {\\n margin-right: 70px;\\n margin-bottom: 80px; }\\n [vp] [vp-rate-button] .vp-button {\\n margin-right: 110px;\\n margin-bottom: 130px; }\\n [vp] [vp-rate-button] .vp-button img {\\n width: 32px;\\n margin-bottom: -37px;\\n margin-right: -14px; }\\n [vp] .vpw-settings .vpw-content .vpw-vlibras-logo {\\n left: 39%;\\n bottom: 125px; }\\n [vp] .vpw-settings .vpw-content > ul {\\n margin-left: -20px; }\\n [vp] .vpw-settings .vpw-content > ul li .vpw-name {\\n font-size: 12px; }\\n [vp] .vpw-settings .vpw-content > ul .vpw-localism .vpw-flag {\\n right: 88px;\\n height: 24px; }\\n [vp] .vpw-switch {\\n width: 48px;\\n height: 15px;\\n margin-top: -10px;\\n right: 64px; }\\n [vp] .vpw-slider-check.vpw-round:before {\\n top: -3px; }\\n [vp] .vpw-slider-check:before {\\n height: 21px;\\n width: 20px;\\n left: -20;\\n bottom: 4px; }\\n [vp] .vpw-bar .vpw-title {\\n margin-right: 40px; }\\n [vp] .vpw-dictionary .vpw-dict-container ul li:not(.margin) {\\n padding: 5px; } }\\n\\ndiv[vw] {\\n position: fixed;\\n max-width: 95vw;\\n right: 0;\\n top: 50%;\\n transform: translateY(-50%);\\n z-index: 99999999;\\n display: none;\\n font-family: Arial;\\n color: #000;\\n line-height: 1.3;\\n font-size: 16px;\\n margin: 10px !important; }\\n div[vw].enabled {\\n display: block; }\\n div[vw].active {\\n margin-top: -285px; }\\n div[vw].maximize {\\n top: 6vh;\\n left: 6vh;\\n right: 6vh;\\n bottom: 6vh;\\n max-width: initial;\\n margin-top: 0; }\\n div[vw].left {\\n left: 0;\\n right: initial; }\\n div[vw] #gameContainer {\\n position: absolute !important;\\n left: 0;\\n right: 0;\\n top: 0;\\n bottom: 0;\\n margin: auto !important;\\n width: 100%;\\n height: calc(100% - 80px);\\n overflow: hidden;\\n -moz-border-radius: 10px;\\n -webkit-border-radius: 10px;\\n border-radius: 0px;\\n background: none !important; }\\n div[vw] #gameContainer canvas {\\n min-height: calc(0.7 * 450px);\\n min-width: calc(0.9 * 300px);\\n height: 100%;\\n width: 100%;\\n -webkit-filter: blur(0px);\\n -moz-filter: blur(0px);\\n -ms-filter: blur(0px);\\n -o-filter: blur(0px);\\n filter: blur(0px); }\\n\\n.vw-text:hover {\\n background-color: rgba(0, 63, 134, 0.2);\\n color: #000;\\n cursor: pointer; }\\n\\n.vw-text-active {\\n background-color: rgba(30, 63, 134, 0.2);\\n color: #000; }\\n\\nvlibraswidget {\\n cursor: url(\\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAABQCAYAAABf9vbdAAAACXBIWXMAAAsTAAALEwEAmpwYAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAjASURBVHgB7VlbbBRVGP7PzJSCFK2KQAk2Q0JreEC5viCQEkADxMjFQOILt6eCiDxrQnkg8EaQ2xNQX0gkGkgMJVwartEHrloSoTVhI0gL1tDSAm13Z8b/O7NnO7s7253pbmti5iPDbHdmzn7//T//CCoy9l58Vj4iXmJqwim3NWHiO812Yjj3GIk72xe+2UFFhKACIQlbpet4oRpebTo5ZOZ5JMbHHf7pU716z2UWKEYFYNAC7D/fVaMJfYck7kGpIahsJNEIg2jMSHf5rh6H+hJE3T1EvQknbR3+65IgUb958ajvaBAILUAmcRB+q4zovQk6TXxTS5HOhX+6HWrvtin2Nx/ttvdSjOnUhRUksADsKia7yjFFHESrKzSaNkmXQkDLt/8kPmzq6iVq63QPWKOs1D2qxguqGidoRqX7PJ553GHTzQeW/OwScup79L6dQV0rkACu1rWTbOpykJ01WZfE8aNXWxxqaAJ5h8JgRqWgZdNwaPLv+22WV5AYO9f2zYtHn8q3Tl4BDje+2uE4Th0+V5QLWji1RGrvxA2bjl51tV0IKt4g2jhPk4KA/M8tiZRrCSHqaheN2kmDFcBLfrZpSM23PHFoV4PFZyoqIMj+z3U+C7oRS0hrSIJ5hBBByNdMNWSQFkvrA+HLRRqtnaPRb48S9EtLfiF8BTh09sUK0sVJfJ5bZUh/P3rNpiPXbBoOwKU28YG4uPR7wiXqWAtrl4y5lHmvlvkFsg2T34vPcJvhJg+o34PV4baAI/STklsGsgQoiZfU8ck0x2ryYbjNcJJXgBDfX7elEpE8GKj4xzLvS3Ohg+e61wtNO4Ys88mMEupmX//ssJW6PoED7ZvlOk0ZR3kLlhfILmc41e5rDKcI1I4DHNj43R+vx2UVz3Qlw/sAk9+BMzQPghuOJdIWPJDMEsj7sgkIQWTNHNfYYYSAAnc12FS/QaeZkzUZ1DZ3AXzpUpYA0D6fTBCH7zU02dTa2b8YCg/I77tgS7cKi92r3FwPd+wOkcWQtuFKa+cYdPehDWvWHObCqqzQHwOatg4nFTRHM/weZpQLPg1XcVNEnrptRRjXUwAXNIJoXYCkFVza+A/RrXqcieValvaDwO1xRErQYgIWu9Ji0/uTDNl3gSvaeFyTAvAGpAZnZB5oyPXxcNi9WpMxgiAfCoATWnR0vkBponQ9zlIADt5PcTbf0aSpBtOYIT7gr7AEgrbYACdwQ3wCTtJjVAxMx39vl4nQ5AF0la2dbpqEn6sO0w9wMQjrPYLiFrfq2HMAQtAHOBvSlywyYZ6xZRo1Pw2XYUAIhBE3EB6CLKhGt+p/P9zMDyc40+RLsdhvYG3EAdcEE9w1I2FI7b8+0pXsjyfhLDCzsl+D6GFgZrgUXCkMUCfQ/wyErl6XG6wMjI6PNlNPjDDUTRQKS1n70DqKOtxBZS9oKizWzB5YgLbk2oqrJXrLDQ2jD6dfKmgwKOA+sADcZ9fpfvOf/cqQZML2UIpDLrR1uhZApmxl0hjbGJk3hamS1ePdlHvierrb7Wu02I00uUnJrCdXmp2030DGCmotv+xm2Dx00kW/5if4/GgugMyVZivrewjV0GT5PvNto510ORcQckG1QUFQ5hnTABiYGZojOlDa+hL9C94eYJExBeb4bbzjgoVAYdM8PVTNUPf2eXpMo68kHiu1Sul5j528CVJmZ6KrMP0iN9N09dqpgAoCN9W62oOfw8JfL9dS3wUFxjKA8haMKg3MKg81voyxVCZMg6D0y+Hw2yPXLNq2WM+Zy4Ng12krVTvCoor3IRiKJad7MXB3nc/BrJLMx89sDr7c5E7cwBwoQdMrszU3s1LkJIX2G4VqfpWW0v5gMJMTw1/P3NhyHPoVZymA7diXeXC1ormN96EVuixEuVoKEGjN0ewtm+b7NRPHPsIVZM1sMSjtgxPczzMzkkMHuVLciNfjrMwT1jcHwi1WhKoRCEJYEW7kzURBAE5w8ZQAcbpMSgD4EqbEiG7sehawqQvtKKHtL45btPW4JbtU7MjqN+q8tls7sNeGIEjF+aBiBi4OgGvt0lGxlACA7VhycIRZDEyVry/JBxBDpsI6P9Qy8WpNthq7V+u0Z5XrphCkIsAGSHG5GUsOungcr66lTyUuvLyI3c7cKTwPelen9UetwFvIpWxi72YG5s63ffS758M96YMEOZGoNeh+Kw+57slrsc2LX5usrqepWVkBs0ksjmwR1JWuZrhCkL1v5j3oqTKBlA0uSvt4h+C9nibAVt7pq1jASA+FI6groU7su2DRYIGgzhwkoGrD7TBOgRB+b3KymhAtLjbYJfZtfvFQjgnxmjl6sojl7yxVnZgyTuTtLL1ArGSmbVR87BHgDQ/apWJiFKesAa+vnfFCQxf6RXxWk+n/Yrjb9MiS7wskLGfl5o+zX3j4+od0JceR0sKVmh5aclGYdCiBeMNvqMm0Ig8ufuSBASPt4PkXdVzx5BBJveCAryK/t4WcG+XDlPE8d12my7jzvuAA+S1LRtflei5vqvAKgbkR3he4syPXpQoVBFrflPR3BCosjhd/QcgHEgDYf+H5Cp0HGJScnc4yddkzARAEO7IwI0eQns+7sOVcXdWkG/4OraOV4X8d3J+t3OrzQmNQAgCHz7wyHd2uI03IGaoSRL0bDhrkKExqyg2yaF3g72qXhTSOTKhahaIJoJB8hwCXMtV3qnIHEQKjcvj5T7fj8qW3enMP4iikQbRekAAKchzPE201FFbpFp2nX0UFkGHg6/BzaL0Q4goF983eIB9ICJXbVYaBn3PvsnDLR2V3qAAUnNiRJbw1Ay0veqgZnl0bZkRDQR4o2s5FWQJTM7xfG2losl6gpUDQqqpaTPJA8bZe5C8EkmJ7l03n7hafPFDU3kC5E7pZZJmehC1nOJfvWUNCHiiqBRSUJVS/zzOnISEPDIkAgBJiqDQ/LIAQXC+mU4QIESJEiBAhQoQIESJEiBAhQoQIEf5n+Bc5J4A9gCvsTAAAAABJRU5ErkJggg==\\") 24 50, auto !important; }\\n", ""]);\n// Exports\nmodule.exports = exports;\n\n\n//# sourceURL=webpack://VLibras/./widget/src/scss/styles.scss?./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js'
)
},
'./node_modules/css-loader/dist/runtime/api.js': function (
module,
exports,
__webpack_require__
) {
'use strict'
eval(
'\n\n/*\n MIT License http://www.opensource.org/licenses/mit-license.php\n Author Tobias Koppers @sokra\n*/\n// css base code, injected by the css-loader\n// eslint-disable-next-line func-names\nmodule.exports = function (useSourceMap) {\n var list = []; // return the list of modules as css string\n\n list.toString = function toString() {\n return this.map(function (item) {\n var content = cssWithMappingToString(item, useSourceMap);\n\n if (item[2]) {\n return "@media ".concat(item[2], " {").concat(content, "}");\n }\n\n return content;\n }).join(\'\');\n }; // import a list of modules into the list\n // eslint-disable-next-line func-names\n\n\n list.i = function (modules, mediaQuery, dedupe) {\n if (typeof modules === \'string\') {\n // eslint-disable-next-line no-param-reassign\n modules = [[null, modules, \'\']];\n }\n\n var alreadyImportedModules = {};\n\n if (dedupe) {\n for (var i = 0; i < this.length; i++) {\n // eslint-disable-next-line prefer-destructuring\n var id = this[i][0];\n\n if (id != null) {\n alreadyImportedModules[id] = true;\n }\n }\n }\n\n for (var _i = 0; _i < modules.length; _i++) {\n var item = [].concat(modules[_i]);\n\n if (dedupe && alreadyImportedModules[item[0]]) {\n // eslint-disable-next-line no-continue\n continue;\n }\n\n if (mediaQuery) {\n if (!item[2]) {\n item[2] = mediaQuery;\n } else {\n item[2] = "".concat(mediaQuery, " and ").concat(item[2]);\n }\n }\n\n list.push(item);\n }\n };\n\n return list;\n};\n\nfunction cssWithMappingToString(item, useSourceMap) {\n var content = item[1] || \'\'; // eslint-disable-next-line prefer-destructuring\n\n var cssMapping = item[3];\n\n if (!cssMapping) {\n return content;\n }\n\n if (useSourceMap && typeof btoa === \'function\') {\n var sourceMapping = toComment(cssMapping);\n var sourceURLs = cssMapping.sources.map(function (source) {\n return "/*# sourceURL=".concat(cssMapping.sourceRoot || \'\').concat(source, " */");\n });\n return [content].concat(sourceURLs).concat([sourceMapping]).join(\'\\n\');\n }\n\n return [content].join(\'\\n\');\n} // Adapted from convert-source-map (MIT)\n\n\nfunction toComment(sourceMap) {\n // eslint-disable-next-line no-undef\n var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));\n var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64);\n return "/*# ".concat(data, " */");\n}\n\n//# sourceURL=webpack://VLibras/./node_modules/css-loader/dist/runtime/api.js?'
)
},
'./node_modules/events/events.js': function (
module,
exports,
__webpack_require__
) {
'use strict'
eval(
"// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n\n\nvar R = typeof Reflect === 'object' ? Reflect : null\nvar ReflectApply = R && typeof R.apply === 'function'\n ? R.apply\n : function ReflectApply(target, receiver, args) {\n return Function.prototype.apply.call(target, receiver, args);\n }\n\nvar ReflectOwnKeys\nif (R && typeof R.ownKeys === 'function') {\n ReflectOwnKeys = R.ownKeys\n} else if (Object.getOwnPropertySymbols) {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target)\n .concat(Object.getOwnPropertySymbols(target));\n };\n} else {\n ReflectOwnKeys = function ReflectOwnKeys(target) {\n return Object.getOwnPropertyNames(target);\n };\n}\n\nfunction ProcessEmitWarning(warning) {\n if (console && console.warn) console.warn(warning);\n}\n\nvar NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {\n return value !== value;\n}\n\nfunction EventEmitter() {\n EventEmitter.init.call(this);\n}\nmodule.exports = EventEmitter;\nmodule.exports.once = once;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._eventsCount = 0;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nvar defaultMaxListeners = 10;\n\nfunction checkListener(listener) {\n if (typeof listener !== 'function') {\n throw new TypeError('The \"listener\" argument must be of type Function. Received type ' + typeof listener);\n }\n}\n\nObject.defineProperty(EventEmitter, 'defaultMaxListeners', {\n enumerable: true,\n get: function() {\n return defaultMaxListeners;\n },\n set: function(arg) {\n if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {\n throw new RangeError('The value of \"defaultMaxListeners\" is out of range. It must be a non-negative number. Received ' + arg + '.');\n }\n defaultMaxListeners = arg;\n }\n});\n\nEventEmitter.init = function() {\n\n if (this._events === undefined ||\n this._events === Object.getPrototypeOf(this)._events) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n }\n\n this._maxListeners = this._maxListeners || undefined;\n};\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {\n if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {\n throw new RangeError('The value of \"n\" is out of range. It must be a non-negative number. Received ' + n + '.');\n }\n this._maxListeners = n;\n return this;\n};\n\nfunction _getMaxListeners(that) {\n if (that._maxListeners === undefined)\n return EventEmitter.defaultMaxListeners;\n return that._maxListeners;\n}\n\nEventEmitter.prototype.getMaxListeners = function getMaxListeners() {\n return _getMaxListeners(this);\n};\n\nEventEmitter.prototype.emit = function emit(type) {\n var args = [];\n for (var i = 1; i < arguments.length; i++) args.push(arguments[i]);\n var doError = (type === 'error');\n\n var events = this._events;\n if (events !== undefined)\n doError = (doError && events.error === undefined);\n else if (!doError)\n return false;\n\n // If there is no 'error' event listener then throw.\n if (doError) {\n var er;\n if (args.length > 0)\n er = args[0];\n if (er instanceof Error) {\n // Note: The comments on the `throw` lines are intentional, they show\n // up in Node's output if this results in an unhandled exception.\n throw er; // Unhandled 'error' event\n }\n // At least give some kind of context to the user\n var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));\n err.context = er;\n throw err; // Unhandled 'error' event\n }\n\n var handler = events[type];\n\n if (handler === undefined)\n return false;\n\n if (typeof handler === 'function') {\n ReflectApply(handler, this, args);\n } else {\n var len = handler.length;\n var listeners = arrayClone(handler, len);\n for (var i = 0; i < len; ++i)\n ReflectApply(listeners[i], this, args);\n }\n\n return true;\n};\n\nfunction _addListener(target, type, listener, prepend) {\n var m;\n var events;\n var existing;\n\n checkListener(listener);\n\n events = target._events;\n if (events === undefined) {\n events = target._events = Object.create(null);\n target._eventsCount = 0;\n } else {\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (events.newListener !== undefined) {\n target.emit('newListener', type,\n listener.listener ? listener.listener : listener);\n\n // Re-assign `events` because a newListener handler could have caused the\n // this._events to be assigned to a new object\n events = target._events;\n }\n existing = events[type];\n }\n\n if (existing === undefined) {\n // Optimize the case of one listener. Don't need the extra array object.\n existing = events[type] = listener;\n ++target._eventsCount;\n } else {\n if (typeof existing === 'function') {\n // Adding the second element, need to change to array.\n existing = events[type] =\n prepend ? [listener, existing] : [existing, listener];\n // If we've already got an array, just append.\n } else if (prepend) {\n existing.unshift(listener);\n } else {\n existing.push(listener);\n }\n\n // Check for listener leak\n m = _getMaxListeners(target);\n if (m > 0 && existing.length > m && !existing.warned) {\n existing.warned = true;\n // No error code for this since it is a Warning\n // eslint-disable-next-line no-restricted-syntax\n var w = new Error('Possible EventEmitter memory leak detected. ' +\n existing.length + ' ' + String(type) + ' listeners ' +\n 'added. Use emitter.setMaxListeners() to ' +\n 'increase limit');\n w.name = 'MaxListenersExceededWarning';\n w.emitter = target;\n w.type = type;\n w.count = existing.length;\n ProcessEmitWarning(w);\n }\n }\n\n return target;\n}\n\nEventEmitter.prototype.addListener = function addListener(type, listener) {\n return _addListener(this, type, listener, false);\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.prependListener =\n function prependListener(type, listener) {\n return _addListener(this, type, listener, true);\n };\n\nfunction onceWrapper() {\n if (!this.fired) {\n this.target.removeListener(this.type, this.wrapFn);\n this.fired = true;\n if (arguments.length === 0)\n return this.listener.call(this.target);\n return this.listener.apply(this.target, arguments);\n }\n}\n\nfunction _onceWrap(target, type, listener) {\n var state = { fired: false, wrapFn: undefined, target: target, type: type, listener: listener };\n var wrapped = onceWrapper.bind(state);\n wrapped.listener = listener;\n state.wrapFn = wrapped;\n return wrapped;\n}\n\nEventEmitter.prototype.once = function once(type, listener) {\n checkListener(listener);\n this.on(type, _onceWrap(this, type, listener));\n return this;\n};\n\nEventEmitter.prototype.prependOnceListener =\n function prependOnceListener(type, listener) {\n checkListener(listener);\n this.prependListener(type, _onceWrap(this, type, listener));\n return this;\n };\n\n// Emits a 'removeListener' event if and only if the listener was removed.\nEventEmitter.prototype.removeListener =\n function removeListener(type, listener) {\n var list, events, position, i, originalListener;\n\n checkListener(listener);\n\n events = this._events;\n if (events === undefined)\n return this;\n\n list = events[type];\n if (list === undefined)\n return this;\n\n if (list === listener || list.listener === listener) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else {\n delete events[type];\n if (events.removeListener)\n this.emit('removeListener', type, list.listener || listener);\n }\n } else if (typeof list !== 'function') {\n position = -1;\n\n for (i = list.length - 1; i >= 0; i--) {\n if (list[i] === listener || list[i].listener === listener) {\n originalListener = list[i].listener;\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (position === 0)\n list.shift();\n else {\n spliceOne(list, position);\n }\n\n if (list.length === 1)\n events[type] = list[0];\n\n if (events.removeListener !== undefined)\n this.emit('removeListener', type, originalListener || listener);\n }\n\n return this;\n };\n\nEventEmitter.prototype.off = EventEmitter.prototype.removeListener;\n\nEventEmitter.prototype.removeAllListeners =\n function removeAllListeners(type) {\n var listeners, events, i;\n\n events = this._events;\n if (events === undefined)\n return this;\n\n // not listening for removeListener, no need to emit\n if (events.removeListener === undefined) {\n if (arguments.length === 0) {\n this._events = Object.create(null);\n this._eventsCount = 0;\n } else if (events[type] !== undefined) {\n if (--this._eventsCount === 0)\n this._events = Object.create(null);\n else\n delete events[type];\n }\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n var keys = Object.keys(events);\n var key;\n for (i = 0; i < keys.length; ++i) {\n key = keys[i];\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = Object.create(null);\n this._eventsCount = 0;\n return this;\n }\n\n listeners = events[type];\n\n if (typeof listeners === 'function') {\n this.removeListener(type, listeners);\n } else if (listeners !== undefined) {\n // LIFO order\n for (i = listeners.length - 1; i >= 0; i--) {\n this.removeListener(type, listeners[i]);\n }\n }\n\n return this;\n };\n\nfunction _listeners(target, type, unwrap) {\n var events = target._events;\n\n if (events === undefined)\n return [];\n\n var evlistener = events[type];\n if (evlistener === undefined)\n return [];\n\n if (typeof evlistener === 'function')\n return unwrap ? [evlistener.listener || evlistener] : [evlistener];\n\n return unwrap ?\n unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);\n}\n\nEventEmitter.prototype.listeners = function listeners(type) {\n return _listeners(this, type, true);\n};\n\nEventEmitter.prototype.rawListeners = function rawListeners(type) {\n return _listeners(this, type, false);\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n if (typeof emitter.listenerCount === 'function') {\n return emitter.listenerCount(type);\n } else {\n return listenerCount.call(emitter, type);\n }\n};\n\nEventEmitter.prototype.listenerCount = listenerCount;\nfunction listenerCount(type) {\n var events = this._events;\n\n if (events !== undefined) {\n var evlistener = events[type];\n\n if (typeof evlistener === 'function') {\n return 1;\n } else if (evlistener !== undefined) {\n return evlistener.length;\n }\n }\n\n return 0;\n}\n\nEventEmitter.prototype.eventNames = function eventNames() {\n return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];\n};\n\nfunction arrayClone(arr, n) {\n var copy = new Array(n);\n for (var i = 0; i < n; ++i)\n copy[i] = arr[i];\n return copy;\n}\n\nfunction spliceOne(list, index) {\n for (; index + 1 < list.length; index++)\n list[index] = list[index + 1];\n list.pop();\n}\n\nfunction unwrapListeners(arr) {\n var ret = new Array(arr.length);\n for (var i = 0; i < ret.length; ++i) {\n ret[i] = arr[i].listener || arr[i];\n }\n return ret;\n}\n\nfunction once(emitter, name) {\n return new Promise(function (resolve, reject) {\n function errorListener(err) {\n emitter.removeListener(name, resolver);\n reject(err);\n }\n\n function resolver() {\n if (typeof emitter.removeListener === 'function') {\n emitter.removeListener('error', errorListener);\n }\n resolve([].slice.call(arguments));\n };\n\n eventTargetAgnosticAddListener(emitter, name, resolver, { once: true });\n if (name !== 'error') {\n addErrorHandlerIfEventEmitter(emitter, errorListener, { once: true });\n }\n });\n}\n\nfunction addErrorHandlerIfEventEmitter(emitter, handler, flags) {\n if (typeof emitter.on === 'function') {\n eventTargetAgnosticAddListener(emitter, 'error', handler, flags);\n }\n}\n\nfunction eventTargetAgnosticAddListener(emitter, name, listener, flags) {\n if (typeof emitter.on === 'function') {\n if (flags.once) {\n emitter.once(name, listener);\n } else {\n emitter.on(name, listener);\n }\n } else if (typeof emitter.addEventListener === 'function') {\n // EventTarget does not have `error` event semantics like Node\n // EventEmitters, we do not listen for `error` events here.\n emitter.addEventListener(name, function wrapListener(arg) {\n // IE does not have builtin `{ once: true }` support so we\n // have to do it manually.\n if (flags.once) {\n emitter.removeEventListener(name, wrapListener);\n }\n listener(arg);\n });\n } else {\n throw new TypeError('The \"emitter\" argument must be of type EventEmitter. Received type ' + typeof emitter);\n }\n}\n\n\n//# sourceURL=webpack://VLibras/./node_modules/events/events.js?"
)
},
'./node_modules/hasharray/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
'module.exports = __webpack_require__(/*! ./src/HashArray.js */ "./node_modules/hasharray/src/HashArray.js");\n\n//# sourceURL=webpack://VLibras/./node_modules/hasharray/index.js?'
)
},
'./node_modules/hasharray/src/HashArray.js': function (
module,
exports,
__webpack_require__
) {
eval(
"/*===========================================================================*\\\n * Requires\n\\*===========================================================================*/\nvar JClass = __webpack_require__(/*! jclass */ \"./node_modules/jclass/index.js\");\n\n/*===========================================================================*\\\n * HashArray\n\\*===========================================================================*/\nvar HashArray = JClass._extend({\n //-----------------------------------\n // Constructor\n //-----------------------------------\n init: function(keyFields, callback, options) {\n keyFields = keyFields instanceof Array ? keyFields : [keyFields];\n\n this._map = {};\n this._list = [];\n this.callback = callback;\n\n this.keyFields = keyFields;\n\n this.isHashArray = true;\n \n this.options = options || {\n ignoreDuplicates: false\n };\n\n if (callback) {\n callback('construct');\n }\n },\n //-----------------------------------\n // add()\n //-----------------------------------\n addOne: function (obj) {\n var needsDupCheck = false;\n for (var key in this.keyFields) {\n key = this.keyFields[key];\n var inst = this.objectAt(obj, key);\n if (inst) {\n if (this.has(inst)) {\n if (this.options.ignoreDuplicates)\n return;\n if (this._map[inst].indexOf(obj) != -1) {\n // Cannot add the same item twice\n needsDupCheck = true;\n continue;\n }\n this._map[inst].push(obj);\n }\n else this._map[inst] = [obj];\n }\n }\n\n if (!needsDupCheck || this._list.indexOf(obj) == -1)\n this._list.push(obj);\n },\n add: function() {\n for (var i = 0; i < arguments.length; i++) {\n this.addOne(arguments[i]);\n }\n\n if (this.callback) {\n this.callback('add', Array.prototype.slice.call(arguments, 0));\n }\n \n return this;\n },\n addAll: function (arr) {\n if (arr.length < 100)\n this.add.apply(this, arr);\n else {\n for (var i = 0; i < arr.length; i++)\n this.add(arr[i]);\n }\n \n return this;\n },\n addMap: function(key, obj) {\n this._map[key] = obj;\n if (this.callback) {\n this.callback('addMap', {\n key: key,\n obj: obj\n });\n }\n \n return this;\n },\n //-----------------------------------\n // Intersection, union, etc.\n //-----------------------------------\n /**\n * Returns a new HashArray that contains the intersection between this (A) and the hasharray passed in (B). Returns A ^ B.\n */\n intersection: function (other) {\n var self = this;\n\n if (!other || !other.isHashArray)\n throw Error('Cannot HashArray.intersection() on a non-hasharray object. You passed in: ', other);\n\n var ret = this.clone(null, true),\n allItems = this.clone(null, true).addAll(this.all.concat(other.all));\n\n allItems.all.forEach(function (item) {\n if (self.collides(item) && other.collides(item))\n ret.add(item);\n });\n\n return ret;\n },\n /**\n * Returns a new HashArray that contains the complement (difference) between this hash array (A) and the hasharray passed in (B). Returns A - B.\n */\n complement: function (other) {\n var self = this;\n\n if (!other || !other.isHashArray)\n throw Error('Cannot HashArray.complement() on a non-hasharray object. You passed in: ', other);\n\n var ret = this.clone(null, true);\n\n this.all.forEach(function (item) {\n if (!other.collides(item))\n ret.add(item);\n });\n\n return ret;\n },\n //-----------------------------------\n // Retrieval\n //-----------------------------------\n get: function(key) {\n if (!this.has(key))\n return;\n return (!(this._map[key] instanceof Array) || this._map[key].length != 1) ? this._map[key] : this._map[key][0];\n },\n getAll: function(keys) {\n keys = keys instanceof Array ? keys : [keys];\n\n if (keys[0] == '*')\n return this.all;\n\n var res = new HashArray(this.keyFields);\n for (var key in keys)\n res.add.apply(res, this.getAsArray(keys[key]));\n\n return res.all;\n },\n getAsArray: function(key) {\n return this._map[key] || [];\n },\n getUniqueRandomIntegers: function (count, min, max) {\n var res = [], map = {};\n\n count = Math.min(Math.max(max - min, 1), count);\n \n while (res.length < count)\n {\n var r = Math.floor(min + (Math.random() * (max + 1)));\n if (map[r]) continue;\n map[r] = true;\n res.push(r);\n }\n\n return res;\n },\n sample: function (count, keys) {\n // http://en.wikipedia.org/wiki/Image_(mathematics)\n var image = this.all,\n ixs = {},\n res = [];\n\n if (keys)\n image = this.getAll(keys);\n\n var rand = this.getUniqueRandomIntegers(count, 0, image.length - 1);\n\n for (var i = 0; i < rand.length; i++)\n res.push(image[rand[i]]);\n\n return res;\n },\n //-----------------------------------\n // Peeking\n //-----------------------------------\n has: function(key) {\n return this._map.hasOwnProperty(key);\n },\n collides: function (item) {\n for (var k in this.keyFields)\n if (this.has(this.objectAt(item, this.keyFields[k])))\n return true;\n \n return false;\n },\n hasMultiple: function(key) {\n return this._map[key] instanceof Array;\n },\n //-----------------------------------\n // Removal\n //-----------------------------------\n removeByKey: function() {\n var removed = [];\n for (var i = 0; i < arguments.length; i++) {\n var key = arguments[i];\n var items = this._map[key].concat();\n if (items) {\n removed = removed.concat(items);\n for (var j in items) {\n var item = items[j];\n for (var ix in this.keyFields) {\n var key2 = this.objectAt(item, this.keyFields[ix]);\n if (key2 && this.has(key2)) {\n var ix = this._map[key2].indexOf(item);\n if (ix != -1) {\n this._map[key2].splice(ix, 1);\n }\n\n if (this._map[key2].length == 0)\n delete this._map[key2];\n }\n }\n\n this._list.splice(this._list.indexOf(item), 1);\n }\n }\n delete this._map[key];\n }\n\n if (this.callback) {\n this.callback('removeByKey', removed);\n }\n \n return this;\n },\n remove: function() {\n for (var i = 0; i < arguments.length; i++) {\n var item = arguments[i];\n for (var ix in this.keyFields) {\n var key = this.objectAt(item, this.keyFields[ix]);\n if (key) {\n var ix = this._map[key].indexOf(item);\n if (ix != -1)\n this._map[key].splice(ix, 1);\n else\n throw new Error('HashArray: attempting to remove an object that was never added!' + key);\n\n if (this._map[key].length == 0)\n delete this._map[key];\n }\n }\n\n var ix = this._list.indexOf(item);\n\n if (ix != -1)\n this._list.splice(ix, 1);\n else\n throw new Error('HashArray: attempting to remove an object that was never added!' + key);\n }\n\n if (this.callback) {\n this.callback('remove', arguments);\n }\n \n return this;\n },\n removeAll: function() {\n var old = this._list.concat();\n this._map = {};\n this._list = [];\n\n if (this.callback) {\n this.callback('remove', old);\n }\n \n return this;\n },\n //-----------------------------------\n // Utility\n //-----------------------------------\n objectAt: function(obj, path) {\n if (typeof path === 'string') {\n return obj[path];\n }\n\n var dup = path.concat();\n // else assume array.\n while (dup.length && obj) {\n obj = obj[dup.shift()];\n }\n\n return obj;\n },\n //-----------------------------------\n // Iteration\n //-----------------------------------\n forEach: function(keys, callback) {\n keys = keys instanceof Array ? keys : [keys];\n\n var objs = this.getAll(keys);\n\n objs.forEach(callback);\n \n return this;\n },\n forEachDeep: function(keys, key, callback) {\n keys = keys instanceof Array ? keys : [keys];\n\n var self = this,\n objs = this.getAll(keys);\n\n objs.forEach(function (item) {\n callback(self.objectAt(item, key), item);\n });\n \n return this;\n },\n //-----------------------------------\n // Cloning\n //-----------------------------------\n clone: function(callback, ignoreItems) {\n var n = new HashArray(this.keyFields.concat(), callback ? callback : this.callback);\n if (!ignoreItems)\n n.add.apply(n, this.all.concat());\n return n;\n },\n //-----------------------------------\n // Mathematical\n //-----------------------------------\n sum: function(keys, key, weightKey) {\n var self = this,\n ret = 0;\n this.forEachDeep(keys, key, function (value, item) {\n if (weightKey !== undefined)\n value *= self.objectAt(item, weightKey);\n\n ret += value;\n });\n return ret;\n },\n average: function(keys, key, weightKey) {\n var ret = 0,\n tot = 0,\n weightsTotal = 0,\n self = this;\n\n if (weightKey !== undefined)\n this.forEachDeep(keys, weightKey, function (value) {\n weightsTotal += value;\n })\n\n this.forEachDeep(keys, key, function (value, item) {\n if (weightKey !== undefined)\n value *= (self.objectAt(item, weightKey) / weightsTotal);\n\n ret += value;\n tot++;\n });\n\n return weightKey !== undefined ? ret : ret / tot;\n },\n //-----------------------------------\n // Filtering\n //-----------------------------------\n filter: function (keys, callbackOrKey) {\n var self = this;\n \n var callback = (typeof(callbackOrKey) == 'function') ? callbackOrKey : defaultCallback;\n\n var ha = new HashArray(this.keyFields);\n ha.addAll(this.getAll(keys).filter(callback));\n return ha;\n \n function defaultCallback(item) {\n var val = self.objectAt(item, callbackOrKey);\n return val !== undefined && val !== false;\n }\n }\n});\n\n//-----------------------------------\n// Operators\n//-----------------------------------\nObject.defineProperty(HashArray.prototype, 'all', {\n get: function () {\n return this._list;\n }\n});\n\nObject.defineProperty(HashArray.prototype, 'map', {\n get: function () {\n return this._map;\n }\n});\n\nmodule.exports = HashArray;\n\n//-----------------------------------\n// Browser\n//-----------------------------------\nif (typeof window !== 'undefined')\n window.HashArray = HashArray;\n\n//# sourceURL=webpack://VLibras/./node_modules/hasharray/src/HashArray.js?"
)
},
'./node_modules/inherits/inherits_browser.js': function (module, exports) {
eval(
"if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n\n\n//# sourceURL=webpack://VLibras/./node_modules/inherits/inherits_browser.js?"
)
},
'./node_modules/jclass/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
'var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/**\n * jclass v1.1.9\n * https://github.com/riga/jclass\n *\n * Marcel Rieger, 2015\n * MIT licensed, http://www.opensource.org/licenses/mit-license\n */\n\n(function(factory) {\n\n /**\n * Make jclass available in any context.\n */\n\n if (true) {\n // AMD\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === \'function\' ?\n\t\t\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n\n } else {}\n\n})(function() {\n\n /**\n * Helper functions.\n */\n\n /**\n * Checks whether a passed object is a function.\n *\n * @param obj - The object to check.\n * @returns {boolean}\n */\n var isFn = function(obj) {\n return obj instanceof Function;\n };\n\n /**\n * Extends a target object by one or more source objects with shallow key comparisons. Note that\n * the extension is done in-place.\n *\n * @param {object} target - The target object to extend.\n * @param {...object} source - Source objects.\n * @returns {object} The extended object.\n */\n var extend = function(target) {\n var sources = Array.prototype.slice.call(arguments, 1);\n\n // loop through all sources\n for (var i in sources) {\n var source = sources[i];\n\n // object check\n if (typeof(source) != "object") {\n continue;\n }\n\n // loop through all source attributes\n for (var key in source) {\n target[key] = source[key];\n }\n }\n\n return target;\n };\n\n\n /**\n * Default options.\n */\n\n var defaultOptions = {\n // internal object for indicating that class objects don\'t have a class object themselves,\n // may not be used by users\n _isClassObject: false\n };\n\n\n /**\n * Flags.\n */\n\n // flag to distinguish between prototype and class instantiation \n var initializing = false;\n\n\n /**\n * Base class definition.\n */\n\n // empty BaseClass implementation\n var BaseClass = function(){};\n\n // add the _subClasses entry\n BaseClass._subClasses = [];\n\n // empty init method\n BaseClass.prototype.init = function(){};\n\n\n /**\n * Extend mechanism. Returns a derived class.\n *\n * @param {object} instanceMembers - Members that will be owned by instances.\n * @param {object} classMembers - Members that will be owned by the class itself.\n * @returns {JClass}\n */\n BaseClass._extend = function(instanceMembers, classMembers, options) {\n\n // default arguments\n if (instanceMembers === undefined) {\n instanceMembers = {};\n }\n if (classMembers === undefined) {\n classMembers = {};\n }\n if (options === undefined) {\n options = {};\n }\n\n // mixin default options\n options = extend({}, defaultOptions, options);\n\n\n // sub class dummy constructor\n var JClass = function() {\n // nothing happens here when we are initializing\n if (initializing) {\n return;\n }\n\n // store a reference to the class itself\n this._class = JClass;\n\n // all construction is actually done in the init method\n if (this.init instanceof Function) {\n this.init.apply(this, arguments);\n }\n };\n\n\n // alias for readability\n var SuperClass = this;\n\n // create an instance of the super class via new\n // the flag sandwich prevents a call to the init method\n initializing = true;\n var prototype = new SuperClass();\n initializing = false;\n\n // get the prototype of the super class\n var superPrototype = SuperClass.prototype;\n\n // the instance of the super class is our new prototype\n JClass.prototype = prototype;\n\n // enforce the constructor to be what we expect\n // calls to the constructor will invoke the init method (see above)\n JClass.prototype.constructor = JClass;\n\n // store a reference to the super class\n JClass._superClass = SuperClass;\n\n // store references to all extending classes\n JClass._subClasses = [];\n SuperClass._subClasses.push(JClass);\n\n // make this class extendable as well\n JClass._extend = SuperClass._extend;\n\n\n // _extends returns true if the class itself extended "target"\n // in any hierarchy, e.g. every class extends "JClass" itself\n JClass._extends = function(target) {\n // this function operates recursive, so stop when the super class is our BaseClass\n if (this._superClass == BaseClass) {\n return false;\n }\n\n // success case\n if (target == this._superClass || target == BaseClass) {\n return true;\n }\n\n // continue with the next super class\n return this._superClass._extends(target);\n };\n\n\n // propagate instance members directly to the created protoype,\n // the member is either a normal member or a descriptor\n for (var key in instanceMembers) {\n var property = Object.getOwnPropertyDescriptor(instanceMembers, key);\n var member = property.value;\n\n // descriptor flag set?\n if (member !== null && typeof(member) == "object" && member.descriptor) {\n Object.defineProperty(prototype, key, member);\n\n // getter/setter syntax\n } else if (!("value" in property) && ("set" in property || "get" in property)) {\n Object.defineProperty(prototype, key, property);\n\n // normal member, simple assignment\n } else {\n prototype[key] = member;\n\n // if both member and the super member are distinct functions\n // add the super member to the member as "_super"\n var superMember = superPrototype[key];\n if (isFn(member) && isFn(superMember) && member !== superMember) {\n member._super = superMember;\n }\n }\n }\n\n\n // propagate class members to the _members object\n if (!options._isClassObject) {\n // try to find the super class of the _members object \n var ClassMembersSuperClass = SuperClass._members === undefined ?\n BaseClass : SuperClass._members._class;\n\n // create the actual class of the _members instance\n // with an updated version of our options\n var opts = extend({}, options, { _isClassObject: true });\n var ClassMembersClass = ClassMembersSuperClass._extend(classMembers, {}, opts);\n\n // store the actual JClass in ClassMembersClass\n ClassMembersClass._instanceClass = JClass;\n\n // create the _members instance\n JClass._members = new ClassMembersClass();\n }\n\n\n // return the new class\n return JClass;\n };\n\n\n /**\n * Converts arbitrary protoype-style classes to our JClass definition.\n *\n * @param {function} cls - The class to convert.\n * @returns {JClass}\n */\n BaseClass._convert = function(cls, options) {\n // the properties consist of the class\' prototype\n var instanceMembers = cls.prototype;\n\n // add the constructor function\n instanceMembers.init = function() {\n // simply create an instance of our target class\n var origin = this._origin = BaseClass._construct(cls, arguments);\n\n // add properties for each own property in _origin\n Object.keys(origin).forEach(function(key) {\n if (!origin.hasOwnProperty(key)) {\n return;\n }\n\n Object.defineProperty(this, key, {\n get: function() {\n return origin[key];\n }\n });\n }, this);\n };\n\n // finally, create and return our new class\n return BaseClass._extend(instanceMembers, {}, options);\n };\n\n\n /**\n * Returns an instance of a class with a list of arguments. This provides an apply-like\n * constructor usage. Note that this approach does not work with native constructors (e.g. String\n * or Boolean).\n *\n * @param {Class|JClass} cls - The class to instantiate. This may be a JClass or a prototype-based\n * class.\n * @param {array} [args=[]] - Arguments to pass to the constructor.\n * @returns {instance}\n */\n BaseClass._construct = function(cls, args) {\n // empty default args\n if (args === undefined) {\n args = [];\n }\n\n // create a class wrapper that calls cls like a function\n var Class = function() {\n return cls.apply(this, args);\n };\n\n // copy the prototype\n Class.prototype = cls.prototype;\n\n // return a new instance\n return new Class();\n };\n\n\n /**\n * Returns a property descriptor of the super class.\n *\n * @param {JClass|instance} cls - A JClass or an instance of a JClass to retrieve the property\n * descriptor from.\n * @param {string} prop - The name of the property descriptor to get.\n * @returns {object}\n */\n BaseClass._superDescriptor = function(cls, prop) {\n // if cls is an instance, use its class\n if ("_class" in cls && cls instanceof cls._class) {\n cls = cls._class;\n }\n\n // a JClass?\n if ("_extends" in cls && cls._extends instanceof Function && cls._extends(this)) {\n return Object.getOwnPropertyDescriptor(cls._superClass.prototype, prop);\n } else {\n return undefined;\n }\n };\n\n\n /**\n * Return the BaseClass.\n */\n\n return BaseClass;\n});\n\n\n//# sourceURL=webpack://VLibras/./node_modules/jclass/index.js?'
)
},
'./node_modules/nouislider/distribute/nouislider.js': function (
module,
exports,
__webpack_require__
) {
eval(
"var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! nouislider - 8.5.1 - 2016-04-24 16:00:29 */\r\n\r\n(function (factory) {\r\n\r\n if ( true ) {\r\n\r\n // AMD. Register as an anonymous module.\r\n !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\r\n\r\n } else {}\r\n\r\n}(function( ){\r\n\r\n\t'use strict';\r\n\r\n\r\n\t// Removes duplicates from an array.\r\n\tfunction unique(array) {\r\n\t\treturn array.filter(function(a){\r\n\t\t\treturn !this[a] ? this[a] = true : false;\r\n\t\t}, {});\r\n\t}\r\n\r\n\t// Round a value to the closest 'to'.\r\n\tfunction closest ( value, to ) {\r\n\t\treturn Math.round(value / to) * to;\r\n\t}\r\n\r\n\t// Current position of an element relative to the document.\r\n\tfunction offset ( elem ) {\r\n\r\n\tvar rect = elem.getBoundingClientRect(),\r\n\t\tdoc = elem.ownerDocument,\r\n\t\tdocElem = doc.documentElement,\r\n\t\tpageOffset = getPageOffset();\r\n\r\n\t\t// getBoundingClientRect contains left scroll in Chrome on Android.\r\n\t\t// I haven't found a feature detection that proves this. Worst case\r\n\t\t// scenario on mis-match: the 'tap' feature on horizontal sliders breaks.\r\n\t\tif ( /webkit.*Chrome.*Mobile/i.test(navigator.userAgent) ) {\r\n\t\t\tpageOffset.x = 0;\r\n\t\t}\r\n\r\n\t\treturn {\r\n\t\t\ttop: rect.top + pageOffset.y - docElem.clientTop,\r\n\t\t\tleft: rect.left + pageOffset.x - docElem.clientLeft\r\n\t\t};\r\n\t}\r\n\r\n\t// Checks whether a value is numerical.\r\n\tfunction isNumeric ( a ) {\r\n\t\treturn typeof a === 'number' && !isNaN( a ) && isFinite( a );\r\n\t}\r\n\r\n\t// Sets a class and removes it after [duration] ms.\r\n\tfunction addClassFor ( element, className, duration ) {\r\n\t\taddClass(element, className);\r\n\t\tsetTimeout(function(){\r\n\t\t\tremoveClass(element, className);\r\n\t\t}, duration);\r\n\t}\r\n\r\n\t// Limits a value to 0 - 100\r\n\tfunction limit ( a ) {\r\n\t\treturn Math.max(Math.min(a, 100), 0);\r\n\t}\r\n\r\n\t// Wraps a variable as an array, if it isn't one yet.\r\n\tfunction asArray ( a ) {\r\n\t\treturn Array.isArray(a) ? a : [a];\r\n\t}\r\n\r\n\t// Counts decimals\r\n\tfunction countDecimals ( numStr ) {\r\n\t\tvar pieces = numStr.split(\".\");\r\n\t\treturn pieces.length > 1 ? pieces[1].length : 0;\r\n\t}\r\n\r\n\t// http://youmightnotneedjquery.com/#add_class\r\n\tfunction addClass ( el, className ) {\r\n\t\tif ( el.classList ) {\r\n\t\t\tel.classList.add(className);\r\n\t\t} else {\r\n\t\t\tel.className += ' ' + className;\r\n\t\t}\r\n\t}\r\n\r\n\t// http://youmightnotneedjquery.com/#remove_class\r\n\tfunction removeClass ( el, className ) {\r\n\t\tif ( el.classList ) {\r\n\t\t\tel.classList.remove(className);\r\n\t\t} else {\r\n\t\t\tel.className = el.className.replace(new RegExp('(^|\\\\b)' + className.split(' ').join('|') + '(\\\\b|$)', 'gi'), ' ');\r\n\t\t}\r\n\t}\r\n\r\n\t// https://plainjs.com/javascript/attributes/adding-removing-and-testing-for-classes-9/\r\n\tfunction hasClass ( el, className ) {\r\n\t\treturn el.classList ? el.classList.contains(className) : new RegExp('\\\\b' + className + '\\\\b').test(el.className);\r\n\t}\r\n\r\n\t// https://developer.mozilla.org/en-US/docs/Web/API/Window/scrollY#Notes\r\n\tfunction getPageOffset ( ) {\r\n\r\n\t\tvar supportPageOffset = window.pageXOffset !== undefined,\r\n\t\t\tisCSS1Compat = ((document.compatMode || \"\") === \"CSS1Compat\"),\r\n\t\t\tx = supportPageOffset ? window.pageXOffset : isCSS1Compat ? document.documentElement.scrollLeft : document.body.scrollLeft,\r\n\t\t\ty = supportPageOffset ? window.pageYOffset : isCSS1Compat ? document.documentElement.scrollTop : document.body.scrollTop;\r\n\r\n\t\treturn {\r\n\t\t\tx: x,\r\n\t\t\ty: y\r\n\t\t};\r\n\t}\r\n\r\n\t// we provide a function to compute constants instead\r\n\t// of accessing window.* as soon as the module needs it\r\n\t// so that we do not compute anything if not needed\r\n\tfunction getActions ( ) {\r\n\r\n\t\t// Determine the events to bind. IE11 implements pointerEvents without\r\n\t\t// a prefix, which breaks compatibility with the IE10 implementation.\r\n\t\treturn window.navigator.pointerEnabled ? {\r\n\t\t\tstart: 'pointerdown',\r\n\t\t\tmove: 'pointermove',\r\n\t\t\tend: 'pointerup'\r\n\t\t} : window.navigator.msPointerEnabled ? {\r\n\t\t\tstart: 'MSPointerDown',\r\n\t\t\tmove: 'MSPointerMove',\r\n\t\t\tend: 'MSPointerUp'\r\n\t\t} : {\r\n\t\t\tstart: 'mousedown touchstart',\r\n\t\t\tmove: 'mousemove touchmove',\r\n\t\t\tend: 'mouseup touchend'\r\n\t\t};\r\n\t}\r\n\r\n\r\n// Value calculation\r\n\r\n\t// Determine the size of a sub-range in relation to a full range.\r\n\tfunction subRangeRatio ( pa, pb ) {\r\n\t\treturn (100 / (pb - pa));\r\n\t}\r\n\r\n\t// (percentage) How many percent is this value of this range?\r\n\tfunction fromPercentage ( range, value ) {\r\n\t\treturn (value * 100) / ( range[1] - range[0] );\r\n\t}\r\n\r\n\t// (percentage) Where is this value on this range?\r\n\tfunction toPercentage ( range, value ) {\r\n\t\treturn fromPercentage( range, range[0] < 0 ?\r\n\t\t\tvalue + Math.abs(range[0]) :\r\n\t\t\t\tvalue - range[0] );\r\n\t}\r\n\r\n\t// (value) How much is this percentage on this range?\r\n\tfunction isPercentage ( range, value ) {\r\n\t\treturn ((value * ( range[1] - range[0] )) / 100) + range[0];\r\n\t}\r\n\r\n\r\n// Range conversion\r\n\r\n\tfunction getJ ( value, arr ) {\r\n\r\n\t\tvar j = 1;\r\n\r\n\t\twhile ( value >= arr[j] ){\r\n\t\t\tj += 1;\r\n\t\t}\r\n\r\n\t\treturn j;\r\n\t}\r\n\r\n\t// (percentage) Input a value, find where, on a scale of 0-100, it applies.\r\n\tfunction toStepping ( xVal, xPct, value ) {\r\n\r\n\t\tif ( value >= xVal.slice(-1)[0] ){\r\n\t\t\treturn 100;\r\n\t\t}\r\n\r\n\t\tvar j = getJ( value, xVal ), va, vb, pa, pb;\r\n\r\n\t\tva = xVal[j-1];\r\n\t\tvb = xVal[j];\r\n\t\tpa = xPct[j-1];\r\n\t\tpb = xPct[j];\r\n\r\n\t\treturn pa + (toPercentage([va, vb], value) / subRangeRatio (pa, pb));\r\n\t}\r\n\r\n\t// (value) Input a percentage, find where it is on the specified range.\r\n\tfunction fromStepping ( xVal, xPct, value ) {\r\n\r\n\t\t// There is no range group that fits 100\r\n\t\tif ( value >= 100 ){\r\n\t\t\treturn xVal.slice(-1)[0];\r\n\t\t}\r\n\r\n\t\tvar j = getJ( value, xPct ), va, vb, pa, pb;\r\n\r\n\t\tva = xVal[j-1];\r\n\t\tvb = xVal[j];\r\n\t\tpa = xPct[j-1];\r\n\t\tpb = xPct[j];\r\n\r\n\t\treturn isPercentage([va, vb], (value - pa) * subRangeRatio (pa, pb));\r\n\t}\r\n\r\n\t// (percentage) Get the step that applies at a certain value.\r\n\tfunction getStep ( xPct, xSteps, snap, value ) {\r\n\r\n\t\tif ( value === 100 ) {\r\n\t\t\treturn value;\r\n\t\t}\r\n\r\n\t\tvar j = getJ( value, xPct ), a, b;\r\n\r\n\t\t// If 'snap' is set, steps are used as fixed points on the slider.\r\n\t\tif ( snap ) {\r\n\r\n\t\t\ta = xPct[j-1];\r\n\t\t\tb = xPct[j];\r\n\r\n\t\t\t// Find the closest position, a or b.\r\n\t\t\tif ((value - a) > ((b-a)/2)){\r\n\t\t\t\treturn b;\r\n\t\t\t}\r\n\r\n\t\t\treturn a;\r\n\t\t}\r\n\r\n\t\tif ( !xSteps[j-1] ){\r\n\t\t\treturn value;\r\n\t\t}\r\n\r\n\t\treturn xPct[j-1] + closest(\r\n\t\t\tvalue - xPct[j-1],\r\n\t\t\txSteps[j-1]\r\n\t\t);\r\n\t}\r\n\r\n\r\n// Entry parsing\r\n\r\n\tfunction handleEntryPoint ( index, value, that ) {\r\n\r\n\t\tvar percentage;\r\n\r\n\t\t// Wrap numerical input in an array.\r\n\t\tif ( typeof value === \"number\" ) {\r\n\t\t\tvalue = [value];\r\n\t\t}\r\n\r\n\t\t// Reject any invalid input, by testing whether value is an array.\r\n\t\tif ( Object.prototype.toString.call( value ) !== '[object Array]' ){\r\n\t\t\tthrow new Error(\"noUiSlider: 'range' contains invalid value.\");\r\n\t\t}\r\n\r\n\t\t// Covert min/max syntax to 0 and 100.\r\n\t\tif ( index === 'min' ) {\r\n\t\t\tpercentage = 0;\r\n\t\t} else if ( index === 'max' ) {\r\n\t\t\tpercentage = 100;\r\n\t\t} else {\r\n\t\t\tpercentage = parseFloat( index );\r\n\t\t}\r\n\r\n\t\t// Check for correct input.\r\n\t\tif ( !isNumeric( percentage ) || !isNumeric( value[0] ) ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'range' value isn't numeric.\");\r\n\t\t}\r\n\r\n\t\t// Store values.\r\n\t\tthat.xPct.push( percentage );\r\n\t\tthat.xVal.push( value[0] );\r\n\r\n\t\t// NaN will evaluate to false too, but to keep\r\n\t\t// logging clear, set step explicitly. Make sure\r\n\t\t// not to override the 'step' setting with false.\r\n\t\tif ( !percentage ) {\r\n\t\t\tif ( !isNaN( value[1] ) ) {\r\n\t\t\t\tthat.xSteps[0] = value[1];\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tthat.xSteps.push( isNaN(value[1]) ? false : value[1] );\r\n\t\t}\r\n\t}\r\n\r\n\tfunction handleStepPoint ( i, n, that ) {\r\n\r\n\t\t// Ignore 'false' stepping.\r\n\t\tif ( !n ) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\r\n\t\t// Factor to range ratio\r\n\t\tthat.xSteps[i] = fromPercentage([\r\n\t\t\t that.xVal[i]\r\n\t\t\t,that.xVal[i+1]\r\n\t\t], n) / subRangeRatio (\r\n\t\t\tthat.xPct[i],\r\n\t\t\tthat.xPct[i+1] );\r\n\t}\r\n\r\n\r\n// Interface\r\n\r\n\t// The interface to Spectrum handles all direction-based\r\n\t// conversions, so the above values are unaware.\r\n\r\n\tfunction Spectrum ( entry, snap, direction, singleStep ) {\r\n\r\n\t\tthis.xPct = [];\r\n\t\tthis.xVal = [];\r\n\t\tthis.xSteps = [ singleStep || false ];\r\n\t\tthis.xNumSteps = [ false ];\r\n\r\n\t\tthis.snap = snap;\r\n\t\tthis.direction = direction;\r\n\r\n\t\tvar index, ordered = [ /* [0, 'min'], [1, '50%'], [2, 'max'] */ ];\r\n\r\n\t\t// Map the object keys to an array.\r\n\t\tfor ( index in entry ) {\r\n\t\t\tif ( entry.hasOwnProperty(index) ) {\r\n\t\t\t\tordered.push([entry[index], index]);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Sort all entries by value (numeric sort).\r\n\t\tif ( ordered.length && typeof ordered[0][0] === \"object\" ) {\r\n\t\t\tordered.sort(function(a, b) { return a[0][0] - b[0][0]; });\r\n\t\t} else {\r\n\t\t\tordered.sort(function(a, b) { return a[0] - b[0]; });\r\n\t\t}\r\n\r\n\r\n\t\t// Convert all entries to subranges.\r\n\t\tfor ( index = 0; index < ordered.length; index++ ) {\r\n\t\t\thandleEntryPoint(ordered[index][1], ordered[index][0], this);\r\n\t\t}\r\n\r\n\t\t// Store the actual step values.\r\n\t\t// xSteps is sorted in the same order as xPct and xVal.\r\n\t\tthis.xNumSteps = this.xSteps.slice(0);\r\n\r\n\t\t// Convert all numeric steps to the percentage of the subrange they represent.\r\n\t\tfor ( index = 0; index < this.xNumSteps.length; index++ ) {\r\n\t\t\thandleStepPoint(index, this.xNumSteps[index], this);\r\n\t\t}\r\n\t}\r\n\r\n\tSpectrum.prototype.getMargin = function ( value ) {\r\n\t\treturn this.xPct.length === 2 ? fromPercentage(this.xVal, value) : false;\r\n\t};\r\n\r\n\tSpectrum.prototype.toStepping = function ( value ) {\r\n\r\n\t\tvalue = toStepping( this.xVal, this.xPct, value );\r\n\r\n\t\t// Invert the value if this is a right-to-left slider.\r\n\t\tif ( this.direction ) {\r\n\t\t\tvalue = 100 - value;\r\n\t\t}\r\n\r\n\t\treturn value;\r\n\t};\r\n\r\n\tSpectrum.prototype.fromStepping = function ( value ) {\r\n\r\n\t\t// Invert the value if this is a right-to-left slider.\r\n\t\tif ( this.direction ) {\r\n\t\t\tvalue = 100 - value;\r\n\t\t}\r\n\r\n\t\treturn fromStepping( this.xVal, this.xPct, value );\r\n\t};\r\n\r\n\tSpectrum.prototype.getStep = function ( value ) {\r\n\r\n\t\t// Find the proper step for rtl sliders by search in inverse direction.\r\n\t\t// Fixes issue #262.\r\n\t\tif ( this.direction ) {\r\n\t\t\tvalue = 100 - value;\r\n\t\t}\r\n\r\n\t\tvalue = getStep(this.xPct, this.xSteps, this.snap, value );\r\n\r\n\t\tif ( this.direction ) {\r\n\t\t\tvalue = 100 - value;\r\n\t\t}\r\n\r\n\t\treturn value;\r\n\t};\r\n\r\n\tSpectrum.prototype.getApplicableStep = function ( value ) {\r\n\r\n\t\t// If the value is 100%, return the negative step twice.\r\n\t\tvar j = getJ(value, this.xPct), offset = value === 100 ? 2 : 1;\r\n\t\treturn [this.xNumSteps[j-2], this.xVal[j-offset], this.xNumSteps[j-offset]];\r\n\t};\r\n\r\n\t// Outside testing\r\n\tSpectrum.prototype.convert = function ( value ) {\r\n\t\treturn this.getStep(this.toStepping(value));\r\n\t};\r\n\r\n/*\tEvery input option is tested and parsed. This'll prevent\r\n\tendless validation in internal methods. These tests are\r\n\tstructured with an item for every option available. An\r\n\toption can be marked as required by setting the 'r' flag.\r\n\tThe testing function is provided with three arguments:\r\n\t\t- The provided value for the option;\r\n\t\t- A reference to the options object;\r\n\t\t- The name for the option;\r\n\r\n\tThe testing function returns false when an error is detected,\r\n\tor true when everything is OK. It can also modify the option\r\n\tobject, to make sure all values can be correctly looped elsewhere. */\r\n\r\n\tvar defaultFormatter = { 'to': function( value ){\r\n\t\treturn value !== undefined && value.toFixed(2);\r\n\t}, 'from': Number };\r\n\r\n\tfunction testStep ( parsed, entry ) {\r\n\r\n\t\tif ( !isNumeric( entry ) ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'step' is not numeric.\");\r\n\t\t}\r\n\r\n\t\t// The step option can still be used to set stepping\r\n\t\t// for linear sliders. Overwritten if set in 'range'.\r\n\t\tparsed.singleStep = entry;\r\n\t}\r\n\r\n\tfunction testRange ( parsed, entry ) {\r\n\r\n\t\t// Filter incorrect input.\r\n\t\tif ( typeof entry !== 'object' || Array.isArray(entry) ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'range' is not an object.\");\r\n\t\t}\r\n\r\n\t\t// Catch missing start or end.\r\n\t\tif ( entry.min === undefined || entry.max === undefined ) {\r\n\t\t\tthrow new Error(\"noUiSlider: Missing 'min' or 'max' in 'range'.\");\r\n\t\t}\r\n\r\n\t\t// Catch equal start or end.\r\n\t\tif ( entry.min === entry.max ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'range' 'min' and 'max' cannot be equal.\");\r\n\t\t}\r\n\r\n\t\tparsed.spectrum = new Spectrum(entry, parsed.snap, parsed.dir, parsed.singleStep);\r\n\t}\r\n\r\n\tfunction testStart ( parsed, entry ) {\r\n\r\n\t\tentry = asArray(entry);\r\n\r\n\t\t// Validate input. Values aren't tested, as the public .val method\r\n\t\t// will always provide a valid location.\r\n\t\tif ( !Array.isArray( entry ) || !entry.length || entry.length > 2 ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'start' option is incorrect.\");\r\n\t\t}\r\n\r\n\t\t// Store the number of handles.\r\n\t\tparsed.handles = entry.length;\r\n\r\n\t\t// When the slider is initialized, the .val method will\r\n\t\t// be called with the start options.\r\n\t\tparsed.start = entry;\r\n\t}\r\n\r\n\tfunction testSnap ( parsed, entry ) {\r\n\r\n\t\t// Enforce 100% stepping within subranges.\r\n\t\tparsed.snap = entry;\r\n\r\n\t\tif ( typeof entry !== 'boolean' ){\r\n\t\t\tthrow new Error(\"noUiSlider: 'snap' option must be a boolean.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testAnimate ( parsed, entry ) {\r\n\r\n\t\t// Enforce 100% stepping within subranges.\r\n\t\tparsed.animate = entry;\r\n\r\n\t\tif ( typeof entry !== 'boolean' ){\r\n\t\t\tthrow new Error(\"noUiSlider: 'animate' option must be a boolean.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testAnimationDuration ( parsed, entry ) {\r\n\r\n\t\tparsed.animationDuration = entry;\r\n\r\n\t\tif ( typeof entry !== 'number' ){\r\n\t\t\tthrow new Error(\"noUiSlider: 'animationDuration' option must be a number.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testConnect ( parsed, entry ) {\r\n\r\n\t\tif ( entry === 'lower' && parsed.handles === 1 ) {\r\n\t\t\tparsed.connect = 1;\r\n\t\t} else if ( entry === 'upper' && parsed.handles === 1 ) {\r\n\t\t\tparsed.connect = 2;\r\n\t\t} else if ( entry === true && parsed.handles === 2 ) {\r\n\t\t\tparsed.connect = 3;\r\n\t\t} else if ( entry === false ) {\r\n\t\t\tparsed.connect = 0;\r\n\t\t} else {\r\n\t\t\tthrow new Error(\"noUiSlider: 'connect' option doesn't match handle count.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testOrientation ( parsed, entry ) {\r\n\r\n\t\t// Set orientation to an a numerical value for easy\r\n\t\t// array selection.\r\n\t\tswitch ( entry ){\r\n\t\t case 'horizontal':\r\n\t\t\tparsed.ort = 0;\r\n\t\t\tbreak;\r\n\t\t case 'vertical':\r\n\t\t\tparsed.ort = 1;\r\n\t\t\tbreak;\r\n\t\t default:\r\n\t\t\tthrow new Error(\"noUiSlider: 'orientation' option is invalid.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testMargin ( parsed, entry ) {\r\n\r\n\t\tif ( !isNumeric(entry) ){\r\n\t\t\tthrow new Error(\"noUiSlider: 'margin' option must be numeric.\");\r\n\t\t}\r\n\r\n\t\t// Issue #582\r\n\t\tif ( entry === 0 ) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tparsed.margin = parsed.spectrum.getMargin(entry);\r\n\r\n\t\tif ( !parsed.margin ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'margin' option is only supported on linear sliders.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testLimit ( parsed, entry ) {\r\n\r\n\t\tif ( !isNumeric(entry) ){\r\n\t\t\tthrow new Error(\"noUiSlider: 'limit' option must be numeric.\");\r\n\t\t}\r\n\r\n\t\tparsed.limit = parsed.spectrum.getMargin(entry);\r\n\r\n\t\tif ( !parsed.limit ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'limit' option is only supported on linear sliders.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testDirection ( parsed, entry ) {\r\n\r\n\t\t// Set direction as a numerical value for easy parsing.\r\n\t\t// Invert connection for RTL sliders, so that the proper\r\n\t\t// handles get the connect/background classes.\r\n\t\tswitch ( entry ) {\r\n\t\t case 'ltr':\r\n\t\t\tparsed.dir = 0;\r\n\t\t\tbreak;\r\n\t\t case 'rtl':\r\n\t\t\tparsed.dir = 1;\r\n\t\t\tparsed.connect = [0,2,1,3][parsed.connect];\r\n\t\t\tbreak;\r\n\t\t default:\r\n\t\t\tthrow new Error(\"noUiSlider: 'direction' option was not recognized.\");\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testBehaviour ( parsed, entry ) {\r\n\r\n\t\t// Make sure the input is a string.\r\n\t\tif ( typeof entry !== 'string' ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'behaviour' must be a string containing options.\");\r\n\t\t}\r\n\r\n\t\t// Check if the string contains any keywords.\r\n\t\t// None are required.\r\n\t\tvar tap = entry.indexOf('tap') >= 0,\r\n\t\t\tdrag = entry.indexOf('drag') >= 0,\r\n\t\t\tfixed = entry.indexOf('fixed') >= 0,\r\n\t\t\tsnap = entry.indexOf('snap') >= 0,\r\n\t\t\thover = entry.indexOf('hover') >= 0;\r\n\r\n\t\t// Fix #472\r\n\t\tif ( drag && !parsed.connect ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'drag' behaviour must be used with 'connect': true.\");\r\n\t\t}\r\n\r\n\t\tparsed.events = {\r\n\t\t\ttap: tap || snap,\r\n\t\t\tdrag: drag,\r\n\t\t\tfixed: fixed,\r\n\t\t\tsnap: snap,\r\n\t\t\thover: hover\r\n\t\t};\r\n\t}\r\n\r\n\tfunction testTooltips ( parsed, entry ) {\r\n\r\n\t\tvar i;\r\n\r\n\t\tif ( entry === false ) {\r\n\t\t\treturn;\r\n\t\t} else if ( entry === true ) {\r\n\r\n\t\t\tparsed.tooltips = [];\r\n\r\n\t\t\tfor ( i = 0; i < parsed.handles; i++ ) {\r\n\t\t\t\tparsed.tooltips.push(true);\r\n\t\t\t}\r\n\r\n\t\t} else {\r\n\r\n\t\t\tparsed.tooltips = asArray(entry);\r\n\r\n\t\t\tif ( parsed.tooltips.length !== parsed.handles ) {\r\n\t\t\t\tthrow new Error(\"noUiSlider: must pass a formatter for all handles.\");\r\n\t\t\t}\r\n\r\n\t\t\tparsed.tooltips.forEach(function(formatter){\r\n\t\t\t\tif ( typeof formatter !== 'boolean' && (typeof formatter !== 'object' || typeof formatter.to !== 'function') ) {\r\n\t\t\t\t\tthrow new Error(\"noUiSlider: 'tooltips' must be passed a formatter or 'false'.\");\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tfunction testFormat ( parsed, entry ) {\r\n\r\n\t\tparsed.format = entry;\r\n\r\n\t\t// Any object with a to and from method is supported.\r\n\t\tif ( typeof entry.to === 'function' && typeof entry.from === 'function' ) {\r\n\t\t\treturn true;\r\n\t\t}\r\n\r\n\t\tthrow new Error(\"noUiSlider: 'format' requires 'to' and 'from' methods.\");\r\n\t}\r\n\r\n\tfunction testCssPrefix ( parsed, entry ) {\r\n\r\n\t\tif ( entry !== undefined && typeof entry !== 'string' && entry !== false ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'cssPrefix' must be a string or `false`.\");\r\n\t\t}\r\n\r\n\t\tparsed.cssPrefix = entry;\r\n\t}\r\n\r\n\tfunction testCssClasses ( parsed, entry ) {\r\n\r\n\t\tif ( entry !== undefined && typeof entry !== 'object' ) {\r\n\t\t\tthrow new Error(\"noUiSlider: 'cssClasses' must be an object.\");\r\n\t\t}\r\n\r\n\t\tif ( typeof parsed.cssPrefix === 'string' ) {\r\n\t\t\tparsed.cssClasses = {};\r\n\r\n\t\t\tfor ( var key in entry ) {\r\n\t\t\t\tif ( !entry.hasOwnProperty(key) ) { continue; }\r\n\r\n\t\t\t\tparsed.cssClasses[key] = parsed.cssPrefix + entry[key];\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tparsed.cssClasses = entry;\r\n\t\t}\r\n\t}\r\n\r\n\t// Test all developer settings and parse to assumption-safe values.\r\n\tfunction testOptions ( options ) {\r\n\r\n\t\t// To prove a fix for #537, freeze options here.\r\n\t\t// If the object is modified, an error will be thrown.\r\n\t\t// Object.freeze(options);\r\n\r\n\t\tvar parsed = {\r\n\t\t\tmargin: 0,\r\n\t\t\tlimit: 0,\r\n\t\t\tanimate: true,\r\n\t\t\tanimationDuration: 300,\r\n\t\t\tformat: defaultFormatter\r\n\t\t}, tests;\r\n\r\n\t\t// Tests are executed in the order they are presented here.\r\n\t\ttests = {\r\n\t\t\t'step': { r: false, t: testStep },\r\n\t\t\t'start': { r: true, t: testStart },\r\n\t\t\t'connect': { r: true, t: testConnect },\r\n\t\t\t'direction': { r: true, t: testDirection },\r\n\t\t\t'snap': { r: false, t: testSnap },\r\n\t\t\t'animate': { r: false, t: testAnimate },\r\n\t\t\t'animationDuration': { r: false, t: testAnimationDuration },\r\n\t\t\t'range': { r: true, t: testRange },\r\n\t\t\t'orientation': { r: false, t: testOrientation },\r\n\t\t\t'margin': { r: false, t: testMargin },\r\n\t\t\t'limit': { r: false, t: testLimit },\r\n\t\t\t'behaviour': { r: true, t: testBehaviour },\r\n\t\t\t'format': { r: false, t: testFormat },\r\n\t\t\t'tooltips': { r: false, t: testTooltips },\r\n\t\t\t'cssPrefix': { r: false, t: testCssPrefix },\r\n\t\t\t'cssClasses': { r: false, t: testCssClasses }\r\n\t\t};\r\n\r\n\t\tvar defaults = {\r\n\t\t\t'connect': false,\r\n\t\t\t'direction': 'ltr',\r\n\t\t\t'behaviour': 'tap',\r\n\t\t\t'orientation': 'horizontal',\r\n\t\t\t'cssPrefix' : 'noUi-',\r\n\t\t\t'cssClasses': {\r\n\t\t\t\ttarget: 'target',\r\n\t\t\t\tbase: 'base',\r\n\t\t\t\torigin: 'origin',\r\n\t\t\t\thandle: 'handle',\r\n\t\t\t\thandleLower: 'handle-lower',\r\n\t\t\t\thandleUpper: 'handle-upper',\r\n\t\t\t\thorizontal: 'horizontal',\r\n\t\t\t\tvertical: 'vertical',\r\n\t\t\t\tbackground: 'background',\r\n\t\t\t\tconnect: 'connect',\r\n\t\t\t\tltr: 'ltr',\r\n\t\t\t\trtl: 'rtl',\r\n\t\t\t\tdraggable: 'draggable',\r\n\t\t\t\tdrag: 'state-drag',\r\n\t\t\t\ttap: 'state-tap',\r\n\t\t\t\tactive: 'active',\r\n\t\t\t\tstacking: 'stacking',\r\n\t\t\t\ttooltip: 'tooltip',\r\n\t\t\t\tpips: 'pips',\r\n\t\t\t\tpipsHorizontal: 'pips-horizontal',\r\n\t\t\t\tpipsVertical: 'pips-vertical',\r\n\t\t\t\tmarker: 'marker',\r\n\t\t\t\tmarkerHorizontal: 'marker-horizontal',\r\n\t\t\t\tmarkerVertical: 'marker-vertical',\r\n\t\t\t\tmarkerNormal: 'marker-normal',\r\n\t\t\t\tmarkerLarge: 'marker-large',\r\n\t\t\t\tmarkerSub: 'marker-sub',\r\n\t\t\t\tvalue: 'value',\r\n\t\t\t\tvalueHorizontal: 'value-horizontal',\r\n\t\t\t\tvalueVertical: 'value-vertical',\r\n\t\t\t\tvalueNormal: 'value-normal',\r\n\t\t\t\tvalueLarge: 'value-large',\r\n\t\t\t\tvalueSub: 'value-sub'\r\n\t\t\t}\r\n\t\t};\r\n\r\n\t\t// Run all options through a testing mechanism to ensure correct\r\n\t\t// input. It should be noted that options might get modified to\r\n\t\t// be handled properly. E.g. wrapping integers in arrays.\r\n\t\tObject.keys(tests).forEach(function( name ){\r\n\r\n\t\t\t// If the option isn't set, but it is required, throw an error.\r\n\t\t\tif ( options[name] === undefined && defaults[name] === undefined ) {\r\n\r\n\t\t\t\tif ( tests[name].r ) {\r\n\t\t\t\t\tthrow new Error(\"noUiSlider: '\" + name + \"' is required.\");\r\n\t\t\t\t}\r\n\r\n\t\t\t\treturn true;\r\n\t\t\t}\r\n\r\n\t\t\ttests[name].t( parsed, options[name] === undefined ? defaults[name] : options[name] );\r\n\t\t});\r\n\r\n\t\t// Forward pips options\r\n\t\tparsed.pips = options.pips;\r\n\r\n\t\t// Pre-define the styles.\r\n\t\tparsed.style = parsed.ort ? 'top' : 'left';\r\n\r\n\t\treturn parsed;\r\n\t}\r\n\r\n\r\nfunction closure ( target, options, originalOptions ){\r\n\tvar\r\n\t\tactions = getActions( ),\r\n\t\t// All variables local to 'closure' are prefixed with 'scope_'\r\n\t\tscope_Target = target,\r\n\t\tscope_Locations = [-1, -1],\r\n\t\tscope_Base,\r\n\t\tscope_Handles,\r\n\t\tscope_Spectrum = options.spectrum,\r\n\t\tscope_Values = [],\r\n\t\tscope_Events = {},\r\n\t\tscope_Self;\r\n\r\n\r\n\t// Delimit proposed values for handle positions.\r\n\tfunction getPositions ( a, b, delimit ) {\r\n\r\n\t\t// Add movement to current position.\r\n\t\tvar c = a + b[0], d = a + b[1];\r\n\r\n\t\t// Only alter the other position on drag,\r\n\t\t// not on standard sliding.\r\n\t\tif ( delimit ) {\r\n\t\t\tif ( c < 0 ) {\r\n\t\t\t\td += Math.abs(c);\r\n\t\t\t}\r\n\t\t\tif ( d > 100 ) {\r\n\t\t\t\tc -= ( d - 100 );\r\n\t\t\t}\r\n\r\n\t\t\t// Limit values to 0 and 100.\r\n\t\t\treturn [limit(c), limit(d)];\r\n\t\t}\r\n\r\n\t\treturn [c,d];\r\n\t}\r\n\r\n\t// Provide a clean event with standardized offset values.\r\n\tfunction fixEvent ( e, pageOffset ) {\r\n\r\n\t\t// Prevent scrolling and panning on touch events, while\r\n\t\t// attempting to slide. The tap event also depends on this.\r\n\t\te.preventDefault();\r\n\r\n\t\t// Filter the event to register the type, which can be\r\n\t\t// touch, mouse or pointer. Offset changes need to be\r\n\t\t// made on an event specific basis.\r\n\t\tvar touch = e.type.indexOf('touch') === 0,\r\n\t\t\tmouse = e.type.indexOf('mouse') === 0,\r\n\t\t\tpointer = e.type.indexOf('pointer') === 0,\r\n\t\t\tx,y, event = e;\r\n\r\n\t\t// IE10 implemented pointer events with a prefix;\r\n\t\tif ( e.type.indexOf('MSPointer') === 0 ) {\r\n\t\t\tpointer = true;\r\n\t\t}\r\n\r\n\t\tif ( touch ) {\r\n\t\t\t// noUiSlider supports one movement at a time,\r\n\t\t\t// so we can select the first 'changedTouch'.\r\n\t\t\tx = e.changedTouches[0].pageX;\r\n\t\t\ty = e.changedTouches[0].pageY;\r\n\t\t}\r\n\r\n\t\tpageOffset = pageOffset || getPageOffset();\r\n\r\n\t\tif ( mouse || pointer ) {\r\n\t\t\tx = e.clientX + pageOffset.x;\r\n\t\t\ty = e.clientY + pageOffset.y;\r\n\t\t}\r\n\r\n\t\tevent.pageOffset = pageOffset;\r\n\t\tevent.points = [x, y];\r\n\t\tevent.cursor = mouse || pointer; // Fix #435\r\n\r\n\t\treturn event;\r\n\t}\r\n\r\n\t// Append a handle to the base.\r\n\tfunction addHandle ( direction, index ) {\r\n\r\n\t\tvar origin = document.createElement('div'),\r\n\t\t\thandle = document.createElement('div'),\r\n\t\t\tclassModifier = [options.cssClasses.handleLower, options.cssClasses.handleUpper];\r\n\r\n\t\tif ( direction ) {\r\n\t\t\tclassModifier.reverse();\r\n\t\t}\r\n\r\n\t\taddClass(handle, options.cssClasses.handle);\r\n\t\taddClass(handle, classModifier[index]);\r\n\r\n\t\taddClass(origin, options.cssClasses.origin);\r\n\t\torigin.appendChild(handle);\r\n\r\n\t\treturn origin;\r\n\t}\r\n\r\n\t// Add the proper connection classes.\r\n\tfunction addConnection ( connect, target, handles ) {\r\n\r\n\t\t// Apply the required connection classes to the elements\r\n\t\t// that need them. Some classes are made up for several\r\n\t\t// segments listed in the class list, to allow easy\r\n\t\t// renaming and provide a minor compression benefit.\r\n\t\tswitch ( connect ) {\r\n\t\t\tcase 1:\taddClass(target, options.cssClasses.connect);\r\n\t\t\t\t\taddClass(handles[0], options.cssClasses.background);\r\n\t\t\t\t\tbreak;\r\n\t\t\tcase 3: addClass(handles[1], options.cssClasses.background);\r\n\t\t\t\t\t/* falls through */\r\n\t\t\tcase 2: addClass(handles[0], options.cssClasses.connect);\r\n\t\t\t\t\t/* falls through */\r\n\t\t\tcase 0: addClass(target, options.cssClasses.background);\r\n\t\t\t\t\tbreak;\r\n\t\t}\r\n\t}\r\n\r\n\t// Add handles to the slider base.\r\n\tfunction addHandles ( nrHandles, direction, base ) {\r\n\r\n\t\tvar index, handles = [];\r\n\r\n\t\t// Append handles.\r\n\t\tfor ( index = 0; index < nrHandles; index += 1 ) {\r\n\r\n\t\t\t// Keep a list of all added handles.\r\n\t\t\thandles.push( base.appendChild(addHandle( direction, index )) );\r\n\t\t}\r\n\r\n\t\treturn handles;\r\n\t}\r\n\r\n\t// Initialize a single slider.\r\n\tfunction addSlider ( direction, orientation, target ) {\r\n\r\n\t\t// Apply classes and data to the target.\r\n\t\taddClass(target, options.cssClasses.target);\r\n\r\n\t\tif ( direction === 0 ) {\r\n\t\t\taddClass(target, options.cssClasses.ltr);\r\n\t\t} else {\r\n\t\t\taddClass(target, options.cssClasses.rtl);\r\n\t\t}\r\n\r\n\t\tif ( orientation === 0 ) {\r\n\t\t\taddClass(target, options.cssClasses.horizontal);\r\n\t\t} else {\r\n\t\t\taddClass(target, options.cssClasses.vertical);\r\n\t\t}\r\n\r\n\t\tvar div = document.createElement('div');\r\n\t\taddClass(div, options.cssClasses.base);\r\n\t\ttarget.appendChild(div);\r\n\t\treturn div;\r\n\t}\r\n\r\n\r\n\tfunction addTooltip ( handle, index ) {\r\n\r\n\t\tif ( !options.tooltips[index] ) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\tvar element = document.createElement('div');\r\n\t\telement.className = options.cssClasses.tooltip;\r\n\t\treturn handle.firstChild.appendChild(element);\r\n\t}\r\n\r\n\t// The tooltips option is a shorthand for using the 'update' event.\r\n\tfunction tooltips ( ) {\r\n\r\n\t\tif ( options.dir ) {\r\n\t\t\toptions.tooltips.reverse();\r\n\t\t}\r\n\r\n\t\t// Tooltips are added with options.tooltips in original order.\r\n\t\tvar tips = scope_Handles.map(addTooltip);\r\n\r\n\t\tif ( options.dir ) {\r\n\t\t\ttips.reverse();\r\n\t\t\toptions.tooltips.reverse();\r\n\t\t}\r\n\r\n\t\tbindEvent('update', function(f, o, r) {\r\n\t\t\tif ( tips[o] ) {\r\n\t\t\t\ttips[o].innerHTML = options.tooltips[o] === true ? f[o] : options.tooltips[o].to(r[o]);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\r\n\tfunction getGroup ( mode, values, stepped ) {\r\n\r\n\t\t// Use the range.\r\n\t\tif ( mode === 'range' || mode === 'steps' ) {\r\n\t\t\treturn scope_Spectrum.xVal;\r\n\t\t}\r\n\r\n\t\tif ( mode === 'count' ) {\r\n\r\n\t\t\t// Divide 0 - 100 in 'count' parts.\r\n\t\t\tvar spread = ( 100 / (values-1) ), v, i = 0;\r\n\t\t\tvalues = [];\r\n\r\n\t\t\t// List these parts and have them handled as 'positions'.\r\n\t\t\twhile ((v=i++*spread) <= 100 ) {\r\n\t\t\t\tvalues.push(v);\r\n\t\t\t}\r\n\r\n\t\t\tmode = 'positions';\r\n\t\t}\r\n\r\n\t\tif ( mode === 'positions' ) {\r\n\r\n\t\t\t// Map all percentages to on-range values.\r\n\t\t\treturn values.map(function( value ){\r\n\t\t\t\treturn scope_Spectrum.fromStepping( stepped ? scope_Spectrum.getStep( value ) : value );\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\tif ( mode === 'values' ) {\r\n\r\n\t\t\t// If the value must be stepped, it needs to be converted to a percentage first.\r\n\t\t\tif ( stepped ) {\r\n\r\n\t\t\t\treturn values.map(function( value ){\r\n\r\n\t\t\t\t\t// Convert to percentage, apply step, return to value.\r\n\t\t\t\t\treturn scope_Spectrum.fromStepping( scope_Spectrum.getStep( scope_Spectrum.toStepping( value ) ) );\r\n\t\t\t\t});\r\n\r\n\t\t\t}\r\n\r\n\t\t\t// Otherwise, we can simply use the values.\r\n\t\t\treturn values;\r\n\t\t}\r\n\t}\r\n\r\n\tfunction generateSpread ( density, mode, group ) {\r\n\r\n\t\tfunction safeIncrement(value, increment) {\r\n\t\t\t// Avoid floating point variance by dropping the smallest decimal places.\r\n\t\t\treturn (value + increment).toFixed(7) / 1;\r\n\t\t}\r\n\r\n\t\tvar originalSpectrumDirection = scope_Spectrum.direction,\r\n\t\t\tindexes = {},\r\n\t\t\tfirstInRange = scope_Spectrum.xVal[0],\r\n\t\t\tlastInRange = scope_Spectrum.xVal[scope_Spectrum.xVal.length-1],\r\n\t\t\tignoreFirst = false,\r\n\t\t\tignoreLast = false,\r\n\t\t\tprevPct = 0;\r\n\r\n\t\t// This function loops the spectrum in an ltr linear fashion,\r\n\t\t// while the toStepping method is direction aware. Trick it into\r\n\t\t// believing it is ltr.\r\n\t\tscope_Spectrum.direction = 0;\r\n\r\n\t\t// Create a copy of the group, sort it and filter away all duplicates.\r\n\t\tgroup = unique(group.slice().sort(function(a, b){ return a - b; }));\r\n\r\n\t\t// Make sure the range starts with the first element.\r\n\t\tif ( group[0] !== firstInRange ) {\r\n\t\t\tgroup.unshift(firstInRange);\r\n\t\t\tignoreFirst = true;\r\n\t\t}\r\n\r\n\t\t// Likewise for the last one.\r\n\t\tif ( group[group.length - 1] !== lastInRange ) {\r\n\t\t\tgroup.push(lastInRange);\r\n\t\t\tignoreLast = true;\r\n\t\t}\r\n\r\n\t\tgroup.forEach(function ( current, index ) {\r\n\r\n\t\t\t// Get the current step and the lower + upper positions.\r\n\t\t\tvar step, i, q,\r\n\t\t\t\tlow = current,\r\n\t\t\t\thigh = group[index+1],\r\n\t\t\t\tnewPct, pctDifference, pctPos, type,\r\n\t\t\t\tsteps, realSteps, stepsize;\r\n\r\n\t\t\t// When using 'steps' mode, use the provided steps.\r\n\t\t\t// Otherwise, we'll step on to the next subrange.\r\n\t\t\tif ( mode === 'steps' ) {\r\n\t\t\t\tstep = scope_Spectrum.xNumSteps[ index ];\r\n\t\t\t}\r\n\r\n\t\t\t// Default to a 'full' step.\r\n\t\t\tif ( !step ) {\r\n\t\t\t\tstep = high-low;\r\n\t\t\t}\r\n\r\n\t\t\t// Low can be 0, so test for false. If high is undefined,\r\n\t\t\t// we are at the last subrange. Index 0 is already handled.\r\n\t\t\tif ( low === false || high === undefined ) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\r\n\t\t\t// Find all steps in the subrange.\r\n\t\t\tfor ( i = low; i <= high; i = safeIncrement(i, step) ) {\r\n\r\n\t\t\t\t// Get the percentage value for the current step,\r\n\t\t\t\t// calculate the size for the subrange.\r\n\t\t\t\tnewPct = scope_Spectrum.toStepping( i );\r\n\t\t\t\tpctDifference = newPct - prevPct;\r\n\r\n\t\t\t\tsteps = pctDifference / density;\r\n\t\t\t\trealSteps = Math.round(steps);\r\n\r\n\t\t\t\t// This ratio represents the ammount of percentage-space a point indicates.\r\n\t\t\t\t// For a density 1 the points/percentage = 1. For density 2, that percentage needs to be re-devided.\r\n\t\t\t\t// Round the percentage offset to an even number, then divide by two\r\n\t\t\t\t// to spread the offset on both sides of the range.\r\n\t\t\t\tstepsize = pctDifference/realSteps;\r\n\r\n\t\t\t\t// Divide all points evenly, adding the correct number to this subrange.\r\n\t\t\t\t// Run up to <= so that 100% gets a point, event if ignoreLast is set.\r\n\t\t\t\tfor ( q = 1; q <= realSteps; q += 1 ) {\r\n\r\n\t\t\t\t\t// The ratio between the rounded value and the actual size might be ~1% off.\r\n\t\t\t\t\t// Correct the percentage offset by the number of points\r\n\t\t\t\t\t// per subrange. density = 1 will result in 100 points on the\r\n\t\t\t\t\t// full range, 2 for 50, 4 for 25, etc.\r\n\t\t\t\t\tpctPos = prevPct + ( q * stepsize );\r\n\t\t\t\t\tindexes[pctPos.toFixed(5)] = ['x', 0];\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// Determine the point type.\r\n\t\t\t\ttype = (group.indexOf(i) > -1) ? 1 : ( mode === 'steps' ? 2 : 0 );\r\n\r\n\t\t\t\t// Enforce the 'ignoreFirst' option by overwriting the type for 0.\r\n\t\t\t\tif ( !index && ignoreFirst ) {\r\n\t\t\t\t\ttype = 0;\r\n\t\t\t\t}\r\n\r\n\t\t\t\tif ( !(i === high && ignoreLast)) {\r\n\t\t\t\t\t// Mark the 'type' of this point. 0 = plain, 1 = real value, 2 = step value.\r\n\t\t\t\t\tindexes[newPct.toFixed(5)] = [i, type];\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// Update the percentage count.\r\n\t\t\t\tprevPct = newPct;\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\t// Reset the spectrum.\r\n\t\tscope_Spectrum.direction = originalSpectrumDirection;\r\n\r\n\t\treturn indexes;\r\n\t}\r\n\r\n\tfunction addMarking ( spread, filterFunc, formatter ) {\r\n\r\n\t\tvar element = document.createElement('div'),\r\n\t\t\tout = '',\r\n\t\t\tvalueSizeClasses = [\r\n\t\t\t\toptions.cssClasses.valueNormal,\r\n\t\t\t\toptions.cssClasses.valueLarge,\r\n\t\t\t\toptions.cssClasses.valueSub\r\n\t\t\t],\r\n\t\t\tmarkerSizeClasses = [\r\n\t\t\t\toptions.cssClasses.markerNormal,\r\n\t\t\t\toptions.cssClasses.markerLarge,\r\n\t\t\t\toptions.cssClasses.markerSub\r\n\t\t\t],\r\n\t\t\tvalueOrientationClasses = [\r\n\t\t\t\toptions.cssClasses.valueHorizontal,\r\n\t\t\t\toptions.cssClasses.valueVertical\r\n\t\t\t],\r\n\t\t\tmarkerOrientationClasses = [\r\n\t\t\t\toptions.cssClasses.markerHorizontal,\r\n\t\t\t\toptions.cssClasses.markerVertical\r\n\t\t\t];\r\n\r\n\t\taddClass(element, options.cssClasses.pips);\r\n\t\taddClass(element, options.ort === 0 ? options.cssClasses.pipsHorizontal : options.cssClasses.pipsVertical);\r\n\r\n\t\tfunction getClasses( type, source ){\r\n\t\t\tvar a = source === options.cssClasses.value,\r\n\t\t\t\torientationClasses = a ? valueOrientationClasses : markerOrientationClasses,\r\n\t\t\t\tsizeClasses = a ? valueSizeClasses : markerSizeClasses;\r\n\r\n\t\t\treturn source + ' ' + orientationClasses[options.ort] + ' ' + sizeClasses[type];\r\n\t\t}\r\n\r\n\t\tfunction getTags( offset, source, values ) {\r\n\t\t\treturn 'class=\"' + getClasses(values[1], source) + '\" style=\"' + options.style + ': ' + offset + '%\"';\r\n\t\t}\r\n\r\n\t\tfunction addSpread ( offset, values ){\r\n\r\n\t\t\tif ( scope_Spectrum.direction ) {\r\n\t\t\t\toffset = 100 - offset;\r\n\t\t\t}\r\n\r\n\t\t\t// Apply the filter function, if it is set.\r\n\t\t\tvalues[1] = (values[1] && filterFunc) ? filterFunc(values[0], values[1]) : values[1];\r\n\r\n\t\t\t// Add a marker for every point\r\n\t\t\tout += '<div ' + getTags(offset, options.cssClasses.marker, values) + '></div>';\r\n\r\n\t\t\t// Values are only appended for points marked '1' or '2'.\r\n\t\t\tif ( values[1] ) {\r\n\t\t\t\tout += '<div ' + getTags(offset, options.cssClasses.value, values) + '>' + formatter.to(values[0]) + '</div>';\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Append all points.\r\n\t\tObject.keys(spread).forEach(function(a){\r\n\t\t\taddSpread(a, spread[a]);\r\n\t\t});\r\n\r\n\t\telement.innerHTML = out;\r\n\r\n\t\treturn element;\r\n\t}\r\n\r\n\tfunction pips ( grid ) {\r\n\r\n\tvar mode = grid.mode,\r\n\t\tdensity = grid.density || 1,\r\n\t\tfilter = grid.filter || false,\r\n\t\tvalues = grid.values || false,\r\n\t\tstepped = grid.stepped || false,\r\n\t\tgroup = getGroup( mode, values, stepped ),\r\n\t\tspread = generateSpread( density, mode, group ),\r\n\t\tformat = grid.format || {\r\n\t\t\tto: Math.round\r\n\t\t};\r\n\r\n\t\treturn scope_Target.appendChild(addMarking(\r\n\t\t\tspread,\r\n\t\t\tfilter,\r\n\t\t\tformat\r\n\t\t));\r\n\t}\r\n\r\n\r\n\t// Shorthand for base dimensions.\r\n\tfunction baseSize ( ) {\r\n\t\tvar rect = scope_Base.getBoundingClientRect(), alt = 'offset' + ['Width', 'Height'][options.ort];\r\n\t\treturn options.ort === 0 ? (rect.width||scope_Base[alt]) : (rect.height||scope_Base[alt]);\r\n\t}\r\n\r\n\t// External event handling\r\n\tfunction fireEvent ( event, handleNumber, tap ) {\r\n\r\n\t\tvar i;\r\n\r\n\t\t// During initialization, do not fire events.\r\n\t\tfor ( i = 0; i < options.handles; i++ ) {\r\n\t\t\tif ( scope_Locations[i] === -1 ) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif ( handleNumber !== undefined && options.handles !== 1 ) {\r\n\t\t\thandleNumber = Math.abs(handleNumber - options.dir);\r\n\t\t}\r\n\r\n\t\tObject.keys(scope_Events).forEach(function( targetEvent ) {\r\n\r\n\t\t\tvar eventType = targetEvent.split('.')[0];\r\n\r\n\t\t\tif ( event === eventType ) {\r\n\t\t\t\tscope_Events[targetEvent].forEach(function( callback ) {\r\n\r\n\t\t\t\t\tcallback.call(\r\n\t\t\t\t\t\t// Use the slider public API as the scope ('this')\r\n\t\t\t\t\t\tscope_Self,\r\n\t\t\t\t\t\t// Return values as array, so arg_1[arg_2] is always valid.\r\n\t\t\t\t\t\tasArray(valueGet()),\r\n\t\t\t\t\t\t// Handle index, 0 or 1\r\n\t\t\t\t\t\thandleNumber,\r\n\t\t\t\t\t\t// Unformatted slider values\r\n\t\t\t\t\t\tasArray(inSliderOrder(Array.prototype.slice.call(scope_Values))),\r\n\t\t\t\t\t\t// Event is fired by tap, true or false\r\n\t\t\t\t\t\ttap || false,\r\n\t\t\t\t\t\t// Left offset of the handle, in relation to the slider\r\n\t\t\t\t\t\tscope_Locations\r\n\t\t\t\t\t);\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t// Returns the input array, respecting the slider direction configuration.\r\n\tfunction inSliderOrder ( values ) {\r\n\r\n\t\t// If only one handle is used, return a single value.\r\n\t\tif ( values.length === 1 ){\r\n\t\t\treturn values[0];\r\n\t\t}\r\n\r\n\t\tif ( options.dir ) {\r\n\t\t\treturn values.reverse();\r\n\t\t}\r\n\r\n\t\treturn values;\r\n\t}\r\n\r\n\r\n\t// Handler for attaching events trough a proxy.\r\n\tfunction attach ( events, element, callback, data ) {\r\n\r\n\t\t// This function can be used to 'filter' events to the slider.\r\n\t\t// element is a node, not a nodeList\r\n\r\n\t\tvar method = function ( e ){\r\n\r\n\t\t\tif ( scope_Target.hasAttribute('disabled') ) {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\r\n\t\t\t// Stop if an active 'tap' transition is taking place.\r\n\t\t\tif ( hasClass(scope_Target, options.cssClasses.tap) ) {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\r\n\t\t\te = fixEvent(e, data.pageOffset);\r\n\r\n\t\t\t// Ignore right or middle clicks on start #454\r\n\t\t\tif ( events === actions.start && e.buttons !== undefined && e.buttons > 1 ) {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\r\n\t\t\t// Ignore right or middle clicks on start #454\r\n\t\t\tif ( data.hover && e.buttons ) {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\r\n\t\t\te.calcPoint = e.points[ options.ort ];\r\n\r\n\t\t\t// Call the event handler with the event [ and additional data ].\r\n\t\t\tcallback ( e, data );\r\n\r\n\t\t}, methods = [];\r\n\r\n\t\t// Bind a closure on the target for every event type.\r\n\t\tevents.split(' ').forEach(function( eventName ){\r\n\t\t\telement.addEventListener(eventName, method, false);\r\n\t\t\tmethods.push([eventName, method]);\r\n\t\t});\r\n\r\n\t\treturn methods;\r\n\t}\r\n\r\n\t// Handle movement on document for handle and range drag.\r\n\tfunction move ( event, data ) {\r\n\r\n\t\t// Fix #498\r\n\t\t// Check value of .buttons in 'start' to work around a bug in IE10 mobile (data.buttonsProperty).\r\n\t\t// https://connect.microsoft.com/IE/feedback/details/927005/mobile-ie10-windows-phone-buttons-property-of-pointermove-event-always-zero\r\n\t\t// IE9 has .buttons and .which zero on mousemove.\r\n\t\t// Firefox breaks the spec MDN defines.\r\n\t\tif ( navigator.appVersion.indexOf(\"MSIE 9\") === -1 && event.buttons === 0 && data.buttonsProperty !== 0 ) {\r\n\t\t\treturn end(event, data);\r\n\t\t}\r\n\r\n\t\tvar handles = data.handles || scope_Handles, positions, state = false,\r\n\t\t\tproposal = ((event.calcPoint - data.start) * 100) / data.baseSize,\r\n\t\t\thandleNumber = handles[0] === scope_Handles[0] ? 0 : 1, i;\r\n\r\n\t\t// Calculate relative positions for the handles.\r\n\t\tpositions = getPositions( proposal, data.positions, handles.length > 1);\r\n\r\n\t\tstate = setHandle ( handles[0], positions[handleNumber], handles.length === 1 );\r\n\r\n\t\tif ( handles.length > 1 ) {\r\n\r\n\t\t\tstate = setHandle ( handles[1], positions[handleNumber?0:1], false ) || state;\r\n\r\n\t\t\tif ( state ) {\r\n\t\t\t\t// fire for both handles\r\n\t\t\t\tfor ( i = 0; i < data.handles.length; i++ ) {\r\n\t\t\t\t\tfireEvent('slide', i);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t} else if ( state ) {\r\n\t\t\t// Fire for a single handle\r\n\t\t\tfireEvent('slide', handleNumber);\r\n\t\t}\r\n\t}\r\n\r\n\t// Unbind move events on document, call callbacks.\r\n\tfunction end ( event, data ) {\r\n\r\n\t\t// The handle is no longer active, so remove the class.\r\n\t\tvar active = scope_Base.querySelector( '.' + options.cssClasses.active ),\r\n\t\t\thandleNumber = data.handles[0] === scope_Handles[0] ? 0 : 1;\r\n\r\n\t\tif ( active !== null ) {\r\n\t\t\tremoveClass(active, options.cssClasses.active);\r\n\t\t}\r\n\r\n\t\t// Remove cursor styles and text-selection events bound to the body.\r\n\t\tif ( event.cursor ) {\r\n\t\t\tdocument.body.style.cursor = '';\r\n\t\t\tdocument.body.removeEventListener('selectstart', document.body.noUiListener);\r\n\t\t}\r\n\r\n\t\tvar d = document.documentElement;\r\n\r\n\t\t// Unbind the move and end events, which are added on 'start'.\r\n\t\td.noUiListeners.forEach(function( c ) {\r\n\t\t\td.removeEventListener(c[0], c[1]);\r\n\t\t});\r\n\r\n\t\t// Remove dragging class.\r\n\t\tremoveClass(scope_Target, options.cssClasses.drag);\r\n\r\n\t\t// Fire the change and set events.\r\n\t\tfireEvent('set', handleNumber);\r\n\t\tfireEvent('change', handleNumber);\r\n\r\n\t\t// If this is a standard handle movement, fire the end event.\r\n\t\tif ( data.handleNumber !== undefined ) {\r\n\t\t\tfireEvent('end', data.handleNumber);\r\n\t\t}\r\n\t}\r\n\r\n\t// Fire 'end' when a mouse or pen leaves the document.\r\n\tfunction documentLeave ( event, data ) {\r\n\t\tif ( event.type === \"mouseout\" && event.target.nodeName === \"HTML\" && event.relatedTarget === null ){\r\n\t\t\tend ( event, data );\r\n\t\t}\r\n\t}\r\n\r\n\t// Bind move events on document.\r\n\tfunction start ( event, data ) {\r\n\r\n\t\tvar d = document.documentElement;\r\n\r\n\t\t// Mark the handle as 'active' so it can be styled.\r\n\t\tif ( data.handles.length === 1 ) {\r\n\t\t\t// Support 'disabled' handles\r\n\t\t\tif ( data.handles[0].hasAttribute('disabled') ) {\r\n\t\t\t\treturn false;\r\n\t\t\t}\r\n\r\n\t\t\taddClass(data.handles[0].children[0], options.cssClasses.active);\r\n\t\t}\r\n\r\n\t\t// Fix #551, where a handle gets selected instead of dragged.\r\n\t\tevent.preventDefault();\r\n\r\n\t\t// A drag should never propagate up to the 'tap' event.\r\n\t\tevent.stopPropagation();\r\n\r\n\t\t// Attach the move and end events.\r\n\t\tvar moveEvent = attach(actions.move, d, move, {\r\n\t\t\tstart: event.calcPoint,\r\n\t\t\tbaseSize: baseSize(),\r\n\t\t\tpageOffset: event.pageOffset,\r\n\t\t\thandles: data.handles,\r\n\t\t\thandleNumber: data.handleNumber,\r\n\t\t\tbuttonsProperty: event.buttons,\r\n\t\t\tpositions: [\r\n\t\t\t\tscope_Locations[0],\r\n\t\t\t\tscope_Locations[scope_Handles.length - 1]\r\n\t\t\t]\r\n\t\t}), endEvent = attach(actions.end, d, end, {\r\n\t\t\thandles: data.handles,\r\n\t\t\thandleNumber: data.handleNumber\r\n\t\t});\r\n\r\n\t\tvar outEvent = attach(\"mouseout\", d, documentLeave, {\r\n\t\t\thandles: data.handles,\r\n\t\t\thandleNumber: data.handleNumber\r\n\t\t});\r\n\r\n\t\td.noUiListeners = moveEvent.concat(endEvent, outEvent);\r\n\r\n\t\t// Text selection isn't an issue on touch devices,\r\n\t\t// so adding cursor styles can be skipped.\r\n\t\tif ( event.cursor ) {\r\n\r\n\t\t\t// Prevent the 'I' cursor and extend the range-drag cursor.\r\n\t\t\tdocument.body.style.cursor = getComputedStyle(event.target).cursor;\r\n\r\n\t\t\t// Mark the target with a dragging state.\r\n\t\t\tif ( scope_Handles.length > 1 ) {\r\n\t\t\t\taddClass(scope_Target, options.cssClasses.drag);\r\n\t\t\t}\r\n\r\n\t\t\tvar f = function(){\r\n\t\t\t\treturn false;\r\n\t\t\t};\r\n\r\n\t\t\tdocument.body.noUiListener = f;\r\n\r\n\t\t\t// Prevent text selection when dragging the handles.\r\n\t\t\tdocument.body.addEventListener('selectstart', f, false);\r\n\t\t}\r\n\r\n\t\tif ( data.handleNumber !== undefined ) {\r\n\t\t\tfireEvent('start', data.handleNumber);\r\n\t\t}\r\n\t}\r\n\r\n\t// Move closest handle to tapped location.\r\n\tfunction tap ( event ) {\r\n\r\n\t\tvar location = event.calcPoint, total = 0, handleNumber, to;\r\n\r\n\t\t// The tap event shouldn't propagate up and cause 'edge' to run.\r\n\t\tevent.stopPropagation();\r\n\r\n\t\t// Add up the handle offsets.\r\n\t\tscope_Handles.forEach(function(a){\r\n\t\t\ttotal += offset(a)[ options.style ];\r\n\t\t});\r\n\r\n\t\t// Find the handle closest to the tapped position.\r\n\t\thandleNumber = ( location < total/2 || scope_Handles.length === 1 ) ? 0 : 1;\r\n\r\n\t\t// Check if handler is not disablet if yes set number to the next handler\r\n\t\tif (scope_Handles[handleNumber].hasAttribute('disabled')) {\r\n\t\t\thandleNumber = handleNumber ? 0 : 1;\r\n\t\t}\r\n\r\n\t\tlocation -= offset(scope_Base)[ options.style ];\r\n\r\n\t\t// Calculate the new position.\r\n\t\tto = ( location * 100 ) / baseSize();\r\n\r\n\t\tif ( !options.events.snap ) {\r\n\t\t\t// Flag the slider as it is now in a transitional state.\r\n\t\t\t// Transition takes a configurable amount of ms (default 300). Re-enable the slider after that.\r\n\t\t\taddClassFor( scope_Target, options.cssClasses.tap, options.animationDuration );\r\n\t\t}\r\n\r\n\t\t// Support 'disabled' handles\r\n\t\tif ( scope_Handles[handleNumber].hasAttribute('disabled') ) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\t// Find the closest handle and calculate the tapped point.\r\n\t\t// The set handle to the new position.\r\n\t\tsetHandle( scope_Handles[handleNumber], to );\r\n\r\n\t\tfireEvent('slide', handleNumber, true);\r\n\t\tfireEvent('set', handleNumber, true);\r\n\t\tfireEvent('change', handleNumber, true);\r\n\r\n\t\tif ( options.events.snap ) {\r\n\t\t\tstart(event, { handles: [scope_Handles[handleNumber]] });\r\n\t\t}\r\n\t}\r\n\r\n\t// Fires a 'hover' event for a hovered mouse/pen position.\r\n\tfunction hover ( event ) {\r\n\r\n\t\tvar location = event.calcPoint - offset(scope_Base)[ options.style ],\r\n\t\t\tto = scope_Spectrum.getStep(( location * 100 ) / baseSize()),\r\n\t\t\tvalue = scope_Spectrum.fromStepping( to );\r\n\r\n\t\tObject.keys(scope_Events).forEach(function( targetEvent ) {\r\n\t\t\tif ( 'hover' === targetEvent.split('.')[0] ) {\r\n\t\t\t\tscope_Events[targetEvent].forEach(function( callback ) {\r\n\t\t\t\t\tcallback.call( scope_Self, value );\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t// Attach events to several slider parts.\r\n\tfunction events ( behaviour ) {\r\n\r\n\t\t// Attach the standard drag event to the handles.\r\n\t\tif ( !behaviour.fixed ) {\r\n\r\n\t\t\tscope_Handles.forEach(function( handle, index ){\r\n\r\n\t\t\t\t// These events are only bound to the visual handle\r\n\t\t\t\t// element, not the 'real' origin element.\r\n\t\t\t\tattach ( actions.start, handle.children[0], start, {\r\n\t\t\t\t\thandles: [ handle ],\r\n\t\t\t\t\thandleNumber: index\r\n\t\t\t\t});\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t// Attach the tap event to the slider base.\r\n\t\tif ( behaviour.tap ) {\r\n\r\n\t\t\tattach ( actions.start, scope_Base, tap, {\r\n\t\t\t\thandles: scope_Handles\r\n\t\t\t});\r\n\t\t}\r\n\r\n\t\t// Fire hover events\r\n\t\tif ( behaviour.hover ) {\r\n\t\t\tattach ( actions.move, scope_Base, hover, { hover: true } );\r\n\t\t}\r\n\r\n\t\t// Make the range draggable.\r\n\t\tif ( behaviour.drag ){\r\n\r\n\t\t\tvar drag = [scope_Base.querySelector( '.' + options.cssClasses.connect )];\r\n\t\t\taddClass(drag[0], options.cssClasses.draggable);\r\n\r\n\t\t\t// When the range is fixed, the entire range can\r\n\t\t\t// be dragged by the handles. The handle in the first\r\n\t\t\t// origin will propagate the start event upward,\r\n\t\t\t// but it needs to be bound manually on the other.\r\n\t\t\tif ( behaviour.fixed ) {\r\n\t\t\t\tdrag.push(scope_Handles[(drag[0] === scope_Handles[0] ? 1 : 0)].children[0]);\r\n\t\t\t}\r\n\r\n\t\t\tdrag.forEach(function( element ) {\r\n\t\t\t\tattach ( actions.start, element, start, {\r\n\t\t\t\t\thandles: scope_Handles\r\n\t\t\t\t});\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\r\n\t// Test suggested values and apply margin, step.\r\n\tfunction setHandle ( handle, to, noLimitOption ) {\r\n\r\n\t\tvar trigger = handle !== scope_Handles[0] ? 1 : 0,\r\n\t\t\tlowerMargin = scope_Locations[0] + options.margin,\r\n\t\t\tupperMargin = scope_Locations[1] - options.margin,\r\n\t\t\tlowerLimit = scope_Locations[0] + options.limit,\r\n\t\t\tupperLimit = scope_Locations[1] - options.limit;\r\n\r\n\t\t// For sliders with multiple handles,\r\n\t\t// limit movement to the other handle.\r\n\t\t// Apply the margin option by adding it to the handle positions.\r\n\t\tif ( scope_Handles.length > 1 ) {\r\n\t\t\tto = trigger ? Math.max( to, lowerMargin ) : Math.min( to, upperMargin );\r\n\t\t}\r\n\r\n\t\t// The limit option has the opposite effect, limiting handles to a\r\n\t\t// maximum distance from another. Limit must be > 0, as otherwise\r\n\t\t// handles would be unmoveable. 'noLimitOption' is set to 'false'\r\n\t\t// for the .val() method, except for pass 4/4.\r\n\t\tif ( noLimitOption !== false && options.limit && scope_Handles.length > 1 ) {\r\n\t\t\tto = trigger ? Math.min ( to, lowerLimit ) : Math.max( to, upperLimit );\r\n\t\t}\r\n\r\n\t\t// Handle the step option.\r\n\t\tto = scope_Spectrum.getStep( to );\r\n\r\n\t\t// Limit percentage to the 0 - 100 range\r\n\t\tto = limit(to);\r\n\r\n\t\t// Return false if handle can't move\r\n\t\tif ( to === scope_Locations[trigger] ) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\r\n\t\t// Set the handle to the new position.\r\n\t\t// Use requestAnimationFrame for efficient painting.\r\n\t\t// No significant effect in Chrome, Edge sees dramatic\r\n\t\t// performace improvements.\r\n\t\tif ( window.requestAnimationFrame ) {\r\n\t\t\twindow.requestAnimationFrame(function(){\r\n\t\t\t\thandle.style[options.style] = to + '%';\r\n\t\t\t});\r\n\t\t} else {\r\n\t\t\thandle.style[options.style] = to + '%';\r\n\t\t}\r\n\r\n\t\t// Force proper handle stacking\r\n\t\tif ( !handle.previousSibling ) {\r\n\t\t\tremoveClass(handle, options.cssClasses.stacking);\r\n\t\t\tif ( to > 50 ) {\r\n\t\t\t\taddClass(handle, options.cssClasses.stacking);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\t// Update locations.\r\n\t\tscope_Locations[trigger] = to;\r\n\r\n\t\t// Convert the value to the slider stepping/range.\r\n\t\tscope_Values[trigger] = scope_Spectrum.fromStepping( to );\r\n\r\n\t\tfireEvent('update', trigger);\r\n\r\n\t\treturn true;\r\n\t}\r\n\r\n\t// Loop values from value method and apply them.\r\n\tfunction setValues ( count, values ) {\r\n\r\n\t\tvar i, trigger, to;\r\n\r\n\t\t// With the limit option, we'll need another limiting pass.\r\n\t\tif ( options.limit ) {\r\n\t\t\tcount += 1;\r\n\t\t}\r\n\r\n\t\t// If there are multiple handles to be set run the setting\r\n\t\t// mechanism twice for the first handle, to make sure it\r\n\t\t// can be bounced of the second one properly.\r\n\t\tfor ( i = 0; i < count; i += 1 ) {\r\n\r\n\t\t\ttrigger = i%2;\r\n\r\n\t\t\t// Get the current argument from the array.\r\n\t\t\tto = values[trigger];\r\n\r\n\t\t\t// Setting with null indicates an 'ignore'.\r\n\t\t\t// Inputting 'false' is invalid.\r\n\t\t\tif ( to !== null && to !== false ) {\r\n\r\n\t\t\t\t// If a formatted number was passed, attemt to decode it.\r\n\t\t\t\tif ( typeof to === 'number' ) {\r\n\t\t\t\t\tto = String(to);\r\n\t\t\t\t}\r\n\r\n\t\t\t\tto = options.format.from( to );\r\n\r\n\t\t\t\t// Request an update for all links if the value was invalid.\r\n\t\t\t\t// Do so too if setting the handle fails.\r\n\t\t\t\tif ( to === false || isNaN(to) || setHandle( scope_Handles[trigger], scope_Spectrum.toStepping( to ), i === (3 - options.dir) ) === false ) {\r\n\t\t\t\t\tfireEvent('update', trigger);\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// Set the slider value.\r\n\tfunction valueSet ( input, fireSetEvent ) {\r\n\r\n\t\tvar count, values = asArray( input ), i;\r\n\r\n\t\t// Event fires by default\r\n\t\tfireSetEvent = (fireSetEvent === undefined ? true : !!fireSetEvent);\r\n\r\n\t\t// The RTL settings is implemented by reversing the front-end,\r\n\t\t// internal mechanisms are the same.\r\n\t\tif ( options.dir && options.handles > 1 ) {\r\n\t\t\tvalues.reverse();\r\n\t\t}\r\n\r\n\t\t// Animation is optional.\r\n\t\t// Make sure the initial values where set before using animated placement.\r\n\t\tif ( options.animate && scope_Locations[0] !== -1 ) {\r\n\t\t\taddClassFor( scope_Target, options.cssClasses.tap, options.animationDuration );\r\n\t\t}\r\n\r\n\t\t// Determine how often to set the handles.\r\n\t\tcount = scope_Handles.length > 1 ? 3 : 1;\r\n\r\n\t\tif ( values.length === 1 ) {\r\n\t\t\tcount = 1;\r\n\t\t}\r\n\r\n\t\tsetValues ( count, values );\r\n\r\n\t\t// Fire the 'set' event for both handles.\r\n\t\tfor ( i = 0; i < scope_Handles.length; i++ ) {\r\n\r\n\t\t\t// Fire the event only for handles that received a new value, as per #579\r\n\t\t\tif ( values[i] !== null && fireSetEvent ) {\r\n\t\t\t\tfireEvent('set', i);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\t// Get the slider value.\r\n\tfunction valueGet ( ) {\r\n\r\n\t\tvar i, retour = [];\r\n\r\n\t\t// Get the value from all handles.\r\n\t\tfor ( i = 0; i < options.handles; i += 1 ){\r\n\t\t\tretour[i] = options.format.to( scope_Values[i] );\r\n\t\t}\r\n\r\n\t\treturn inSliderOrder( retour );\r\n\t}\r\n\r\n\t// Removes classes from the root and empties it.\r\n\tfunction destroy ( ) {\r\n\r\n\t\tfor ( var key in options.cssClasses ) {\r\n\t\t\tif ( !options.cssClasses.hasOwnProperty(key) ) { continue; }\r\n\t\t\tremoveClass(scope_Target, options.cssClasses[key]);\r\n\t\t}\r\n\r\n\t\twhile (scope_Target.firstChild) {\r\n\t\t\tscope_Target.removeChild(scope_Target.firstChild);\r\n\t\t}\r\n\r\n\t\tdelete scope_Target.noUiSlider;\r\n\t}\r\n\r\n\t// Get the current step size for the slider.\r\n\tfunction getCurrentStep ( ) {\r\n\r\n\t\t// Check all locations, map them to their stepping point.\r\n\t\t// Get the step point, then find it in the input list.\r\n\t\tvar retour = scope_Locations.map(function( location, index ){\r\n\r\n\t\t\tvar step = scope_Spectrum.getApplicableStep( location ),\r\n\r\n\t\t\t\t// As per #391, the comparison for the decrement step can have some rounding issues.\r\n\t\t\t\t// Round the value to the precision used in the step.\r\n\t\t\t\tstepDecimals = countDecimals(String(step[2])),\r\n\r\n\t\t\t\t// Get the current numeric value\r\n\t\t\t\tvalue = scope_Values[index],\r\n\r\n\t\t\t\t// To move the slider 'one step up', the current step value needs to be added.\r\n\t\t\t\t// Use null if we are at the maximum slider value.\r\n\t\t\t\tincrement = location === 100 ? null : step[2],\r\n\r\n\t\t\t\t// Going 'one step down' might put the slider in a different sub-range, so we\r\n\t\t\t\t// need to switch between the current or the previous step.\r\n\t\t\t\tprev = Number((value - step[2]).toFixed(stepDecimals)),\r\n\r\n\t\t\t\t// If the value fits the step, return the current step value. Otherwise, use the\r\n\t\t\t\t// previous step. Return null if the slider is at its minimum value.\r\n\t\t\t\tdecrement = location === 0 ? null : (prev >= step[1]) ? step[2] : (step[0] || false);\r\n\r\n\t\t\treturn [decrement, increment];\r\n\t\t});\r\n\r\n\t\t// Return values in the proper order.\r\n\t\treturn inSliderOrder( retour );\r\n\t}\r\n\r\n\t// Attach an event to this slider, possibly including a namespace\r\n\tfunction bindEvent ( namespacedEvent, callback ) {\r\n\t\tscope_Events[namespacedEvent] = scope_Events[namespacedEvent] || [];\r\n\t\tscope_Events[namespacedEvent].push(callback);\r\n\r\n\t\t// If the event bound is 'update,' fire it immediately for all handles.\r\n\t\tif ( namespacedEvent.split('.')[0] === 'update' ) {\r\n\t\t\tscope_Handles.forEach(function(a, index){\r\n\t\t\t\tfireEvent('update', index);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\t// Undo attachment of event\r\n\tfunction removeEvent ( namespacedEvent ) {\r\n\r\n\t\tvar event = namespacedEvent && namespacedEvent.split('.')[0],\r\n\t\t\tnamespace = event && namespacedEvent.substring(event.length);\r\n\r\n\t\tObject.keys(scope_Events).forEach(function( bind ){\r\n\r\n\t\t\tvar tEvent = bind.split('.')[0],\r\n\t\t\t\ttNamespace = bind.substring(tEvent.length);\r\n\r\n\t\t\tif ( (!event || event === tEvent) && (!namespace || namespace === tNamespace) ) {\r\n\t\t\t\tdelete scope_Events[bind];\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\t// Updateable: margin, limit, step, range, animate, snap\r\n\tfunction updateOptions ( optionsToUpdate, fireSetEvent ) {\r\n\r\n\t\t// Spectrum is created using the range, snap, direction and step options.\r\n\t\t// 'snap' and 'step' can be updated, 'direction' cannot, due to event binding.\r\n\t\t// If 'snap' and 'step' are not passed, they should remain unchanged.\r\n\t\tvar v = valueGet(), newOptions = testOptions({\r\n\t\t\tstart: [0, 0],\r\n\t\t\tmargin: optionsToUpdate.margin,\r\n\t\t\tlimit: optionsToUpdate.limit,\r\n\t\t\tstep: optionsToUpdate.step === undefined ? options.singleStep : optionsToUpdate.step,\r\n\t\t\trange: optionsToUpdate.range,\r\n\t\t\tanimate: optionsToUpdate.animate,\r\n\t\t\tsnap: optionsToUpdate.snap === undefined ? options.snap : optionsToUpdate.snap\r\n\t\t});\r\n\r\n\t\t['margin', 'limit', 'range', 'animate'].forEach(function(name){\r\n\r\n\t\t\t// Only change options that we're actually passed to update.\r\n\t\t\tif ( optionsToUpdate[name] !== undefined ) {\r\n\t\t\t\toptions[name] = optionsToUpdate[name];\r\n\t\t\t}\r\n\t\t});\r\n\r\n\t\t// Save current spectrum direction as testOptions in testRange call\r\n\t\t// doesn't rely on current direction\r\n\t\tnewOptions.spectrum.direction = scope_Spectrum.direction;\r\n\t\tscope_Spectrum = newOptions.spectrum;\r\n\r\n\t\t// Invalidate the current positioning so valueSet forces an update.\r\n\t\tscope_Locations = [-1, -1];\r\n\t\tvalueSet(optionsToUpdate.start || v, fireSetEvent);\r\n\t}\r\n\r\n\r\n\t// Throw an error if the slider was already initialized.\r\n\tif ( scope_Target.noUiSlider ) {\r\n\t\tthrow new Error('Slider was already initialized.');\r\n\t}\r\n\r\n\t// Create the base element, initialise HTML and set classes.\r\n\t// Add handles and links.\r\n\tscope_Base = addSlider( options.dir, options.ort, scope_Target );\r\n\tscope_Handles = addHandles( options.handles, options.dir, scope_Base );\r\n\r\n\t// Set the connect classes.\r\n\taddConnection ( options.connect, scope_Target, scope_Handles );\r\n\r\n\tif ( options.pips ) {\r\n\t\tpips(options.pips);\r\n\t}\r\n\r\n\tif ( options.tooltips ) {\r\n\t\ttooltips();\r\n\t}\r\n\r\n\tscope_Self = {\r\n\t\tdestroy: destroy,\r\n\t\tsteps: getCurrentStep,\r\n\t\ton: bindEvent,\r\n\t\toff: removeEvent,\r\n\t\tget: valueGet,\r\n\t\tset: valueSet,\r\n\t\tupdateOptions: updateOptions,\r\n\t\toptions: originalOptions, // Issue #600\r\n\t\ttarget: scope_Target, // Issue #597\r\n\t\tpips: pips // Issue #594\r\n\t};\r\n\r\n\t// Attach user events.\r\n\tevents( options.events );\r\n\r\n\treturn scope_Self;\r\n\r\n}\r\n\r\n\r\n\t// Run the standard initializer\r\n\tfunction initialize ( target, originalOptions ) {\r\n\r\n\t\tif ( !target.nodeName ) {\r\n\t\t\tthrow new Error('noUiSlider.create requires a single element.');\r\n\t\t}\r\n\r\n\t\t// Test the options and create the slider environment;\r\n\t\tvar options = testOptions( originalOptions, target ),\r\n\t\t\tslider = closure( target, options, originalOptions );\r\n\r\n\t\t// Use the public value method to set the start values.\r\n\t\tslider.set(options.start);\r\n\r\n\t\ttarget.noUiSlider = slider;\r\n\t\treturn slider;\r\n\t}\r\n\r\n\t// Use an object instead of a function for future expansibility;\r\n\treturn {\r\n\t\tcreate: initialize\r\n\t};\r\n\r\n}));\n\n//# sourceURL=webpack://VLibras/./node_modules/nouislider/distribute/nouislider.js?"
)
},
'./node_modules/nouislider/distribute/nouislider.min.css': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../css-loader/dist/cjs.js!../../sass-loader/dist/cjs.js!./nouislider.min.css */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./node_modules/nouislider/distribute/nouislider.min.css");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./node_modules/nouislider/distribute/nouislider.min.css?'
)
},
'./node_modules/path-browserify/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"/* WEBPACK VAR INJECTION */(function(process) {// .dirname, .basename, and .extname methods are extracted from Node.js v8.11.1,\n// backported and transplited with Babel, with backwards-compat fixes\n\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\n// resolves . and .. elements in a path array with directory names there\n// must be no slashes, empty elements, or device names (c:\\) in the array\n// (so also no leading and trailing slashes - it does not distinguish\n// relative and absolute paths)\nfunction normalizeArray(parts, allowAboveRoot) {\n // if the path tries to go above the root, `up` ends up > 0\n var up = 0;\n for (var i = parts.length - 1; i >= 0; i--) {\n var last = parts[i];\n if (last === '.') {\n parts.splice(i, 1);\n } else if (last === '..') {\n parts.splice(i, 1);\n up++;\n } else if (up) {\n parts.splice(i, 1);\n up--;\n }\n }\n\n // if the path is allowed to go above the root, restore leading ..s\n if (allowAboveRoot) {\n for (; up--; up) {\n parts.unshift('..');\n }\n }\n\n return parts;\n}\n\n// path.resolve([from ...], to)\n// posix version\nexports.resolve = function() {\n var resolvedPath = '',\n resolvedAbsolute = false;\n\n for (var i = arguments.length - 1; i >= -1 && !resolvedAbsolute; i--) {\n var path = (i >= 0) ? arguments[i] : process.cwd();\n\n // Skip empty and invalid entries\n if (typeof path !== 'string') {\n throw new TypeError('Arguments to path.resolve must be strings');\n } else if (!path) {\n continue;\n }\n\n resolvedPath = path + '/' + resolvedPath;\n resolvedAbsolute = path.charAt(0) === '/';\n }\n\n // At this point the path should be resolved to a full absolute path, but\n // handle relative paths to be safe (might happen when process.cwd() fails)\n\n // Normalize the path\n resolvedPath = normalizeArray(filter(resolvedPath.split('/'), function(p) {\n return !!p;\n }), !resolvedAbsolute).join('/');\n\n return ((resolvedAbsolute ? '/' : '') + resolvedPath) || '.';\n};\n\n// path.normalize(path)\n// posix version\nexports.normalize = function(path) {\n var isAbsolute = exports.isAbsolute(path),\n trailingSlash = substr(path, -1) === '/';\n\n // Normalize the path\n path = normalizeArray(filter(path.split('/'), function(p) {\n return !!p;\n }), !isAbsolute).join('/');\n\n if (!path && !isAbsolute) {\n path = '.';\n }\n if (path && trailingSlash) {\n path += '/';\n }\n\n return (isAbsolute ? '/' : '') + path;\n};\n\n// posix version\nexports.isAbsolute = function(path) {\n return path.charAt(0) === '/';\n};\n\n// posix version\nexports.join = function() {\n var paths = Array.prototype.slice.call(arguments, 0);\n return exports.normalize(filter(paths, function(p, index) {\n if (typeof p !== 'string') {\n throw new TypeError('Arguments to path.join must be strings');\n }\n return p;\n }).join('/'));\n};\n\n\n// path.relative(from, to)\n// posix version\nexports.relative = function(from, to) {\n from = exports.resolve(from).substr(1);\n to = exports.resolve(to).substr(1);\n\n function trim(arr) {\n var start = 0;\n for (; start < arr.length; start++) {\n if (arr[start] !== '') break;\n }\n\n var end = arr.length - 1;\n for (; end >= 0; end--) {\n if (arr[end] !== '') break;\n }\n\n if (start > end) return [];\n return arr.slice(start, end - start + 1);\n }\n\n var fromParts = trim(from.split('/'));\n var toParts = trim(to.split('/'));\n\n var length = Math.min(fromParts.length, toParts.length);\n var samePartsLength = length;\n for (var i = 0; i < length; i++) {\n if (fromParts[i] !== toParts[i]) {\n samePartsLength = i;\n break;\n }\n }\n\n var outputParts = [];\n for (var i = samePartsLength; i < fromParts.length; i++) {\n outputParts.push('..');\n }\n\n outputParts = outputParts.concat(toParts.slice(samePartsLength));\n\n return outputParts.join('/');\n};\n\nexports.sep = '/';\nexports.delimiter = ':';\n\nexports.dirname = function (path) {\n if (typeof path !== 'string') path = path + '';\n if (path.length === 0) return '.';\n var code = path.charCodeAt(0);\n var hasRoot = code === 47 /*/*/;\n var end = -1;\n var matchedSlash = true;\n for (var i = path.length - 1; i >= 1; --i) {\n code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n if (!matchedSlash) {\n end = i;\n break;\n }\n } else {\n // We saw the first non-path separator\n matchedSlash = false;\n }\n }\n\n if (end === -1) return hasRoot ? '/' : '.';\n if (hasRoot && end === 1) {\n // return '//';\n // Backwards-compat fix:\n return '/';\n }\n return path.slice(0, end);\n};\n\nfunction basename(path) {\n if (typeof path !== 'string') path = path + '';\n\n var start = 0;\n var end = -1;\n var matchedSlash = true;\n var i;\n\n for (i = path.length - 1; i >= 0; --i) {\n if (path.charCodeAt(i) === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n start = i + 1;\n break;\n }\n } else if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // path component\n matchedSlash = false;\n end = i + 1;\n }\n }\n\n if (end === -1) return '';\n return path.slice(start, end);\n}\n\n// Uses a mixed approach for backwards-compatibility, as ext behavior changed\n// in new Node.js versions, so only basename() above is backported here\nexports.basename = function (path, ext) {\n var f = basename(path);\n if (ext && f.substr(-1 * ext.length) === ext) {\n f = f.substr(0, f.length - ext.length);\n }\n return f;\n};\n\nexports.extname = function (path) {\n if (typeof path !== 'string') path = path + '';\n var startDot = -1;\n var startPart = 0;\n var end = -1;\n var matchedSlash = true;\n // Track the state of characters (if any) we see before our first dot and\n // after any path separator we find\n var preDotState = 0;\n for (var i = path.length - 1; i >= 0; --i) {\n var code = path.charCodeAt(i);\n if (code === 47 /*/*/) {\n // If we reached a path separator that was not part of a set of path\n // separators at the end of the string, stop now\n if (!matchedSlash) {\n startPart = i + 1;\n break;\n }\n continue;\n }\n if (end === -1) {\n // We saw the first non-path separator, mark this as the end of our\n // extension\n matchedSlash = false;\n end = i + 1;\n }\n if (code === 46 /*.*/) {\n // If this is our first dot, mark it as the start of our extension\n if (startDot === -1)\n startDot = i;\n else if (preDotState !== 1)\n preDotState = 1;\n } else if (startDot !== -1) {\n // We saw a non-dot and non-path separator before our dot, so we should\n // have a good chance at having a non-empty extension\n preDotState = -1;\n }\n }\n\n if (startDot === -1 || end === -1 ||\n // We saw a non-dot character immediately before the dot\n preDotState === 0 ||\n // The (right-most) trimmed path component is exactly '..'\n preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {\n return '';\n }\n return path.slice(startDot, end);\n};\n\nfunction filter (xs, f) {\n if (xs.filter) return xs.filter(f);\n var res = [];\n for (var i = 0; i < xs.length; i++) {\n if (f(xs[i], i, xs)) res.push(xs[i]);\n }\n return res;\n}\n\n// String.prototype.substr - negative index don't work in IE8\nvar substr = 'ab'.substr(-1) === 'b'\n ? function (str, start, len) { return str.substr(start, len) }\n : function (str, start, len) {\n if (start < 0) start = str.length + start;\n return str.substr(start, len);\n }\n;\n\n/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../process/browser.js */ \"./node_modules/process/browser.js\")))\n\n//# sourceURL=webpack://VLibras/./node_modules/path-browserify/index.js?"
)
},
'./node_modules/process/browser.js': function (module, exports) {
eval(
"// 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\n//# sourceURL=webpack://VLibras/./node_modules/process/browser.js?"
)
},
'./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js':
function (module, exports, __webpack_require__) {
'use strict'
eval(
"\n\nvar isOldIE = function isOldIE() {\n var memo;\n return function memorize() {\n if (typeof memo === 'undefined') {\n // Test for IE <= 9 as proposed by Browserhacks\n // @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805\n // Tests for existence of standard globals is to allow style-loader\n // to operate correctly into non-standard environments\n // @see https://github.com/webpack-contrib/style-loader/issues/177\n memo = Boolean(window && document && document.all && !window.atob);\n }\n\n return memo;\n };\n}();\n\nvar getTarget = function getTarget() {\n var memo = {};\n return function memorize(target) {\n if (typeof memo[target] === 'undefined') {\n var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself\n\n if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {\n try {\n // This will throw an exception if access to iframe is blocked\n // due to cross-origin restrictions\n styleTarget = styleTarget.contentDocument.head;\n } catch (e) {\n // istanbul ignore next\n styleTarget = null;\n }\n }\n\n memo[target] = styleTarget;\n }\n\n return memo[target];\n };\n}();\n\nvar stylesInDom = [];\n\nfunction getIndexByIdentifier(identifier) {\n var result = -1;\n\n for (var i = 0; i < stylesInDom.length; i++) {\n if (stylesInDom[i].identifier === identifier) {\n result = i;\n break;\n }\n }\n\n return result;\n}\n\nfunction modulesToDom(list, options) {\n var idCountMap = {};\n var identifiers = [];\n\n for (var i = 0; i < list.length; i++) {\n var item = list[i];\n var id = options.base ? item[0] + options.base : item[0];\n var count = idCountMap[id] || 0;\n var identifier = \"\".concat(id, \" \").concat(count);\n idCountMap[id] = count + 1;\n var index = getIndexByIdentifier(identifier);\n var obj = {\n css: item[1],\n media: item[2],\n sourceMap: item[3]\n };\n\n if (index !== -1) {\n stylesInDom[index].references++;\n stylesInDom[index].updater(obj);\n } else {\n stylesInDom.push({\n identifier: identifier,\n updater: addStyle(obj, options),\n references: 1\n });\n }\n\n identifiers.push(identifier);\n }\n\n return identifiers;\n}\n\nfunction insertStyleElement(options) {\n var style = document.createElement('style');\n var attributes = options.attributes || {};\n\n if (typeof attributes.nonce === 'undefined') {\n var nonce = true ? __webpack_require__.nc : undefined;\n\n if (nonce) {\n attributes.nonce = nonce;\n }\n }\n\n Object.keys(attributes).forEach(function (key) {\n style.setAttribute(key, attributes[key]);\n });\n\n if (typeof options.insert === 'function') {\n options.insert(style);\n } else {\n var target = getTarget(options.insert || 'head');\n\n if (!target) {\n throw new Error(\"Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.\");\n }\n\n target.appendChild(style);\n }\n\n return style;\n}\n\nfunction removeStyleElement(style) {\n // istanbul ignore if\n if (style.parentNode === null) {\n return false;\n }\n\n style.parentNode.removeChild(style);\n}\n/* istanbul ignore next */\n\n\nvar replaceText = function replaceText() {\n var textStore = [];\n return function replace(index, replacement) {\n textStore[index] = replacement;\n return textStore.filter(Boolean).join('\\n');\n };\n}();\n\nfunction applyToSingletonTag(style, index, remove, obj) {\n var css = remove ? '' : obj.media ? \"@media \".concat(obj.media, \" {\").concat(obj.css, \"}\") : obj.css; // For old IE\n\n /* istanbul ignore if */\n\n if (style.styleSheet) {\n style.styleSheet.cssText = replaceText(index, css);\n } else {\n var cssNode = document.createTextNode(css);\n var childNodes = style.childNodes;\n\n if (childNodes[index]) {\n style.removeChild(childNodes[index]);\n }\n\n if (childNodes.length) {\n style.insertBefore(cssNode, childNodes[index]);\n } else {\n style.appendChild(cssNode);\n }\n }\n}\n\nfunction applyToTag(style, options, obj) {\n var css = obj.css;\n var media = obj.media;\n var sourceMap = obj.sourceMap;\n\n if (media) {\n style.setAttribute('media', media);\n } else {\n style.removeAttribute('media');\n }\n\n if (sourceMap && typeof btoa !== 'undefined') {\n css += \"\\n/*# sourceMappingURL=data:application/json;base64,\".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), \" */\");\n } // For old IE\n\n /* istanbul ignore if */\n\n\n if (style.styleSheet) {\n style.styleSheet.cssText = css;\n } else {\n while (style.firstChild) {\n style.removeChild(style.firstChild);\n }\n\n style.appendChild(document.createTextNode(css));\n }\n}\n\nvar singleton = null;\nvar singletonCounter = 0;\n\nfunction addStyle(obj, options) {\n var style;\n var update;\n var remove;\n\n if (options.singleton) {\n var styleIndex = singletonCounter++;\n style = singleton || (singleton = insertStyleElement(options));\n update = applyToSingletonTag.bind(null, style, styleIndex, false);\n remove = applyToSingletonTag.bind(null, style, styleIndex, true);\n } else {\n style = insertStyleElement(options);\n update = applyToTag.bind(null, style, options);\n\n remove = function remove() {\n removeStyleElement(style);\n };\n }\n\n update(obj);\n return function updateStyle(newObj) {\n if (newObj) {\n if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) {\n return;\n }\n\n update(obj = newObj);\n } else {\n remove();\n }\n };\n}\n\nmodule.exports = function (list, options) {\n options = options || {}; // Force single-tag solution on IE6-9, which has a hard limit on the # of <style>\n // tags it will allow on a page\n\n if (!options.singleton && typeof options.singleton !== 'boolean') {\n options.singleton = isOldIE();\n }\n\n list = list || [];\n var lastIdentifiers = modulesToDom(list, options);\n return function update(newList) {\n newList = newList || [];\n\n if (Object.prototype.toString.call(newList) !== '[object Array]') {\n return;\n }\n\n for (var i = 0; i < lastIdentifiers.length; i++) {\n var identifier = lastIdentifiers[i];\n var index = getIndexByIdentifier(identifier);\n stylesInDom[index].references--;\n }\n\n var newLastIdentifiers = modulesToDom(newList, options);\n\n for (var _i = 0; _i < lastIdentifiers.length; _i++) {\n var _identifier = lastIdentifiers[_i];\n\n var _index = getIndexByIdentifier(_identifier);\n\n if (stylesInDom[_index].references === 0) {\n stylesInDom[_index].updater();\n\n stylesInDom.splice(_index, 1);\n }\n }\n\n lastIdentifiers = newLastIdentifiers;\n };\n};\n\n//# sourceURL=webpack://VLibras/./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js?"
)
},
'./node_modules/textarea-caret/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"/* jshint browser: true */\n\n(function () {\n\n// We'll copy the properties below into the mirror div.\n// Note that some browsers, such as Firefox, do not concatenate properties\n// into their shorthand (e.g. padding-top, padding-bottom etc. -> padding),\n// so we have to list every single property explicitly.\nvar properties = [\n 'direction', // RTL support\n 'boxSizing',\n 'width', // on Chrome and IE, exclude the scrollbar, so the mirror div wraps exactly as the textarea does\n 'height',\n 'overflowX',\n 'overflowY', // copy the scrollbar for IE\n\n 'borderTopWidth',\n 'borderRightWidth',\n 'borderBottomWidth',\n 'borderLeftWidth',\n 'borderStyle',\n\n 'paddingTop',\n 'paddingRight',\n 'paddingBottom',\n 'paddingLeft',\n\n // https://developer.mozilla.org/en-US/docs/Web/CSS/font\n 'fontStyle',\n 'fontVariant',\n 'fontWeight',\n 'fontStretch',\n 'fontSize',\n 'fontSizeAdjust',\n 'lineHeight',\n 'fontFamily',\n\n 'textAlign',\n 'textTransform',\n 'textIndent',\n 'textDecoration', // might not make a difference, but better be safe\n\n 'letterSpacing',\n 'wordSpacing',\n\n 'tabSize',\n 'MozTabSize'\n\n];\n\nvar isBrowser = (typeof window !== 'undefined');\nvar isFirefox = (isBrowser && window.mozInnerScreenX != null);\n\nfunction getCaretCoordinates(element, position, options) {\n if (!isBrowser) {\n throw new Error('textarea-caret-position#getCaretCoordinates should only be called in a browser');\n }\n\n var debug = options && options.debug || false;\n if (debug) {\n var el = document.querySelector('#input-textarea-caret-position-mirror-div');\n if (el) el.parentNode.removeChild(el);\n }\n\n // The mirror div will replicate the textarea's style\n var div = document.createElement('div');\n div.id = 'input-textarea-caret-position-mirror-div';\n document.body.appendChild(div);\n\n var style = div.style;\n var computed = window.getComputedStyle ? window.getComputedStyle(element) : element.currentStyle; // currentStyle for IE < 9\n var isInput = element.nodeName === 'INPUT';\n\n // Default textarea styles\n style.whiteSpace = 'pre-wrap';\n if (!isInput)\n style.wordWrap = 'break-word'; // only for textarea-s\n\n // Position off-screen\n style.position = 'absolute'; // required to return coordinates properly\n if (!debug)\n style.visibility = 'hidden'; // not 'display: none' because we want rendering\n\n // Transfer the element's properties to the div\n properties.forEach(function (prop) {\n if (isInput && prop === 'lineHeight') {\n // Special case for <input>s because text is rendered centered and line height may be != height\n style.lineHeight = computed.height;\n } else {\n style[prop] = computed[prop];\n }\n });\n\n if (isFirefox) {\n // Firefox lies about the overflow property for textareas: https://bugzilla.mozilla.org/show_bug.cgi?id=984275\n if (element.scrollHeight > parseInt(computed.height))\n style.overflowY = 'scroll';\n } else {\n style.overflow = 'hidden'; // for Chrome to not render a scrollbar; IE keeps overflowY = 'scroll'\n }\n\n div.textContent = element.value.substring(0, position);\n // The second special handling for input type=\"text\" vs textarea:\n // spaces need to be replaced with non-breaking spaces - http://stackoverflow.com/a/13402035/1269037\n if (isInput)\n div.textContent = div.textContent.replace(/\\s/g, '\\u00a0');\n\n var span = document.createElement('span');\n // Wrapping must be replicated *exactly*, including when a long word gets\n // onto the next line, with whitespace at the end of the line before (#7).\n // The *only* reliable way to do that is to copy the *entire* rest of the\n // textarea's content into the <span> created at the caret position.\n // For inputs, just '.' would be enough, but no need to bother.\n span.textContent = element.value.substring(position) || '.'; // || because a completely empty faux span doesn't render at all\n div.appendChild(span);\n\n var coordinates = {\n top: span.offsetTop + parseInt(computed['borderTopWidth']),\n left: span.offsetLeft + parseInt(computed['borderLeftWidth']),\n height: parseInt(computed['lineHeight'])\n };\n\n if (debug) {\n span.style.backgroundColor = '#aaa';\n } else {\n document.body.removeChild(div);\n }\n\n return coordinates;\n}\n\nif ( true && typeof module.exports != 'undefined') {\n module.exports = getCaretCoordinates;\n} else if(isBrowser) {\n window.getCaretCoordinates = getCaretCoordinates;\n}\n\n}());\n\n\n//# sourceURL=webpack://VLibras/./node_modules/textarea-caret/index.js?"
)
},
'./node_modules/trie-search/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
'module.exports = __webpack_require__(/*! ./src/TrieSearch */ "./node_modules/trie-search/src/TrieSearch.js");\n\n//# sourceURL=webpack://VLibras/./node_modules/trie-search/index.js?'
)
},
'./node_modules/trie-search/src/TrieSearch.js': function (
module,
exports,
__webpack_require__
) {
eval(
"var HashArray = __webpack_require__(/*! hasharray */ \"./node_modules/hasharray/index.js\");\n\nvar MAX_CACHE_SIZE = 64;\n\nvar IS_WHITESPACE = /^[\\s]*$/;\n\nvar DEFAULT_INTERNATIONALIZE_EXPAND_REGEXES = [\n {\n regex: /[åäàáâãæ]/ig,\n alternate: 'a'\n },\n {\n regex: /[èéêë]/ig,\n alternate: 'e'\n },\n {\n regex: /[ìíîï]/ig,\n alternate: 'i'\n },\n {\n regex: /[òóôõö]/ig,\n alternate: 'o'\n },\n {\n regex: /[ùúûü]/ig,\n alternate: 'u'\n },\n {\n regex: /[æ]/ig,\n alternate: 'ae'\n }\n];\n\nString.prototype.replaceCharAt=function(index, replacement) {\n return this.substr(0, index) + replacement + this.substr(index + replacement.length);\n};\n\nvar TrieSearch = function (keyFields, options) {\n this.options = options || {};\n\n // Default ignoreCase to true\n this.options.ignoreCase = (this.options.ignoreCase === undefined) ? true : this.options.ignoreCase;\n this.options.maxCacheSize = this.options.maxCacheSize || MAX_CACHE_SIZE;\n this.options.cache = this.options.hasOwnProperty('cache') ? this.options.cache : true;\n this.options.splitOnRegEx = this.options.hasOwnProperty('splitOnRegEx') ? this.options.splitOnRegEx : /\\s/g;\n this.options.splitOnGetRegEx = this.options.hasOwnProperty('splitOnGetRegEx') ? this.options.splitOnGetRegEx : this.options.splitOnRegEx;\n this.options.min = this.options.min || 1;\n this.options.keepAll = this.options.hasOwnProperty('keepAll') ? this.options.keepAll : false;\n this.options.keepAllKey = this.options.hasOwnProperty('keepAllKey') ? this.options.keepAllKey : 'id';\n this.options.idFieldOrFunction = this.options.hasOwnProperty('idFieldOrFunction') ? this.options.idFieldOrFunction : undefined;\n this.options.expandRegexes = this.options.expandRegexes || DEFAULT_INTERNATIONALIZE_EXPAND_REGEXES;\n this.options.insertFullUnsplitKey = this.options.hasOwnProperty('insertFullUnsplitKey') ? this.options.insertFullUnsplitKey : false;\n\n this.keyFields = keyFields ? (keyFields instanceof Array ? keyFields : [keyFields]) : [];\n this.root = {};\n this.size = 0;\n\n if (this.options.cache) {\n this.getCache = new HashArray('key');\n }\n};\n\nfunction deepLookup(obj, keys) {\n return keys.length === 1 ? obj[keys[0]] : deepLookup(obj[keys[0]], keys.slice(1, keys.length));\n}\n\nTrieSearch.prototype = {\n add: function (obj, customKeys) {\n if (this.options.cache)\n this.clearCache();\n\n // Someone might have called add via an array forEach where the second param is a number\n if (typeof customKeys === 'number') {\n customKeys = undefined;\n }\n\n var keyFields = customKeys || this.keyFields;\n\n for (var k in keyFields)\n {\n var key = keyFields[k],\n isKeyArr = key instanceof Array,\n val = isKeyArr ? deepLookup(obj, key) : obj[key];\n\n if (!val) continue;\n\n val = val.toString();\n\n var expandedValues = this.expandString(val);\n\n for (var v = 0; v < expandedValues.length; v++) {\n var expandedValue = expandedValues[v];\n\n this.map(expandedValue, obj);\n }\n }\n },\n /**\n * By default using the options.expandRegexes, given a string like 'ö är bra', this will expand it to:\n *\n * ['ö är bra', 'o är bra', 'ö ar bra', 'o ar bra']\n *\n * By default this was built to allow for internationalization, but it could be also be expanded to\n * allow for word alternates, etc. like spelling alternates ('teh' and 'the').\n *\n * This is used for insertion! This should not be used for lookup since if a person explicitly types\n * 'ä' they probably do not want to see all results for 'a'.\n *\n * @param value The string to find alternates for.\n * @returns {Array} Always returns an array even if no matches.\n */\n expandString: function(value) {\n var values = [value];\n\n if (this.options.expandRegexes && this.options.expandRegexes.length) {\n for (var i = 0; i < this.options.expandRegexes.length; i++) {\n var er = this.options.expandRegexes[i];\n var match;\n\n while((match = er.regex.exec(value)) !== null) {\n var alternateValue = value.replaceCharAt(match.index, er.alternate);\n values.push(alternateValue);\n }\n }\n }\n\n return values;\n },\n addAll: function (arr, customKeys) {\n for (var i = 0; i < arr.length; i++)\n this.add(arr[i], customKeys);\n },\n reset: function () {\n this.root = {};\n this.size = 0;\n },\n clearCache: function () {\n // if (this.getCache && !this.getCache._list.length) {\n // return;\n // }\n this.getCache = new HashArray('key');\n },\n cleanCache: function () {\n while (this.getCache.all.length > this.options.maxCacheSize)\n this.getCache.remove(this.getCache.all[0]);\n },\n addFromObject: function (obj, valueField) {\n if (this.options.cache)\n this.clearCache();\n\n valueField = valueField || 'value';\n\n if (this.keyFields.indexOf('_key_') == -1)\n this.keyFields.push('_key_');\n\n for (var key in obj)\n {\n var o = {_key_: key};\n o[valueField] = obj[key];\n this.add(o);\n }\n },\n map: function (key, value) {\n if (this.options.splitOnRegEx && this.options.splitOnRegEx.test(key))\n {\n var phrases = key.split(this.options.splitOnRegEx);\n var emptySplitMatch = phrases.filter(function(p) { return IS_WHITESPACE.test(p); });\n var selfMatch = phrases.filter(function(p) { return p === key; });\n var selfIsOnlyMatch = selfMatch.length + emptySplitMatch.length === phrases.length;\n\n // There is an edge case that a RegEx with a positive lookeahed like:\n // /?=[A-Z]/ // Split on capital letters for a camelcase sentence\n // Will then match again when we call map, creating an infinite stack loop.\n if (!selfIsOnlyMatch) {\n for (var i = 0, l = phrases.length; i < l; i++) {\n if (!IS_WHITESPACE.test(phrases[i])) {\n this.map(phrases[i], value);\n }\n }\n\n if (!this.options.insertFullUnsplitKey) {\n return;\n }\n }\n }\n\n if (this.options.cache)\n this.clearCache();\n\n if (this.options.keepAll) {\n this.indexed = this.indexed || new HashArray([this.options.keepAllKey]);\n this.indexed.add(value);\n }\n\n if (this.options.ignoreCase) {\n key = key.toLowerCase();\n }\n\n var keyArr = this.keyToArr(key),\n self = this;\n\n insert(keyArr, value, this.root);\n\n function insert(keyArr, value, node) {\n if (keyArr.length == 0)\n {\n node['value'] = node['value'] || [];\n node['value'].push(value);\n return; \n }\n\n var k = keyArr.shift();\n\n if (!node[k])\n self.size++;\n\n node[k] = node[k] || {};\n\n insert(keyArr, value, node[k])\n }\n },\n keyToArr: function (key) {\n var keyArr;\n \n if (this.options.min && this.options.min > 1)\n {\n if (key.length < this.options.min)\n return [];\n\n keyArr = [key.substr(0, this.options.min)];\n keyArr = keyArr.concat(key.substr(this.options.min).split(''));\n }\n else keyArr = key.split('');\n\n return keyArr;\n },\n findNode: function (key) {\n return f(this.keyToArr(key), this.root);\n\n function f(keyArr, node) {\n if (!node) return undefined;\n if (keyArr.length == 0) return node;\n\n var k = keyArr.shift();\n return f(keyArr, node[k]);\n }\n },\n _getCacheKey: function(phrase, limit){\n var cacheKey = phrase\n if(limit) {\n cacheKey = phrase + \"_\" + limit\n }\n return cacheKey\n },\n _get: function (phrase, limit) {\n phrase = this.options.ignoreCase ? phrase.toLowerCase() : phrase;\n \n var c, node;\n if (this.options.cache && (c = this.getCache.get(this._getCacheKey(phrase, limit))))\n return c.value;\n\n var ret = undefined,\n haKeyFields = this.options.indexField ? [this.options.indexField] : this.keyFields,\n words = this.options.splitOnGetRegEx ? phrase.split(this.options.splitOnGetRegEx) : [phrase];\n\n for (var w = 0, l = words.length; w < l; w++)\n {\n if (this.options.min && words[w].length < this.options.min)\n continue;\n\n var temp = new HashArray(haKeyFields);\n\n if (node = this.findNode(words[w]))\n aggregate(node, temp);\n\n ret = ret ? ret.intersection(temp) : temp;\n }\n \n var v = ret ? ret.all : [];\n\n if (this.options.cache)\n {\n var cacheKey = this._getCacheKey(phrase, limit)\n this.getCache.add({key: cacheKey, value: v});\n this.cleanCache();\n }\n\n return v;\n \n function aggregate(node, ha) {\n if(limit && ha.all.length === limit) {\n return\n }\n\n if (node.value && node.value.length) {\n if(!limit || (ha.all.length + node.value.length) < limit) {\n ha.addAll(node.value);\n } else {\n // Limit is less than the number of entries in the node.value + ha combined\n ha.addAll(node.value.slice(0, limit - ha.all.length))\n return\n }\n }\n\n for (var k in node) {\n if (limit && ha.all.length === limit){\n return\n }\n if (k != 'value') {\n aggregate(node[k], ha);\n }\n }\n }\n },\n get: function (phrases, reducer, limit) {\n var haKeyFields = this.options.indexField ? [this.options.indexField] : this.keyFields,\n ret = undefined,\n accumulator = undefined;\n\n if (reducer && !this.options.idFieldOrFunction) {\n throw new Error('To use the accumulator, you must specify and idFieldOrFunction');\n }\n\n phrases = (phrases instanceof Array) ? phrases : [phrases];\n\n for (var i = 0, l = phrases.length; i < l; i++)\n {\n var matches = this._get(phrases[i], limit);\n\n if (reducer) {\n accumulator = reducer(accumulator, phrases[i], matches, this);\n } else {\n ret = ret ? ret.addAll(matches) : new HashArray(haKeyFields).addAll(matches);\n }\n }\n\n return !reducer ? ret.all : accumulator;\n },\n search: function(phrases, reducer) {\n return this.get(phrases, reducer);\n },\n getId: function (item) {\n return typeof this.options.idFieldOrFunction === 'function' ? this.options.idFieldOrFunction(item) : item[this.options.idFieldOrFunction];\n }\n};\n\nTrieSearch.UNION_REDUCER = function(accumulator, phrase, matches, trie) {\n if (accumulator === undefined) {\n return matches;\n }\n\n var map = {}, i, id;\n var maxLength = Math.max(accumulator.length, matches.length);\n var results = [];\n var l = 0;\n\n // One loop, O(N) for max length of accumulator or matches.\n for (i = 0; i < maxLength; i++) {\n if (i < accumulator.length) {\n id = trie.getId(accumulator[i]);\n map[id] = map[id] ? map[id] : 0;\n map[id]++;\n\n if (map[id] === 2) {\n results[l++] = accumulator[i];\n }\n }\n\n if (i < matches.length) {\n id = trie.getId(matches[i]);\n map[id] = map[id] ? map[id] : 0;\n map[id]++;\n\n if (map[id] === 2) {\n results[l++] = matches[i];\n }\n }\n }\n\n return results;\n};\n\nmodule.exports = TrieSearch;\n\n\n//# sourceURL=webpack://VLibras/./node_modules/trie-search/src/TrieSearch.js?"
)
},
'./node_modules/url-join/lib/url-join.js': function (
module,
exports,
__webpack_require__
) {
eval(
"var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (name, context, definition) {\n if ( true && module.exports) module.exports = definition();\n else if (true) !(__WEBPACK_AMD_DEFINE_FACTORY__ = (definition),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :\n\t\t\t\t__WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n\n\n//# sourceURL=webpack://VLibras/./node_modules/url-join/lib/url-join.js?"
)
},
'./node_modules/vlibras/node_modules/inherits/inherits_browser.js':
function (module, exports) {
eval(
"if (typeof Object.create === 'function') {\n // implementation from standard node.js 'util' module\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n ctor.prototype = Object.create(superCtor.prototype, {\n constructor: {\n value: ctor,\n enumerable: false,\n writable: true,\n configurable: true\n }\n })\n }\n };\n} else {\n // old school shim for old browsers\n module.exports = function inherits(ctor, superCtor) {\n if (superCtor) {\n ctor.super_ = superCtor\n var TempCtor = function () {}\n TempCtor.prototype = superCtor.prototype\n ctor.prototype = new TempCtor()\n ctor.prototype.constructor = ctor\n }\n }\n}\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/inherits/inherits_browser.js?"
)
},
'./node_modules/vlibras/node_modules/object-assign/index.js': function (
module,
exports,
__webpack_require__
) {
'use strict'
eval(
"/*\nobject-assign\n(c) Sindre Sorhus\n@license MIT\n*/\n\n\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\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/object-assign/index.js?"
)
},
'./node_modules/vlibras/node_modules/reduce-component/index.js': function (
module,
exports
) {
eval(
'\n/**\n * Reduce `arr` with `fn`.\n *\n * @param {Array} arr\n * @param {Function} fn\n * @param {Mixed} initial\n *\n * TODO: combatible error handling?\n */\n\nmodule.exports = function(arr, fn, initial){ \n var idx = 0;\n var len = arr.length;\n var curr = arguments.length == 3\n ? initial\n : arr[idx++];\n\n while (idx < len) {\n curr = fn.call(null, curr, arr[idx], ++idx, arr);\n }\n \n return curr;\n};\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/reduce-component/index.js?'
)
},
'./node_modules/vlibras/node_modules/superagent/lib/client.js': function (
module,
exports,
__webpack_require__
) {
eval(
"/**\n * Module dependencies.\n */\n\nvar Emitter = __webpack_require__(/*! emitter */ \"./node_modules/vlibras/node_modules/superagent/node_modules/component-emitter/index.js\");\nvar reduce = __webpack_require__(/*! reduce */ \"./node_modules/vlibras/node_modules/reduce-component/index.js\");\nvar requestBase = __webpack_require__(/*! ./request-base */ \"./node_modules/vlibras/node_modules/superagent/lib/request-base.js\");\nvar isObject = __webpack_require__(/*! ./is-object */ \"./node_modules/vlibras/node_modules/superagent/lib/is-object.js\");\n\n/**\n * Root reference for iframes.\n */\n\nvar root;\nif (typeof window !== 'undefined') { // Browser window\n root = window;\n} else if (typeof self !== 'undefined') { // Web Worker\n root = self;\n} else { // Other environments\n root = this;\n}\n\n/**\n * Noop.\n */\n\nfunction noop(){};\n\n/**\n * Check if `obj` is a host object,\n * we don't want to serialize these :)\n *\n * TODO: future proof, move to compoent land\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isHost(obj) {\n var str = {}.toString.call(obj);\n\n switch (str) {\n case '[object File]':\n case '[object Blob]':\n case '[object FormData]':\n return true;\n default:\n return false;\n }\n}\n\n/**\n * Expose `request`.\n */\n\nvar request = module.exports = __webpack_require__(/*! ./request */ \"./node_modules/vlibras/node_modules/superagent/lib/request.js\").bind(null, Request);\n\n/**\n * Determine XHR.\n */\n\nrequest.getXHR = function () {\n if (root.XMLHttpRequest\n && (!root.location || 'file:' != root.location.protocol\n || !root.ActiveXObject)) {\n return new XMLHttpRequest;\n } else {\n try { return new ActiveXObject('Microsoft.XMLHTTP'); } catch(e) {}\n try { return new ActiveXObject('Msxml2.XMLHTTP.6.0'); } catch(e) {}\n try { return new ActiveXObject('Msxml2.XMLHTTP.3.0'); } catch(e) {}\n try { return new ActiveXObject('Msxml2.XMLHTTP'); } catch(e) {}\n }\n return false;\n};\n\n/**\n * Removes leading and trailing whitespace, added to support IE.\n *\n * @param {String} s\n * @return {String}\n * @api private\n */\n\nvar trim = ''.trim\n ? function(s) { return s.trim(); }\n : function(s) { return s.replace(/(^\\s*|\\s*$)/g, ''); };\n\n/**\n * Serialize the given `obj`.\n *\n * @param {Object} obj\n * @return {String}\n * @api private\n */\n\nfunction serialize(obj) {\n if (!isObject(obj)) return obj;\n var pairs = [];\n for (var key in obj) {\n if (null != obj[key]) {\n pushEncodedKeyValuePair(pairs, key, obj[key]);\n }\n }\n return pairs.join('&');\n}\n\n/**\n * Helps 'serialize' with serializing arrays.\n * Mutates the pairs array.\n *\n * @param {Array} pairs\n * @param {String} key\n * @param {Mixed} val\n */\n\nfunction pushEncodedKeyValuePair(pairs, key, val) {\n if (Array.isArray(val)) {\n return val.forEach(function(v) {\n pushEncodedKeyValuePair(pairs, key, v);\n });\n }\n pairs.push(encodeURIComponent(key)\n + '=' + encodeURIComponent(val));\n}\n\n/**\n * Expose serialization method.\n */\n\n request.serializeObject = serialize;\n\n /**\n * Parse the given x-www-form-urlencoded `str`.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseString(str) {\n var obj = {};\n var pairs = str.split('&');\n var parts;\n var pair;\n\n for (var i = 0, len = pairs.length; i < len; ++i) {\n pair = pairs[i];\n parts = pair.split('=');\n obj[decodeURIComponent(parts[0])] = decodeURIComponent(parts[1]);\n }\n\n return obj;\n}\n\n/**\n * Expose parser.\n */\n\nrequest.parseString = parseString;\n\n/**\n * Default MIME type map.\n *\n * superagent.types.xml = 'application/xml';\n *\n */\n\nrequest.types = {\n html: 'text/html',\n json: 'application/json',\n xml: 'application/xml',\n urlencoded: 'application/x-www-form-urlencoded',\n 'form': 'application/x-www-form-urlencoded',\n 'form-data': 'application/x-www-form-urlencoded'\n};\n\n/**\n * Default serialization map.\n *\n * superagent.serialize['application/xml'] = function(obj){\n * return 'generated xml here';\n * };\n *\n */\n\n request.serialize = {\n 'application/x-www-form-urlencoded': serialize,\n 'application/json': JSON.stringify\n };\n\n /**\n * Default parsers.\n *\n * superagent.parse['application/xml'] = function(str){\n * return { object parsed from str };\n * };\n *\n */\n\nrequest.parse = {\n 'application/x-www-form-urlencoded': parseString,\n 'application/json': JSON.parse\n};\n\n/**\n * Parse the given header `str` into\n * an object containing the mapped fields.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction parseHeader(str) {\n var lines = str.split(/\\r?\\n/);\n var fields = {};\n var index;\n var line;\n var field;\n var val;\n\n lines.pop(); // trailing CRLF\n\n for (var i = 0, len = lines.length; i < len; ++i) {\n line = lines[i];\n index = line.indexOf(':');\n field = line.slice(0, index).toLowerCase();\n val = trim(line.slice(index + 1));\n fields[field] = val;\n }\n\n return fields;\n}\n\n/**\n * Check if `mime` is json or has +json structured syntax suffix.\n *\n * @param {String} mime\n * @return {Boolean}\n * @api private\n */\n\nfunction isJSON(mime) {\n return /[\\/+]json\\b/.test(mime);\n}\n\n/**\n * Return the mime type for the given `str`.\n *\n * @param {String} str\n * @return {String}\n * @api private\n */\n\nfunction type(str){\n return str.split(/ *; */).shift();\n};\n\n/**\n * Return header field parameters.\n *\n * @param {String} str\n * @return {Object}\n * @api private\n */\n\nfunction params(str){\n return reduce(str.split(/ *; */), function(obj, str){\n var parts = str.split(/ *= */)\n , key = parts.shift()\n , val = parts.shift();\n\n if (key && val) obj[key] = val;\n return obj;\n }, {});\n};\n\n/**\n * Initialize a new `Response` with the given `xhr`.\n *\n * - set flags (.ok, .error, etc)\n * - parse header\n *\n * Examples:\n *\n * Aliasing `superagent` as `request` is nice:\n *\n * request = superagent;\n *\n * We can use the promise-like API, or pass callbacks:\n *\n * request.get('/').end(function(res){});\n * request.get('/', function(res){});\n *\n * Sending data can be chained:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' })\n * .end(function(res){});\n *\n * Or passed to `.send()`:\n *\n * request\n * .post('/user')\n * .send({ name: 'tj' }, function(res){});\n *\n * Or passed to `.post()`:\n *\n * request\n * .post('/user', { name: 'tj' })\n * .end(function(res){});\n *\n * Or further reduced to a single call for simple cases:\n *\n * request\n * .post('/user', { name: 'tj' }, function(res){});\n *\n * @param {XMLHTTPRequest} xhr\n * @param {Object} options\n * @api private\n */\n\nfunction Response(req, options) {\n options = options || {};\n this.req = req;\n this.xhr = this.req.xhr;\n // responseText is accessible only if responseType is '' or 'text' and on older browsers\n this.text = ((this.req.method !='HEAD' && (this.xhr.responseType === '' || this.xhr.responseType === 'text')) || typeof this.xhr.responseType === 'undefined')\n ? this.xhr.responseText\n : null;\n this.statusText = this.req.xhr.statusText;\n this.setStatusProperties(this.xhr.status);\n this.header = this.headers = parseHeader(this.xhr.getAllResponseHeaders());\n // getAllResponseHeaders sometimes falsely returns \"\" for CORS requests, but\n // getResponseHeader still works. so we get content-type even if getting\n // other headers fails.\n this.header['content-type'] = this.xhr.getResponseHeader('content-type');\n this.setHeaderProperties(this.header);\n this.body = this.req.method != 'HEAD'\n ? this.parseBody(this.text ? this.text : this.xhr.response)\n : null;\n}\n\n/**\n * Get case-insensitive `field` value.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\nResponse.prototype.get = function(field){\n return this.header[field.toLowerCase()];\n};\n\n/**\n * Set header related properties:\n *\n * - `.type` the content type without params\n *\n * A response of \"Content-Type: text/plain; charset=utf-8\"\n * will provide you with a `.type` of \"text/plain\".\n *\n * @param {Object} header\n * @api private\n */\n\nResponse.prototype.setHeaderProperties = function(header){\n // content-type\n var ct = this.header['content-type'] || '';\n this.type = type(ct);\n\n // params\n var obj = params(ct);\n for (var key in obj) this[key] = obj[key];\n};\n\n/**\n * Parse the given body `str`.\n *\n * Used for auto-parsing of bodies. Parsers\n * are defined on the `superagent.parse` object.\n *\n * @param {String} str\n * @return {Mixed}\n * @api private\n */\n\nResponse.prototype.parseBody = function(str){\n var parse = request.parse[this.type];\n if (!parse && isJSON(this.type)) {\n parse = request.parse['application/json'];\n }\n return parse && str && (str.length || str instanceof Object)\n ? parse(str)\n : null;\n};\n\n/**\n * Set flags such as `.ok` based on `status`.\n *\n * For example a 2xx response will give you a `.ok` of __true__\n * whereas 5xx will be __false__ and `.error` will be __true__. The\n * `.clientError` and `.serverError` are also available to be more\n * specific, and `.statusType` is the class of error ranging from 1..5\n * sometimes useful for mapping respond colors etc.\n *\n * \"sugar\" properties are also defined for common cases. Currently providing:\n *\n * - .noContent\n * - .badRequest\n * - .unauthorized\n * - .notAcceptable\n * - .notFound\n *\n * @param {Number} status\n * @api private\n */\n\nResponse.prototype.setStatusProperties = function(status){\n // handle IE9 bug: http://stackoverflow.com/questions/10046972/msie-returns-status-code-of-1223-for-ajax-request\n if (status === 1223) {\n status = 204;\n }\n\n var type = status / 100 | 0;\n\n // status / class\n this.status = this.statusCode = status;\n this.statusType = type;\n\n // basics\n this.info = 1 == type;\n this.ok = 2 == type;\n this.clientError = 4 == type;\n this.serverError = 5 == type;\n this.error = (4 == type || 5 == type)\n ? this.toError()\n : false;\n\n // sugar\n this.accepted = 202 == status;\n this.noContent = 204 == status;\n this.badRequest = 400 == status;\n this.unauthorized = 401 == status;\n this.notAcceptable = 406 == status;\n this.notFound = 404 == status;\n this.forbidden = 403 == status;\n};\n\n/**\n * Return an `Error` representative of this response.\n *\n * @return {Error}\n * @api public\n */\n\nResponse.prototype.toError = function(){\n var req = this.req;\n var method = req.method;\n var url = req.url;\n\n var msg = 'cannot ' + method + ' ' + url + ' (' + this.status + ')';\n var err = new Error(msg);\n err.status = this.status;\n err.method = method;\n err.url = url;\n\n return err;\n};\n\n/**\n * Expose `Response`.\n */\n\nrequest.Response = Response;\n\n/**\n * Initialize a new `Request` with the given `method` and `url`.\n *\n * @param {String} method\n * @param {String} url\n * @api public\n */\n\nfunction Request(method, url) {\n var self = this;\n this._query = this._query || [];\n this.method = method;\n this.url = url;\n this.header = {}; // preserves header name case\n this._header = {}; // coerces header names to lowercase\n this.on('end', function(){\n var err = null;\n var res = null;\n\n try {\n res = new Response(self);\n } catch(e) {\n err = new Error('Parser is unable to parse the response');\n err.parse = true;\n err.original = e;\n // issue #675: return the raw response if the response parsing fails\n err.rawResponse = self.xhr && self.xhr.responseText ? self.xhr.responseText : null;\n // issue #876: return the http status code if the response parsing fails\n err.statusCode = self.xhr && self.xhr.status ? self.xhr.status : null;\n return self.callback(err);\n }\n\n self.emit('response', res);\n\n if (err) {\n return self.callback(err, res);\n }\n\n if (res.status >= 200 && res.status < 300) {\n return self.callback(err, res);\n }\n\n var new_err = new Error(res.statusText || 'Unsuccessful HTTP response');\n new_err.original = err;\n new_err.response = res;\n new_err.status = res.status;\n\n self.callback(new_err, res);\n });\n}\n\n/**\n * Mixin `Emitter` and `requestBase`.\n */\n\nEmitter(Request.prototype);\nfor (var key in requestBase) {\n Request.prototype[key] = requestBase[key];\n}\n\n/**\n * Abort the request, and clear potential timeout.\n *\n * @return {Request}\n * @api public\n */\n\nRequest.prototype.abort = function(){\n if (this.aborted) return;\n this.aborted = true;\n this.xhr && this.xhr.abort();\n this.clearTimeout();\n this.emit('abort');\n return this;\n};\n\n/**\n * Set Content-Type to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.xml = 'application/xml';\n *\n * request.post('/')\n * .type('xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * request.post('/')\n * .type('application/xml')\n * .send(xmlstring)\n * .end(callback);\n *\n * @param {String} type\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.type = function(type){\n this.set('Content-Type', request.types[type] || type);\n return this;\n};\n\n/**\n * Set responseType to `val`. Presently valid responseTypes are 'blob' and \n * 'arraybuffer'.\n *\n * Examples:\n *\n * req.get('/')\n * .responseType('blob')\n * .end(callback);\n *\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.responseType = function(val){\n this._responseType = val;\n return this;\n};\n\n/**\n * Set Accept to `type`, mapping values from `request.types`.\n *\n * Examples:\n *\n * superagent.types.json = 'application/json';\n *\n * request.get('/agent')\n * .accept('json')\n * .end(callback);\n *\n * request.get('/agent')\n * .accept('application/json')\n * .end(callback);\n *\n * @param {String} accept\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.accept = function(type){\n this.set('Accept', request.types[type] || type);\n return this;\n};\n\n/**\n * Set Authorization field value with `user` and `pass`.\n *\n * @param {String} user\n * @param {String} pass\n * @param {Object} options with 'type' property 'auto' or 'basic' (default 'basic')\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.auth = function(user, pass, options){\n if (!options) {\n options = {\n type: 'basic'\n }\n }\n\n switch (options.type) {\n case 'basic':\n var str = btoa(user + ':' + pass);\n this.set('Authorization', 'Basic ' + str);\n break;\n\n case 'auto':\n this.username = user;\n this.password = pass;\n break;\n }\n return this;\n};\n\n/**\n* Add query-string `val`.\n*\n* Examples:\n*\n* request.get('/shoes')\n* .query('size=10')\n* .query({ color: 'blue' })\n*\n* @param {Object|String} val\n* @return {Request} for chaining\n* @api public\n*/\n\nRequest.prototype.query = function(val){\n if ('string' != typeof val) val = serialize(val);\n if (val) this._query.push(val);\n return this;\n};\n\n/**\n * Queue the given `file` as an attachment to the specified `field`,\n * with optional `filename`.\n *\n * ``` js\n * request.post('/upload')\n * .attach(new Blob(['<a id=\"a\"><b id=\"b\">hey!</b></a>'], { type: \"text/html\"}))\n * .end(callback);\n * ```\n *\n * @param {String} field\n * @param {Blob|File} file\n * @param {String} filename\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.attach = function(field, file, filename){\n this._getFormData().append(field, file, filename || file.name);\n return this;\n};\n\nRequest.prototype._getFormData = function(){\n if (!this._formData) {\n this._formData = new root.FormData();\n }\n return this._formData;\n};\n\n/**\n * Send `data` as the request body, defaulting the `.type()` to \"json\" when\n * an object is given.\n *\n * Examples:\n *\n * // manual json\n * request.post('/user')\n * .type('json')\n * .send('{\"name\":\"tj\"}')\n * .end(callback)\n *\n * // auto json\n * request.post('/user')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // manual x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send('name=tj')\n * .end(callback)\n *\n * // auto x-www-form-urlencoded\n * request.post('/user')\n * .type('form')\n * .send({ name: 'tj' })\n * .end(callback)\n *\n * // defaults to x-www-form-urlencoded\n * request.post('/user')\n * .send('name=tobi')\n * .send('species=ferret')\n * .end(callback)\n *\n * @param {String|Object} data\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.send = function(data){\n var obj = isObject(data);\n var type = this._header['content-type'];\n\n // merge\n if (obj && isObject(this._data)) {\n for (var key in data) {\n this._data[key] = data[key];\n }\n } else if ('string' == typeof data) {\n if (!type) this.type('form');\n type = this._header['content-type'];\n if ('application/x-www-form-urlencoded' == type) {\n this._data = this._data\n ? this._data + '&' + data\n : data;\n } else {\n this._data = (this._data || '') + data;\n }\n } else {\n this._data = data;\n }\n\n if (!obj || isHost(data)) return this;\n if (!type) this.type('json');\n return this;\n};\n\n/**\n * @deprecated\n */\nResponse.prototype.parse = function serialize(fn){\n if (root.console) {\n console.warn(\"Client-side parse() method has been renamed to serialize(). This method is not compatible with superagent v2.0\");\n }\n this.serialize(fn);\n return this;\n};\n\nResponse.prototype.serialize = function serialize(fn){\n this._parser = fn;\n return this;\n};\n\n/**\n * Invoke the callback with `err` and `res`\n * and handle arity check.\n *\n * @param {Error} err\n * @param {Response} res\n * @api private\n */\n\nRequest.prototype.callback = function(err, res){\n var fn = this._callback;\n this.clearTimeout();\n fn(err, res);\n};\n\n/**\n * Invoke callback with x-domain error.\n *\n * @api private\n */\n\nRequest.prototype.crossDomainError = function(){\n var err = new Error('Request has been terminated\\nPossible causes: the network is offline, Origin is not allowed by Access-Control-Allow-Origin, the page is being unloaded, etc.');\n err.crossDomain = true;\n\n err.status = this.status;\n err.method = this.method;\n err.url = this.url;\n\n this.callback(err);\n};\n\n/**\n * Invoke callback with timeout error.\n *\n * @api private\n */\n\nRequest.prototype.timeoutError = function(){\n var timeout = this._timeout;\n var err = new Error('timeout of ' + timeout + 'ms exceeded');\n err.timeout = timeout;\n this.callback(err);\n};\n\n/**\n * Enable transmission of cookies with x-domain requests.\n *\n * Note that for this to work the origin must not be\n * using \"Access-Control-Allow-Origin\" with a wildcard,\n * and also must set \"Access-Control-Allow-Credentials\"\n * to \"true\".\n *\n * @api public\n */\n\nRequest.prototype.withCredentials = function(){\n this._withCredentials = true;\n return this;\n};\n\n/**\n * Initiate request, invoking callback `fn(res)`\n * with an instanceof `Response`.\n *\n * @param {Function} fn\n * @return {Request} for chaining\n * @api public\n */\n\nRequest.prototype.end = function(fn){\n var self = this;\n var xhr = this.xhr = request.getXHR();\n var query = this._query.join('&');\n var timeout = this._timeout;\n var data = this._formData || this._data;\n\n // store callback\n this._callback = fn || noop;\n\n // state change\n xhr.onreadystatechange = function(){\n if (4 != xhr.readyState) return;\n\n // In IE9, reads to any property (e.g. status) off of an aborted XHR will\n // result in the error \"Could not complete the operation due to error c00c023f\"\n var status;\n try { status = xhr.status } catch(e) { status = 0; }\n\n if (0 == status) {\n if (self.timedout) return self.timeoutError();\n if (self.aborted) return;\n return self.crossDomainError();\n }\n self.emit('end');\n };\n\n // progress\n var handleProgress = function(e){\n if (e.total > 0) {\n e.percent = e.loaded / e.total * 100;\n }\n e.direction = 'download';\n self.emit('progress', e);\n };\n if (this.hasListeners('progress')) {\n xhr.onprogress = handleProgress;\n }\n try {\n if (xhr.upload && this.hasListeners('progress')) {\n xhr.upload.onprogress = handleProgress;\n }\n } catch(e) {\n // Accessing xhr.upload fails in IE from a web worker, so just pretend it doesn't exist.\n // Reported here:\n // https://connect.microsoft.com/IE/feedback/details/837245/xmlhttprequest-upload-throws-invalid-argument-when-used-from-web-worker-context\n }\n\n // timeout\n if (timeout && !this._timer) {\n this._timer = setTimeout(function(){\n self.timedout = true;\n self.abort();\n }, timeout);\n }\n\n // querystring\n if (query) {\n query = request.serializeObject(query);\n this.url += ~this.url.indexOf('?')\n ? '&' + query\n : '?' + query;\n }\n\n // initiate request\n if (this.username && this.password) {\n xhr.open(this.method, this.url, true, this.username, this.password);\n } else {\n xhr.open(this.method, this.url, true);\n }\n\n // CORS\n if (this._withCredentials) xhr.withCredentials = true;\n\n // body\n if ('GET' != this.method && 'HEAD' != this.method && 'string' != typeof data && !isHost(data)) {\n // serialize stuff\n var contentType = this._header['content-type'];\n var serialize = this._parser || request.serialize[contentType ? contentType.split(';')[0] : ''];\n if (!serialize && isJSON(contentType)) serialize = request.serialize['application/json'];\n if (serialize) data = serialize(data);\n }\n\n // set header fields\n for (var field in this.header) {\n if (null == this.header[field]) continue;\n xhr.setRequestHeader(field, this.header[field]);\n }\n\n if (this._responseType) {\n xhr.responseType = this._responseType;\n }\n\n // send stuff\n this.emit('request', this);\n\n // IE11 xhr.send(undefined) sends 'undefined' string as POST payload (instead of nothing)\n // We need null here if data is undefined\n xhr.send(typeof data !== 'undefined' ? data : null);\n return this;\n};\n\n\n/**\n * Expose `Request`.\n */\n\nrequest.Request = Request;\n\n/**\n * GET `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.get = function(url, data, fn){\n var req = request('GET', url);\n if ('function' == typeof data) fn = data, data = null;\n if (data) req.query(data);\n if (fn) req.end(fn);\n return req;\n};\n\n/**\n * HEAD `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.head = function(url, data, fn){\n var req = request('HEAD', url);\n if ('function' == typeof data) fn = data, data = null;\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n\n/**\n * DELETE `url` with optional callback `fn(res)`.\n *\n * @param {String} url\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nfunction del(url, fn){\n var req = request('DELETE', url);\n if (fn) req.end(fn);\n return req;\n};\n\nrequest['del'] = del;\nrequest['delete'] = del;\n\n/**\n * PATCH `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.patch = function(url, data, fn){\n var req = request('PATCH', url);\n if ('function' == typeof data) fn = data, data = null;\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n\n/**\n * POST `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed} data\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.post = function(url, data, fn){\n var req = request('POST', url);\n if ('function' == typeof data) fn = data, data = null;\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n\n/**\n * PUT `url` with optional `data` and callback `fn(res)`.\n *\n * @param {String} url\n * @param {Mixed|Function} data or fn\n * @param {Function} fn\n * @return {Request}\n * @api public\n */\n\nrequest.put = function(url, data, fn){\n var req = request('PUT', url);\n if ('function' == typeof data) fn = data, data = null;\n if (data) req.send(data);\n if (fn) req.end(fn);\n return req;\n};\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/superagent/lib/client.js?"
)
},
'./node_modules/vlibras/node_modules/superagent/lib/is-object.js':
function (module, exports) {
eval(
"/**\n * Check if `obj` is an object.\n *\n * @param {Object} obj\n * @return {Boolean}\n * @api private\n */\n\nfunction isObject(obj) {\n return null != obj && 'object' == typeof obj;\n}\n\nmodule.exports = isObject;\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/superagent/lib/is-object.js?"
)
},
'./node_modules/vlibras/node_modules/superagent/lib/request-base.js':
function (module, exports, __webpack_require__) {
eval(
"/**\n * Module of mixed-in functions shared between node and client code\n */\nvar isObject = __webpack_require__(/*! ./is-object */ \"./node_modules/vlibras/node_modules/superagent/lib/is-object.js\");\n\n/**\n * Clear previous timeout.\n *\n * @return {Request} for chaining\n * @api public\n */\n\nexports.clearTimeout = function _clearTimeout(){\n this._timeout = 0;\n clearTimeout(this._timer);\n return this;\n};\n\n/**\n * Force given parser\n *\n * Sets the body parser no matter type.\n *\n * @param {Function}\n * @api public\n */\n\nexports.parse = function parse(fn){\n this._parser = fn;\n return this;\n};\n\n/**\n * Set timeout to `ms`.\n *\n * @param {Number} ms\n * @return {Request} for chaining\n * @api public\n */\n\nexports.timeout = function timeout(ms){\n this._timeout = ms;\n return this;\n};\n\n/**\n * Faux promise support\n *\n * @param {Function} fulfill\n * @param {Function} reject\n * @return {Request}\n */\n\nexports.then = function then(fulfill, reject) {\n return this.end(function(err, res) {\n err ? reject(err) : fulfill(res);\n });\n}\n\n/**\n * Allow for extension\n */\n\nexports.use = function use(fn) {\n fn(this);\n return this;\n}\n\n\n/**\n * Get request header `field`.\n * Case-insensitive.\n *\n * @param {String} field\n * @return {String}\n * @api public\n */\n\nexports.get = function(field){\n return this._header[field.toLowerCase()];\n};\n\n/**\n * Get case-insensitive header `field` value.\n * This is a deprecated internal API. Use `.get(field)` instead.\n *\n * (getHeader is no longer used internally by the superagent code base)\n *\n * @param {String} field\n * @return {String}\n * @api private\n * @deprecated\n */\n\nexports.getHeader = exports.get;\n\n/**\n * Set header `field` to `val`, or multiple fields with one object.\n * Case-insensitive.\n *\n * Examples:\n *\n * req.get('/')\n * .set('Accept', 'application/json')\n * .set('X-API-Key', 'foobar')\n * .end(callback);\n *\n * req.get('/')\n * .set({ Accept: 'application/json', 'X-API-Key': 'foobar' })\n * .end(callback);\n *\n * @param {String|Object} field\n * @param {String} val\n * @return {Request} for chaining\n * @api public\n */\n\nexports.set = function(field, val){\n if (isObject(field)) {\n for (var key in field) {\n this.set(key, field[key]);\n }\n return this;\n }\n this._header[field.toLowerCase()] = val;\n this.header[field] = val;\n return this;\n};\n\n/**\n * Remove header `field`.\n * Case-insensitive.\n *\n * Example:\n *\n * req.get('/')\n * .unset('User-Agent')\n * .end(callback);\n *\n * @param {String} field\n */\nexports.unset = function(field){\n delete this._header[field.toLowerCase()];\n delete this.header[field];\n return this;\n};\n\n/**\n * Write the field `name` and `val` for \"multipart/form-data\"\n * request bodies.\n *\n * ``` js\n * request.post('/upload')\n * .field('foo', 'bar')\n * .end(callback);\n * ```\n *\n * @param {String} name\n * @param {String|Blob|File|Buffer|fs.ReadStream} val\n * @return {Request} for chaining\n * @api public\n */\nexports.field = function(name, val) {\n this._getFormData().append(name, val);\n return this;\n};\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/superagent/lib/request-base.js?"
)
},
'./node_modules/vlibras/node_modules/superagent/lib/request.js': function (
module,
exports
) {
eval(
"// The node and browser modules expose versions of this with the\n// appropriate constructor function bound as first argument\n/**\n * Issue a request:\n *\n * Examples:\n *\n * request('GET', '/users').end(callback)\n * request('/users').end(callback)\n * request('/users', callback)\n *\n * @param {String} method\n * @param {String|Function} url or callback\n * @return {Request}\n * @api public\n */\n\nfunction request(RequestConstructor, method, url) {\n // callback\n if ('function' == typeof url) {\n return new RequestConstructor('GET', method).end(url);\n }\n\n // url first\n if (2 == arguments.length) {\n return new RequestConstructor('GET', method);\n }\n\n return new RequestConstructor(method, url);\n}\n\nmodule.exports = request;\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/superagent/lib/request.js?"
)
},
'./node_modules/vlibras/node_modules/superagent/node_modules/component-emitter/index.js':
function (module, exports, __webpack_require__) {
eval(
"\r\n/**\r\n * Expose `Emitter`.\r\n */\r\n\r\nif (true) {\r\n module.exports = Emitter;\r\n}\r\n\r\n/**\r\n * Initialize a new `Emitter`.\r\n *\r\n * @api public\r\n */\r\n\r\nfunction Emitter(obj) {\r\n if (obj) return mixin(obj);\r\n};\r\n\r\n/**\r\n * Mixin the emitter properties.\r\n *\r\n * @param {Object} obj\r\n * @return {Object}\r\n * @api private\r\n */\r\n\r\nfunction mixin(obj) {\r\n for (var key in Emitter.prototype) {\r\n obj[key] = Emitter.prototype[key];\r\n }\r\n return obj;\r\n}\r\n\r\n/**\r\n * Listen on the given `event` with `fn`.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.on =\r\nEmitter.prototype.addEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n (this._callbacks['$' + event] = this._callbacks['$' + event] || [])\r\n .push(fn);\r\n return this;\r\n};\r\n\r\n/**\r\n * Adds an `event` listener that will be invoked a single\r\n * time then automatically removed.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.once = function(event, fn){\r\n function on() {\r\n this.off(event, on);\r\n fn.apply(this, arguments);\r\n }\r\n\r\n on.fn = fn;\r\n this.on(event, on);\r\n return this;\r\n};\r\n\r\n/**\r\n * Remove the given callback for `event` or all\r\n * registered callbacks.\r\n *\r\n * @param {String} event\r\n * @param {Function} fn\r\n * @return {Emitter}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.off =\r\nEmitter.prototype.removeListener =\r\nEmitter.prototype.removeAllListeners =\r\nEmitter.prototype.removeEventListener = function(event, fn){\r\n this._callbacks = this._callbacks || {};\r\n\r\n // all\r\n if (0 == arguments.length) {\r\n this._callbacks = {};\r\n return this;\r\n }\r\n\r\n // specific event\r\n var callbacks = this._callbacks['$' + event];\r\n if (!callbacks) return this;\r\n\r\n // remove all handlers\r\n if (1 == arguments.length) {\r\n delete this._callbacks['$' + event];\r\n return this;\r\n }\r\n\r\n // remove specific handler\r\n var cb;\r\n for (var i = 0; i < callbacks.length; i++) {\r\n cb = callbacks[i];\r\n if (cb === fn || cb.fn === fn) {\r\n callbacks.splice(i, 1);\r\n break;\r\n }\r\n }\r\n return this;\r\n};\r\n\r\n/**\r\n * Emit `event` with the given args.\r\n *\r\n * @param {String} event\r\n * @param {Mixed} ...\r\n * @return {Emitter}\r\n */\r\n\r\nEmitter.prototype.emit = function(event){\r\n this._callbacks = this._callbacks || {};\r\n var args = [].slice.call(arguments, 1)\r\n , callbacks = this._callbacks['$' + event];\r\n\r\n if (callbacks) {\r\n callbacks = callbacks.slice(0);\r\n for (var i = 0, len = callbacks.length; i < len; ++i) {\r\n callbacks[i].apply(this, args);\r\n }\r\n }\r\n\r\n return this;\r\n};\r\n\r\n/**\r\n * Return array of callbacks for `event`.\r\n *\r\n * @param {String} event\r\n * @return {Array}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.listeners = function(event){\r\n this._callbacks = this._callbacks || {};\r\n return this._callbacks['$' + event] || [];\r\n};\r\n\r\n/**\r\n * Check if this emitter has `event` handlers.\r\n *\r\n * @param {String} event\r\n * @return {Boolean}\r\n * @api public\r\n */\r\n\r\nEmitter.prototype.hasListeners = function(event){\r\n return !! this.listeners(event).length;\r\n};\r\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/superagent/node_modules/component-emitter/index.js?"
)
},
'./node_modules/vlibras/node_modules/url-join/lib/url-join.js': function (
module,
exports,
__webpack_require__
) {
eval(
"var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__;(function (name, context, definition) {\n if ( true && module.exports) module.exports = definition();\n else if (true) !(__WEBPACK_AMD_DEFINE_FACTORY__ = (definition),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ?\n\t\t\t\t(__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) :\n\t\t\t\t__WEBPACK_AMD_DEFINE_FACTORY__),\n\t\t\t\t__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));\n else {}\n})('urljoin', this, function () {\n\n function normalize (strArray) {\n var resultArray = [];\n if (strArray.length === 0) { return ''; }\n\n if (typeof strArray[0] !== 'string') {\n throw new TypeError('Url must be a string. Received ' + strArray[0]);\n }\n\n // If the first part is a plain protocol, we combine it with the next part.\n if (strArray[0].match(/^[^/:]+:\\/*$/) && strArray.length > 1) {\n var first = strArray.shift();\n strArray[0] = first + strArray[0];\n }\n\n // There must be two or three slashes in the file protocol, two slashes in anything else.\n if (strArray[0].match(/^file:\\/\\/\\//)) {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1:///');\n } else {\n strArray[0] = strArray[0].replace(/^([^/:]+):\\/*/, '$1://');\n }\n\n for (var i = 0; i < strArray.length; i++) {\n var component = strArray[i];\n\n if (typeof component !== 'string') {\n throw new TypeError('Url must be a string. Received ' + component);\n }\n\n if (component === '') { continue; }\n\n if (i > 0) {\n // Removing the starting slashes for each component but the first.\n component = component.replace(/^[\\/]+/, '');\n }\n if (i < strArray.length - 1) {\n // Removing the ending slashes for each component but the last.\n component = component.replace(/[\\/]+$/, '');\n } else {\n // For the last component we will combine multiple slashes to a single one.\n component = component.replace(/[\\/]+$/, '/');\n }\n\n resultArray.push(component);\n\n }\n\n var str = resultArray.join('/');\n // Each input component is now separated by a single slash except the possible first plain protocol part.\n\n // remove trailing slash before parameters or hash\n str = str.replace(/\\/(\\?|&|#[^!])/g, '$1');\n\n // replace ? in parameters with &\n var parts = str.split('?');\n str = parts.shift() + (parts.length > 0 ? '?': '') + parts.join('&');\n\n return str;\n }\n\n return function () {\n var input;\n\n if (typeof arguments[0] === 'object') {\n input = arguments[0];\n } else {\n input = [].slice.call(arguments);\n }\n\n return normalize(input);\n };\n\n});\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/node_modules/url-join/lib/url-join.js?"
)
},
'./node_modules/vlibras/src/GlosaTranslator.js': function (
module,
exports,
__webpack_require__
) {
eval(
"var request = __webpack_require__(/*! superagent */ \"./node_modules/vlibras/node_modules/superagent/lib/client.js\");\r\n\r\nfunction GlosaTranslator(endpoint) {\r\n this.endpoint = endpoint;\r\n}\r\n\r\nGlosaTranslator.prototype.translate = function (text, domain, callback) {\r\n let time = 5;\r\n let hasTimeout = false;\r\n const size = text.split(' ').length;\r\n\r\n if (size > 50) time += size * 0.4 / 10;\r\n\r\n const timeout = setTimeout(() => {\r\n hasTimeout = true;\r\n callback(undefined, 'timeout_error');\r\n }, time * 1000);\r\n\r\n request.post(this.endpoint, { text: text, domain: domain }).end(\r\n function (err, response) {\r\n if (hasTimeout) return;\r\n\r\n clearTimeout(timeout);\r\n if (err) callback(undefined, err);\r\n else callback(response.text);\r\n }\r\n );\r\n};\r\n\r\nmodule.exports = GlosaTranslator;\r\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/src/GlosaTranslator.js?"
)
},
'./node_modules/vlibras/src/Player.js': function (
module,
exports,
__webpack_require__
) {
eval(
'var window = __webpack_require__(/*! window */ "window");\r\nvar assign = __webpack_require__(/*! object-assign */ "./node_modules/vlibras/node_modules/object-assign/index.js");\r\nvar inherits = __webpack_require__(/*! inherits */ "./node_modules/vlibras/node_modules/inherits/inherits_browser.js");\r\nvar path = __webpack_require__(/*! path */ "./node_modules/path-browserify/index.js");\r\nvar url = __webpack_require__(/*! url-join */ "./node_modules/vlibras/node_modules/url-join/lib/url-join.js");\r\nvar EventEmitter = __webpack_require__(/*! events */ "./node_modules/events/events.js").EventEmitter;\r\n\r\nvar config = __webpack_require__(/*! ./config.js */ "./node_modules/vlibras/src/config.js");\r\nvar PlayerManagerAdapter = __webpack_require__(/*! ./PlayerManagerAdapter.js */ "./node_modules/vlibras/src/PlayerManagerAdapter.js");\r\nvar GlosaTranslator = __webpack_require__(/*! ./GlosaTranslator.js */ "./node_modules/vlibras/src/GlosaTranslator.js");\r\nvar globalGlosaLenght = "";\r\n\r\nvar document = window.document;\r\nvar location = window.location;\r\n\r\nconst STATUSES = {\r\n idle: "idle",\r\n preparing: "preparing",\r\n playing: "playing",\r\n};\r\n\r\nfunction Player(options) {\r\n this.options = assign(\r\n {\r\n translator: config.translatorUrl,\r\n targetPath: "target",\r\n },\r\n options\r\n );\r\n\r\n this.playerManager = new PlayerManagerAdapter();\r\n this.translator = new GlosaTranslator(this.options.translator);\r\n\r\n this.translated = false;\r\n this.text = undefined;\r\n this.gloss = undefined;\r\n this.loaded = false;\r\n this.progress = null;\r\n this.gameContainer = null;\r\n this.player = null;\r\n this.status = STATUSES.idle;\r\n\r\n this.playerManager.on("load", () => {\r\n this.loaded = true;\r\n this.emit("load");\r\n\r\n this.playerManager.setBaseUrl(config.dictionaryUrl);\r\n\r\n if (this.options.onLoad) {\r\n this.options.onLoad();\r\n } else {\r\n this.play(null, true);\r\n }\r\n });\r\n\r\n this.playerManager.on("progress", (progress) => {\r\n this.emit("animation:progress", progress);\r\n });\r\n\r\n this.playerManager.on("stateChange", (isPlaying, isPaused, isLoading) => {\r\n if (isPaused) {\r\n this.emit("animation:pause");\r\n } else if (isPlaying && !isPaused) {\r\n this.emit("animation:play");\r\n this.changeStatus(STATUSES.playing);\r\n } else if (!isPlaying && !isLoading) {\r\n this.emit("animation:end");\r\n this.changeStatus(STATUSES.idle);\r\n }\r\n });\r\n\r\n this.playerManager.on("CounterGloss", (counter, glosaLenght) => {\r\n this.emit("response:glosa", counter, glosaLenght);\r\n globalGlosaLenght = glosaLenght;\r\n });\r\n\r\n this.playerManager.on("GetAvatar", (avatar) => {\r\n this.emit("GetAvatar", avatar);\r\n });\r\n\r\n this.playerManager.on("FinishWelcome", (bool) => {\r\n this.emit("stop:welcome", bool);\r\n });\r\n}\r\n\r\ninherits(Player, EventEmitter);\r\n\r\nPlayer.prototype.translate = function (text) {\r\n this.emit("translate:start");\r\n\r\n if (this.loaded) {\r\n this.stop();\r\n }\r\n\r\n this.text = text;\r\n\r\n this.translator.translate(text, location.host, (gloss, error) => {\r\n if (error) {\r\n this.play(text.toUpperCase());\r\n this.emit("error", error === \'timeout_error\'\r\n ? error : "translation_error");\r\n return;\r\n }\r\n\r\n this.play(gloss, true);\r\n this.emit("translate:end");\r\n });\r\n};\r\n\r\nPlayer.prototype.play = function (glosa, fromTranslation = false) {\r\n this.translated = fromTranslation;\r\n this.gloss = glosa || this.gloss;\r\n\r\n if (this.gloss !== undefined && this.loaded) {\r\n this.changeStatus(STATUSES.preparing);\r\n this.playerManager.play(this.gloss);\r\n }\r\n};\r\n\r\nPlayer.prototype.playWellcome = function () {\r\n this.playerManager.playWellcome();\r\n};\r\n\r\nPlayer.prototype.continue = function () {\r\n this.playerManager.play();\r\n};\r\n\r\nPlayer.prototype.repeat = function () {\r\n this.play();\r\n};\r\n\r\nPlayer.prototype.pause = function () {\r\n this.playerManager.pause();\r\n};\r\n\r\nPlayer.prototype.stop = function () {\r\n this.playerManager.stop();\r\n};\r\n\r\nPlayer.prototype.setSpeed = function (speed) {\r\n this.playerManager.setSpeed(speed);\r\n};\r\n\r\nPlayer.prototype.setPersonalization = function (personalization) {\r\n this.playerManager.setPersonalization(personalization);\r\n};\r\n\r\nPlayer.prototype.changeAvatar = function (avatarName) {\r\n this.playerManager.changeAvatar(avatarName);\r\n};\r\n\r\nPlayer.prototype.toggleSubtitle = function () {\r\n this.playerManager.toggleSubtitle();\r\n};\r\n\r\nPlayer.prototype.setRegion = function (region) {\r\n this.playerManager.setRegion(region);\r\n};\r\n\r\nPlayer.prototype.load = function (wrapper) {\r\n this.gameContainer = document.createElement("div");\r\n this.gameContainer.setAttribute("id", "gameContainer");\r\n this.gameContainer.classList.add("emscripten");\r\n\r\n if ("function" == typeof this.options.progress) {\r\n this.progress = new this.options.progress(wrapper);\r\n }\r\n\r\n wrapper.appendChild(this.gameContainer);\r\n\r\n this._initializeTarget();\r\n};\r\n\r\nPlayer.prototype._getTargetScript = function () {\r\n return url(this.options.targetPath, "UnityLoader.js");\r\n //return path.join(this.options.targetPath, \'UnityLoader.js\');\r\n};\r\n\r\nPlayer.prototype._initializeTarget = function () {\r\n //const targetSetup = path.join(this.options.targetPath, \'playerweb.json\');\r\n const targetSetup = url(this.options.targetPath, "playerweb.json");\r\n const targetScript = document.createElement("script");\r\n\r\n targetScript.src = this._getTargetScript();\r\n targetScript.onload = () => {\r\n this.player = UnityLoader.instantiate("gameContainer", targetSetup, {\r\n compatibilityCheck: (_, accept, deny) => {\r\n if (UnityLoader.SystemInfo.hasWebGL) {\r\n return accept();\r\n }\r\n\r\n this.onError("unsupported");\r\n alert("Seu navegador não suporta WEBGL");\r\n console.error("Seu navegador não suporta WEBGL");\r\n deny();\r\n },\r\n });\r\n\r\n this.playerManager.setPlayerReference(this.player);\r\n };\r\n\r\n document.body.appendChild(targetScript);\r\n};\r\n\r\nPlayer.prototype.changeStatus = function (status) {\r\n switch (status) {\r\n case STATUSES.idle:\r\n if (this.status === STATUSES.playing) {\r\n this.status = status;\r\n this.emit("gloss:end", globalGlosaLenght);\r\n }\r\n break;\r\n\r\n case STATUSES.preparing:\r\n this.status = status;\r\n break;\r\n\r\n case STATUSES.playing:\r\n if (this.status === STATUSES.preparing) {\r\n this.status = status;\r\n this.emit("gloss:start");\r\n }\r\n break;\r\n }\r\n};\r\n\r\nmodule.exports = Player;\r\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/src/Player.js?'
)
},
'./node_modules/vlibras/src/PlayerManagerAdapter.js': function (
module,
exports,
__webpack_require__
) {
eval(
'var window = __webpack_require__(/*! window */ "window");\r\nvar inherits = __webpack_require__(/*! inherits */ "./node_modules/vlibras/node_modules/inherits/inherits_browser.js");\r\nvar EventEmitter = __webpack_require__(/*! events */ "./node_modules/events/events.js").EventEmitter;\r\n\r\nvar GAME_OBJECT = "PlayerManager";\r\n\r\nfunction PlayerManagerAdapter() {\r\n if (PlayerManagerAdapter.instance) return PlayerManagerAdapter.instance;\r\n\r\n this.subtitle = true;\r\n\r\n this.on(\r\n "load",\r\n function () {\r\n this._send("initRandomAnimationsProcess");\r\n }.bind(this)\r\n );\r\n\r\n PlayerManagerAdapter.instance = this;\r\n}\r\n\r\ninherits(PlayerManagerAdapter, EventEmitter);\r\n\r\nPlayerManagerAdapter.prototype.setPlayerReference = function (player) {\r\n this.player = player;\r\n};\r\n\r\nPlayerManagerAdapter.prototype._send = function (method, params) {\r\n this.player.SendMessage(GAME_OBJECT, method, params);\r\n};\r\n\r\nPlayerManagerAdapter.prototype.play = function (glosa) {\r\n if (glosa) {\r\n this._send("playNow", glosa);\r\n } else {\r\n this._send("setPauseState", 0);\r\n }\r\n};\r\n\r\nPlayerManagerAdapter.prototype.setPersonalization = function (personalization) {\r\n this.player.SendMessage("Avatar", "setURL", personalization);\r\n};\r\n\r\nPlayerManagerAdapter.prototype.pause = function () {\r\n this._send("setPauseState", 1);\r\n};\r\n\r\nPlayerManagerAdapter.prototype.stop = function () {\r\n this._send("stopAll");\r\n};\r\n\r\nPlayerManagerAdapter.prototype.setSpeed = function (speed) {\r\n this._send("setSlider", speed);\r\n};\r\n\r\nPlayerManagerAdapter.prototype.toggleSubtitle = function () {\r\n this.subtitle = !this.subtitle;\r\n this._send("setSubtitlesState", toInt(this.subtitle));\r\n};\r\n\r\nPlayerManagerAdapter.prototype.setRegion = function (region) {\r\n this._send("setRegion", region);\r\n};\r\n\r\nPlayerManagerAdapter.prototype.playWellcome = function () {\r\n this._send("playWellcome");\r\n};\r\n\r\nPlayerManagerAdapter.prototype.changeAvatar = function (avatarName) {\r\n this._send("Change", avatarName);\r\n};\r\n\r\nPlayerManagerAdapter.prototype.setBaseUrl = function (url) {\r\n this._send("setBaseUrl", url);\r\n};\r\n\r\nwindow.onLoadPlayer = function () {\r\n PlayerManagerAdapter.instance.emit("load");\r\n};\r\n\r\nwindow.updateProgress = function (progress) {\r\n PlayerManagerAdapter.instance.emit("progress", progress);\r\n};\r\n\r\nwindow.onPlayingStateChange = function (\r\n isPlaying,\r\n isPaused,\r\n isPlayingIntervalAnimation,\r\n isLoading,\r\n isRepeatable\r\n) {\r\n PlayerManagerAdapter.instance.emit(\r\n "stateChange",\r\n toBoolean(isPlaying),\r\n toBoolean(isPaused),\r\n toBoolean(isLoading)\r\n );\r\n};\r\n\r\nwindow.CounterGloss = function (counter, glosaLenght) {\r\n PlayerManagerAdapter.instance.emit("CounterGloss", counter, glosaLenght);\r\n};\r\n\r\nwindow.GetAvatar = function (avatar) {\r\n PlayerManagerAdapter.instance.emit("GetAvatar", avatar);\r\n};\r\n\r\nwindow.FinishWelcome = function (bool) {\r\n PlayerManagerAdapter.instance.emit("FinishWelcome", bool);\r\n};\r\n\r\nfunction toInt(boolean) {\r\n return !boolean ? 0 : 1;\r\n}\r\n\r\nfunction toBoolean(bool) {\r\n return bool != "False";\r\n}\r\n\r\nmodule.exports = PlayerManagerAdapter;\r\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/src/PlayerManagerAdapter.js?'
)
},
'./node_modules/vlibras/src/config.js': function (module, exports) {
eval(
"// prod urls\nexports.translatorUrl = 'https://traducao2.vlibras.gov.br/translate';\nexports.dictionaryUrl = 'https://dicionario2.vlibras.gov.br/2018.3.1/WEBGL/';\n\n// homolog urls\n// exports.translatorUrl = 'https://traducao2-dth.vlibras.gov.br/dl/translate';\n// exports.dictionaryUrl = 'https://dicionario2-dth.vlibras.gov.br/2018.3.1/WEBGL/';\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/src/config.js?"
)
},
'./node_modules/vlibras/src/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
'var window = __webpack_require__(/*! window */ "window");\r\nvar Player = __webpack_require__(/*! ./Player.js */ "./node_modules/vlibras/src/Player.js");\r\n\r\nvar VLibras = {\r\n Player: Player\r\n};\r\n\r\nwindow.VLibras = VLibras;\r\nmodule.exports = VLibras;\r\n\n\n//# sourceURL=webpack://VLibras/./node_modules/vlibras/src/index.js?'
)
},
'./plugin/Plugin.js': function (module, exports, __webpack_require__) {
eval(
"const VLibras = __webpack_require__(/*! vlibras */ \"./node_modules/vlibras/src/index.js\");\n\nconst Settings = __webpack_require__(/*! components/Settings */ \"./plugin/components/Settings/index.js\");\nconst SettingsBtn = __webpack_require__(/*! components/SettingsBtn */ \"./plugin/components/SettingsBtn/index.js\");\nconst InfoScreen = __webpack_require__(/*! components/InfoScreen */ \"./plugin/components/InfoScreen/index.js\");\nconst Dictionary = __webpack_require__(/*! components/Dictionary */ \"./plugin/components/Dictionary/index.js\");\nconst Controls = __webpack_require__(/*! components/Controls */ \"./plugin/components/Controls/index.js\");\n\nconst MessageBox = __webpack_require__(/*! components/MessageBox */ \"./plugin/components/MessageBox/index.js\");\nconst Box = __webpack_require__(/*! components/Box */ \"./plugin/components/Box/index.js\");\nconst SettingsCloseBtn = __webpack_require__(/*! components/SettingsCloseBtn */ \"./plugin/components/SettingsCloseBtn/index.js\");\nconst CloseScreen = __webpack_require__(/*! components/CloseScreen */ \"./plugin/components/CloseScreen/index.js\");\nconst RateBox = __webpack_require__(/*! components/RateBox */ \"./plugin/components/RateBox/index.js\");\nconst SuggestionScreen = __webpack_require__(/*! components/SuggestionScreen */ \"./plugin/components/SuggestionScreen/index.js\");\nconst TranslatorScreen = __webpack_require__(/*! components/AdditionalOptions/TranslatorScreen */ \"./plugin/components/AdditionalOptions/TranslatorScreen/index.js\");\nconst WidgetHelp = __webpack_require__(/*! components/AdditionalOptions/WidgetHelp */ \"./plugin/components/AdditionalOptions/WidgetHelp/index.js\")\nconst AdditionalOptions = __webpack_require__(/*! components/AdditionalOptions */ \"./plugin/components/AdditionalOptions/index.js\");\nconst ChangeAvatar = __webpack_require__(/*! components/AdditionalOptions/ChangeAvatar */ \"./plugin/components/AdditionalOptions/ChangeAvatar/index.js\");\n\nconst url = __webpack_require__(/*! url-join */ \"./node_modules/url-join/lib/url-join.js\");\nconst { REVIEW_URL } = __webpack_require__(/*! ./config */ \"./plugin/config.js\");\n\n__webpack_require__(/*! ./scss/styles.scss */ \"./plugin/scss/styles.scss\");\n\nfunction Plugin(options) {\n this.player = new VLibras.Player({\n // onLoad: options.playWellcome && (() => this.player.playWellcome()),\n targetPath: options.rootPath ? url(options.rootPath, '/target') : 'target',\n personalization: options.personalization,\n opacity: options.opacity,\n wrapper: options.wrapper,\n });\n\n this.opacity = options.opacity;\n this.wrapper = options.wrapper;\n\n if (this.opacity) {\n if (this.opacity.includes[(0.0, 0.25, 0.5, 0.75, 1.0)]) {\n this.opacity = parseFloat(this.opacity);\n } else {\n this.opacity = 0.0;\n }\n } else {\n this.opacity = 0.0;\n }\n\n this.rootPath = options.rootPath;\n this.personalization = options.personalization;\n this.element = document.querySelector('[vp]');\n\n this.dictionary = new Dictionary(this.player);\n this.controls = new Controls(this.player, this.dictionary);\n this.Box = new Box();\n this.info = new InfoScreen(this.Box);\n this.settings = new Settings(\n this.player,\n options,\n this.opacity\n );\n this.settingBtnClose = new SettingsCloseBtn();\n this.closeScreen = new CloseScreen(\n this.dictionary,\n this.info,\n this.settings,\n this.settingBtnClose\n );\n this.settingsBtn = new SettingsBtn(\n this.player,\n this.settings,\n this.dictionary,\n this.info,\n this.settingBtnClose,\n options\n );\n this.messageBox = new MessageBox();\n this.suggestionScreen = new SuggestionScreen(this.player);\n this.translatorScreen = new TranslatorScreen(this.player);\n this.widgetHelp = new WidgetHelp();\n this.rateBox = new RateBox(this.messageBox, this.suggestionScreen);\n this.ChangeAvatar = new ChangeAvatar(this.player);\n this.additionalOptions = new AdditionalOptions(\n this.player,\n this.translatorScreen,\n this.widgetHelp\n );\n\n this.loadingRef = null;\n\n this.additionalOptions.load(this.element.querySelector('[vp-additional-options]'));\n this.messageBox.load(this.element.querySelector('[vp-message-box]'));\n this.rateBox.load(this.element.querySelector('[vp-rate-box]'));\n this.suggestionScreen.load(\n this.element.querySelector('[vp-suggestion-screen]')\n );\n this.translatorScreen.load(\n this.element.querySelector('[vp-translator-screen]')\n );\n\n // this.widgetHelp.load(this.element.querySelector('[vp-widget-help]'));\n\n this.player.load(this.element);\n\n this.player.on('load', () => {\n if (this.personalization == undefined) {\n this.player.setPersonalization('');\n } else {\n this.player.setPersonalization(this.personalization);\n }\n\n if (this.wrapper) {\n this.wrapper.style.background = `rgba(235,235,235, ${1 - this.opacity})`;\n }\n\n this.controls.load(this.element.querySelector('[vp-controls]'));\n this.Box.load(this.element.querySelector('[vp-box]'));\n this.settingBtnClose.load(\n this.element\n .querySelector('[vp-box]')\n .querySelector('[settings-btn-close]'),\n this.closeScreen\n );\n this.settingsBtn.load(\n this.element.querySelector('[vp-box]').querySelector('[settings-btn]'),\n () =>\n this.dictionary.load(\n this.element.querySelector('[vp-dictionary]'),\n this.closeScreen\n ),\n this.element.querySelector('[vp-dictionary]'),\n this.rootPath\n );\n this.settings.load(this.element.querySelector('[vp-settings]'));\n this.info.load(this.element.querySelector('[vp-info-screen]'));\n this.ChangeAvatar.load(this.element.querySelector('[vp-change-avatar]'));\n\n this.loadImages();\n });\n\n this.info.on('show', () => {\n this.player.pause();\n });\n\n window.addEventListener('vp-widget-close', (event) => {\n this.player.stop();\n this.rateBox.hide();\n this.suggestionScreen.hide();\n this.translatorScreen.hide();\n });\n\n let control = 0;\n this.player.on('translate:start', () => {\n control = 1;\n this.ChangeAvatar.hide();\n this.controls.setProgress();\n this.loadingRef = this.messageBox.show('info', 'Traduzindo...');\n });\n\n this.player.on('translate:end', () => {\n this.messageBox.hide(this.loadingRef);\n });\n\n this.player.on('gloss:start', () => {\n control = 0;\n this.ChangeAvatar.hide();\n this.rateBox.hide();\n this.suggestionScreen.hide();\n this.translatorScreen.hide();\n });\n\n this.player.on('gloss:end', (globalGlosaLenght) => {\n if (control == 0) {\n this.ChangeAvatar.show();\n }\n\n if (this.player.translated && control == 0) {\n this.suggestionScreen.setGloss(this.player.gloss);\n this.rateBox.show();\n }\n\n control = 0;\n });\n\n this.player.on('stop:welcome', (bool) => {\n if (bool) {\n this.ChangeAvatar.show();\n this.additionalOptions.show();\n }\n });\n\n this.player.on(\n 'error',\n function (err) {\n switch (err) {\n case 'compatibility_error':\n this.messageBox.show(\n 'warning',\n 'O seu computador não suporta o WebGL. Por favor, atualize os drivers de vídeo.'\n );\n break;\n case 'translation_error':\n this.messageBox.show(\n 'warning',\n 'Não foi possível estabelecer conexão com o serviço de tradução do VLibras.',\n 3000\n );\n break;\n case 'internal_error':\n this.messageBox.show(\n 'warning',\n 'Ops! Ocorreu um problema, por favor entre em contato com a gente.',\n 3000\n );\n break;\n case 'timeout_error':\n this.messageBox.show(\n 'warning',\n 'Tempo de requisição excedido.',\n 3000\n );\n break;\n }\n }.bind(this)\n );\n\n this.loadFont();\n this.loadImages();\n}\n\nPlugin.prototype.translate = function (text) {\n this.player.translate(text);\n};\n\nPlugin.prototype.sendReview = function (rate, review) {\n const body = JSON.stringify({\n text: this.player.text,\n translation: this.player.gloss,\n rating: rate,\n review,\n });\n\n const http = new XMLHttpRequest();\n http.open('POST', REVIEW_URL);\n http.setRequestHeader('Content-type', 'application/json');\n http.send(body);\n http.onload = () => {\n this.rateBox.hide();\n this.suggestionScreen.hide();\n this.messageBox.show('success', 'Obrigado pela contribuição!', 3000);\n };\n};\n\nPlugin.prototype.buildAbsolutePath = function (path) {\n return this.rootPath ? this.rootPath + '/' + path : path;\n};\n\nPlugin.prototype.loadImages = function () {\n this.element.querySelectorAll('img[data-src]').forEach((image) => {\n const imagePath = image.attributes['data-src'].value;\n image.src = this.buildAbsolutePath(imagePath);\n });\n};\n\nPlugin.prototype.loadFont = function () {\n const fontPath = this.buildAbsolutePath('assets/OpenSans-Semibold.ttf');\n const font = new FontFace('Open Sans', 'url(' + fontPath + ')');\n\n font\n .load()\n .then((loaded) => {\n document.fonts.add(loaded);\n })\n .catch((error) => {\n console.error('Error loading font face:', error);\n });\n};\n\nmodule.exports = Plugin;\n\n\n//# sourceURL=webpack://VLibras/./plugin/Plugin.js?"
)
},
'./plugin/assets/icons/additionalOptions/help.svg': function (
module,
exports
) {
eval(
'module.exports = "<svg viewBox=\\"0 0 20 20\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M9.95 16C10.3 16 10.596 15.879 10.838 15.637C11.08 15.395 11.2007 15.0993 11.2 14.75C11.2 14.4 11.0793 14.104 10.838 13.862C10.5967 13.62 10.3007 13.4993 9.95 13.5C9.6 13.5 9.30433 13.621 9.063 13.863C8.82167 14.105 8.70067 14.4007 8.7 14.75C8.7 15.1 8.821 15.396 9.063 15.638C9.305 15.88 9.60067 16.0007 9.95 16ZM9.05 12.15H10.9C10.9 11.6 10.9627 11.1667 11.088 10.85C11.2133 10.5333 11.5673 10.1 12.15 9.55C12.5833 9.11667 12.925 8.704 13.175 8.312C13.425 7.92 13.55 7.44933 13.55 6.9C13.55 5.96667 13.2083 5.25 12.525 4.75C11.8417 4.25 11.0333 4 10.1 4C9.15 4 8.379 4.25 7.787 4.75C7.195 5.25 6.78267 5.85 6.55 6.55L8.2 7.2C8.28333 6.9 8.471 6.575 8.763 6.225C9.055 5.875 9.50067 5.7 10.1 5.7C10.6333 5.7 11.0333 5.846 11.3 6.138C11.5667 6.43 11.7 6.75067 11.7 7.1C11.7 7.43333 11.6 7.746 11.4 8.038C11.2 8.33 10.95 8.60067 10.65 8.85C9.91667 9.5 9.46667 9.99167 9.3 10.325C9.13333 10.6583 9.05 11.2667 9.05 12.15ZM10 20C8.61667 20 7.31667 19.7373 6.1 19.212C4.88333 18.6867 3.825 17.9743 2.925 17.075C2.025 16.175 1.31267 15.1167 0.788 13.9C0.263333 12.6833 0.000666667 11.3833 0 10C0 8.61667 0.262667 7.31667 0.788 6.1C1.31333 4.88333 2.02567 3.825 2.925 2.925C3.825 2.025 4.88333 1.31267 6.1 0.788C7.31667 0.263333 8.61667 0.000666667 10 0C11.3833 0 12.6833 0.262667 13.9 0.788C15.1167 1.31333 16.175 2.02567 17.075 2.925C17.975 3.825 18.6877 4.88333 19.213 6.1C19.7383 7.31667 20.0007 8.61667 20 10C20 11.3833 19.7373 12.6833 19.212 13.9C18.6867 15.1167 17.9743 16.175 17.075 17.075C16.175 17.975 15.1167 18.6877 13.9 19.213C12.6833 19.7383 11.3833 20.0007 10 20ZM10 18C12.2333 18 14.125 17.225 15.675 15.675C17.225 14.125 18 12.2333 18 10C18 7.76667 17.225 5.875 15.675 4.325C14.125 2.775 12.2333 2 10 2C7.76667 2 5.875 2.775 4.325 4.325C2.775 5.875 2 7.76667 2 10C2 12.2333 2.775 14.125 4.325 15.675C5.875 17.225 7.76667 18 10 18Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/additionalOptions/help.svg?'
)
},
'./plugin/assets/icons/additionalOptions/translator.svg': function (
module,
exports
) {
eval(
'module.exports = "<svg viewBox=\\"0 0 19 19\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M5.39719 7.97288L4.88063 9.5H3.5625L5.77362 3.5625H7.29838L9.5 9.5H8.11419L7.59762 7.97288H5.39719ZM7.33756 7.09888L6.53125 4.69775H6.47306L5.66675 7.09888H7.33756Z\\" fill=\\"#FDFDFD\\"></path><path d=\\"M0 2.375C0 1.74511 0.250223 1.14102 0.695621 0.695621C1.14102 0.250223 1.74511 0 2.375 0H10.6875C11.3174 0 11.9215 0.250223 12.3669 0.695621C12.8123 1.14102 13.0625 1.74511 13.0625 2.375V5.9375H16.625C17.2549 5.9375 17.859 6.18772 18.3044 6.63312C18.7498 7.07852 19 7.68261 19 8.3125V16.625C19 17.2549 18.7498 17.859 18.3044 18.3044C17.859 18.7498 17.2549 19 16.625 19H8.3125C7.68261 19 7.07852 18.7498 6.63312 18.3044C6.18772 17.859 5.9375 17.2549 5.9375 16.625V13.0625H2.375C1.74511 13.0625 1.14102 12.8123 0.695621 12.3669C0.250223 11.9215 0 11.3174 0 10.6875V2.375ZM2.375 1.1875C2.06006 1.1875 1.75801 1.31261 1.53531 1.53531C1.31261 1.75801 1.1875 2.06006 1.1875 2.375V10.6875C1.1875 11.0024 1.31261 11.3045 1.53531 11.5272C1.75801 11.7499 2.06006 11.875 2.375 11.875H10.6875C11.0024 11.875 11.3045 11.7499 11.5272 11.5272C11.7499 11.3045 11.875 11.0024 11.875 10.6875V2.375C11.875 2.06006 11.7499 1.75801 11.5272 1.53531C11.3045 1.31261 11.0024 1.1875 10.6875 1.1875H2.375ZM10.8514 13.0566C11.0806 13.414 11.3287 13.7489 11.5995 14.0612C10.7112 14.744 9.61281 15.2499 8.3125 15.5954C8.52388 15.8531 8.84806 16.3495 8.97156 16.625C10.3075 16.1987 11.4416 15.6227 12.3987 14.8509C13.3214 15.6406 14.4638 16.2343 15.8781 16.5989C16.036 16.2972 16.3697 15.7997 16.625 15.542C15.2891 15.2416 14.1823 14.7179 13.2763 14.0173C14.0849 13.1302 14.7274 12.0567 15.2012 10.7433H16.625V9.5H13.0625V10.7433H13.9709C13.5933 11.7456 13.0922 12.5792 12.4604 13.2727C12.2859 13.0868 12.1214 12.8918 11.9676 12.6884C11.6325 12.9033 11.2485 13.0299 10.8514 13.0566Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/additionalOptions/translator.svg?'
)
},
'./plugin/assets/icons/avatars/guga.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 14 19\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path fill-rule=\\"evenodd\\" clip-rule=\\"evenodd\\" d=\\"M3.48336 0.162225C3.11944 0.342375 2.91798 0.625103 2.83877 1.06725L2.78711 1.35516H2.25916C1.96878 1.35516 1.70497 1.3814 1.67289 1.41349C1.64081 1.44557 1.73023 1.56912 1.87163 1.68815C2.22831 1.98824 2.20775 2.22408 1.80023 2.50648C0.689716 3.27602 0.0857602 4.52975 0.0121373 6.21815C-0.0792539 8.31258 0.309426 9.14982 2.42023 11.4052C2.91749 11.9366 3.28042 12.3936 3.28042 12.4884C3.28042 12.7837 3.37626 12.9127 3.5977 12.9155C3.71731 12.917 3.90371 12.992 4.01204 13.0823C4.19869 13.2376 4.20626 13.2797 4.15542 13.8815C4.12589 14.231 4.06683 14.5286 4.02405 14.5429C3.66548 14.6634 3.38555 14.9804 3.17258 15.5071C2.86221 16.2749 2.54765 17.5808 2.48472 18.3625L2.43347 19H5.85945H9.28542V18.708C9.28542 18.3362 9.16738 18.1111 8.33869 16.9024C7.37394 15.4951 7.36201 15.4669 7.42412 14.7323C7.48203 14.0471 7.60312 13.8013 7.97839 13.6073C8.21991 13.4823 8.26227 13.4867 8.81819 13.6926C9.52456 13.9545 10.4033 14.147 10.9482 14.1592C11.4604 14.1708 11.6814 13.9762 11.8796 13.3393C11.9596 13.082 12.0956 12.7806 12.1817 12.6695C12.2815 12.5408 12.321 12.3983 12.2906 12.2769C12.2591 12.1515 12.2838 12.0707 12.3631 12.0404C12.4293 12.0149 12.5073 11.8859 12.5364 11.7535C12.5654 11.6213 12.6634 11.4733 12.754 11.4247C12.9411 11.3246 13.1517 10.8774 13.1517 10.5802C13.1517 10.4707 13.0223 10.193 12.8641 9.96305C12.3946 9.28061 12.3001 8.96103 12.3505 8.2262C12.3815 7.775 12.4618 7.43272 12.6194 7.0818C12.8306 6.61102 12.8405 6.53633 12.7855 5.83309C12.7276 5.09282 12.7288 5.086 12.8982 5.17673C12.9923 5.22707 13.0694 5.30284 13.0694 5.34512C13.0694 5.38732 13.1254 5.4004 13.1939 5.37416C13.2623 5.34783 13.3682 5.36782 13.4294 5.41858C13.519 5.49294 13.5505 5.43708 13.5928 5.12836C13.6786 4.50236 13.65 4.25032 13.4576 3.93781C13.1207 3.39078 10.892 1.58451 10.0796 1.20019C8.5997 0.50015 6.02693 0.384821 4.73939 0.96089C4.28145 1.1658 4.25973 1.16794 4.10187 1.02514C3.91876 0.859381 3.88133 0.416985 4.03722 0.261102C4.09151 0.20681 4.2251 0.111844 4.30917 0.111844C4.39324 0.111844 4.4189 0.125372 4.39094 0.0801288C4.30711 -0.0554362 3.83732 -0.0129898 3.48336 0.162225Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/avatars/guga.svg?'
)
},
'./plugin/assets/icons/avatars/hozana.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 16 22\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path fill-rule=\\"evenodd\\" clip-rule=\\"evenodd\\" d=\\"M8.40241 0.631978C8.9808 0.716853 9.16038 0.769907 9.81694 1.04987C10.3368 1.27153 10.4929 1.29756 11.002 1.2474C11.6047 1.18803 11.7875 1.22545 12.3658 1.52658C12.8876 1.79833 13.5098 2.24078 13.872 2.5977C14.4245 3.14203 14.9568 4.25334 15.0293 5.01382C15.0647 5.38446 14.9857 7.1975 14.9278 7.34425C14.9086 7.39291 14.8658 7.44131 14.8327 7.45183C14.7562 7.47609 14.6277 7.39278 14.5799 7.28788C14.5312 7.18102 14.4891 7.18571 14.4275 7.30485C14.3831 7.3907 14.3824 7.42398 14.4218 7.57474C14.4598 7.72042 14.4599 7.76892 14.4221 7.89206C14.3283 8.19814 14.2787 8.4955 14.3 8.62366C14.3568 8.96556 14.6937 9.52705 14.9792 9.75568C15.2453 9.96881 15.3003 10.0666 15.3003 10.3267C15.3003 10.6665 15.1939 10.8196 14.7916 11.0586C14.6387 11.1494 14.5516 11.2255 14.5166 11.2989C14.4673 11.4023 14.469 11.413 14.5628 11.5945C14.6409 11.7456 14.6533 11.7958 14.6253 11.8482C14.5523 11.9853 14.4879 12.0542 14.3383 12.1551L14.1839 12.2593L14.234 12.363C14.2616 12.4201 14.3052 12.5052 14.3309 12.5523C14.3745 12.6319 14.3708 12.6476 14.2788 12.7803C14.2244 12.8586 14.1423 12.9774 14.0963 13.0443C14.0306 13.1397 14.003 13.2409 13.9676 13.5165C13.9339 13.7776 13.8975 13.9171 13.8248 14.0627C13.7087 14.2953 13.6829 14.3282 13.5244 14.4466C13.206 14.6844 12.786 14.7047 11.9036 14.5249C11.1224 14.3658 11.0853 14.3615 10.871 14.4058C10.4166 14.4997 10.2533 14.677 10.0621 15.284C9.99727 15.49 9.90139 15.7734 9.84912 15.9137C9.79681 16.0541 9.75401 16.1957 9.75401 16.2285C9.75401 16.2613 9.93187 16.5275 10.1492 16.8201C11.2261 18.2696 11.886 19.4454 12.422 20.8695C12.4894 21.0487 12.5541 21.2336 12.5656 21.2805L12.5866 21.3658L10.5841 21.39C9.48268 21.4033 7.68231 21.4033 6.58328 21.3901L4.58502 21.3659L4.55007 21.0821C4.50428 20.7101 4.57726 20.0497 4.72516 19.4983C4.92653 18.7473 5.14849 18.2057 5.7315 17.0427C5.95151 16.6038 6.14734 16.1935 6.16669 16.1308C6.23603 15.906 6.27071 15.5826 6.2401 15.4464C6.20395 15.2854 6.24697 15.1027 6.33175 15.0574C6.36458 15.0398 6.55761 15.0097 6.76071 14.9906C6.97433 14.9704 7.14001 14.9395 7.15378 14.9172C7.16691 14.8959 7.19423 14.7756 7.21449 14.6497C7.23475 14.5239 7.26396 14.3722 7.2794 14.3126C7.3333 14.1045 7.29559 14.0971 7.00117 14.2575C6.70538 14.4188 6.60806 14.4244 6.64275 14.2781C6.65385 14.2313 6.69525 14.1715 6.73472 14.1453C6.84301 14.0735 7.04311 13.8612 7.139 13.7163C7.22338 13.5888 7.22368 13.5861 7.16759 13.4685C7.08155 13.2881 6.71062 12.8597 6.4514 12.6414C6.32429 12.5343 5.98043 12.2827 5.68721 12.0822C5.01593 11.6232 4.69259 11.3551 4.46415 11.0682C4.26897 10.8231 3.97262 10.2518 3.86042 9.90446C3.77171 9.62961 3.74552 9.6073 3.58075 9.66599C3.50992 9.6912 3.35668 9.71341 3.24025 9.7153C3.12381 9.71719 2.92032 9.72956 2.78803 9.74282C2.58949 9.76269 2.49563 9.75383 2.25064 9.69211C1.30751 9.45452 0.61103 8.74315 0.24792 7.64659C-0.14333 6.46499 -0.0664988 5.01141 0.442454 3.96631C0.741533 3.35216 1.23967 2.8749 1.73511 2.72775C1.82591 2.70078 2.07109 2.6575 2.27992 2.63161C2.61375 2.59021 2.70153 2.59038 3.00692 2.6332C3.40378 2.68883 3.53744 2.72111 3.75291 2.81347C3.94842 2.8973 3.99763 2.87568 4.21949 2.60855C4.47066 2.30618 5.03925 1.82136 5.49593 1.52016C6.23512 1.03267 6.87897 0.783293 7.71846 0.659336C7.95133 0.624943 8.15651 0.59827 8.17443 0.600061C8.19234 0.601852 8.29493 0.616215 8.40241 0.631978Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/avatars/hozana.svg?'
)
},
'./plugin/assets/icons/avatars/icaro.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 15 21\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M14.1978 0.544955C14.2458 0.210663 14.2796 0.0704356 14.3199 0.0394909C14.3947 -0.0180806 14.4181 -0.0148594 14.4941 0.0634105C14.5638 0.135272 14.8299 0.96204 14.918 1.38067C14.968 1.61832 14.9679 1.65365 14.9162 1.8705C14.8195 2.2757 14.5298 2.61636 14.0643 2.87211C13.9634 2.92752 13.671 3.02735 13.4145 3.09393C12.7982 3.2539 12.43 3.38011 11.8959 3.61448C11.6529 3.72109 11.4477 3.8145 11.4397 3.82211C11.4318 3.82968 11.4413 3.85237 11.4609 3.87252C11.4861 3.8985 11.5269 3.89284 11.6016 3.85306C11.716 3.79206 11.8364 3.81022 11.8364 3.88846C11.8364 3.91546 11.8226 3.93756 11.8057 3.93756C11.7889 3.93756 11.7293 3.97725 11.6734 4.02574C11.5234 4.15589 11.4894 4.32692 11.5567 4.61324C11.7076 5.25451 11.7067 5.52503 11.5522 6.04509C11.4789 6.2921 11.4698 6.81096 11.534 7.09029C11.5972 7.36533 11.8085 7.79674 11.996 8.03336C12.224 8.32105 12.4668 8.50309 12.8532 8.67601C13.4486 8.94241 13.6198 9.11639 13.5225 9.35614C13.4568 9.51823 13.1041 9.96167 12.8936 10.1468C12.6951 10.3214 12.4511 10.4862 12.1418 10.6546C12.0221 10.7198 11.9129 10.8069 11.8878 10.8572C11.8635 10.9058 11.8328 11.0955 11.8195 11.2788C11.8062 11.4621 11.7785 11.6263 11.7577 11.6438C11.737 11.6613 11.6571 11.693 11.5802 11.7141C11.407 11.7619 11.3819 11.7994 11.4772 11.8681C11.6465 11.9904 11.6434 12.0468 11.4506 12.3516C11.1485 12.8294 10.9934 13.328 10.854 14.2696C10.7599 14.9051 10.6978 15.0198 10.3989 15.1108C10.2332 15.1612 8.31063 14.8339 7.95594 14.6949C7.90365 14.6744 7.83733 14.6821 7.74787 14.719C7.63548 14.7654 7.59539 14.8135 7.47013 15.0525C7.38959 15.2062 7.2519 15.4981 7.16411 15.7012L7.00451 16.0706L7.14762 16.2798C7.28471 16.4802 7.29259 16.5055 7.33504 16.8818C7.36971 17.1889 7.39833 17.308 7.46628 17.4275C7.53446 17.5474 7.54483 17.5908 7.51441 17.6286C7.48124 17.6698 7.46385 17.6688 7.39451 17.622C7.25057 17.5248 7.26772 17.6057 7.42293 17.756C7.61201 17.9391 7.84294 18.3089 7.96355 18.6217C8.01441 18.7537 8.12776 19.1623 8.21542 19.5298C8.30289 19.8964 8.47092 20.5571 8.58938 21H0.959429C0.972833 20.9627 -0.0135542 20.9263 0.000141312 20.891C0.146141 20.5154 0.428168 19.9945 0.769199 19.4705C1.2794 18.6866 1.76783 17.7435 2.19379 16.7198C2.54164 15.8839 2.95523 15.5 2.95523 15.5C2.84759 15.4403 3.16022 15.5357 3.16022 15.4334C3.16022 15.3632 3.45179 14.7941 3.65539 14.4669C3.85737 14.1423 3.99114 14.0582 4.20765 14.1198C4.39653 14.1736 4.48399 14.1353 4.55316 13.9687C4.75265 13.488 5.07214 12.5469 5.17406 12.1399C5.32465 11.5384 5.32352 11.5324 4.89067 10.6326C4.25887 9.3194 3.56252 8.25152 2.69243 7.26163C2.01712 6.49329 1.68417 6.03056 1.3444 5.38799C1.26142 5.23107 1.18081 5.1027 1.16522 5.1027C1.11675 5.1027 1.09817 5.21939 1.12899 5.33021C1.16851 5.47219 1.11845 5.55875 1.05017 5.46657C0.953403 5.33604 0.933424 5.07515 0.977437 4.51787C1.01673 4.0206 1.026 3.97536 1.11406 3.84963C1.16602 3.77551 1.30298 3.64038 1.41839 3.54937C1.62699 3.38491 1.70767 3.27806 1.93026 2.87139C2.11897 2.52661 2.68432 1.99398 2.76896 2.08122C2.78422 2.09695 2.73043 2.26946 2.64945 2.46466C2.56847 2.65982 2.50907 2.83791 2.51748 2.86046C2.52779 2.88815 2.65314 2.84607 2.90465 2.73051C3.10919 2.63651 3.65802 2.39002 4.12424 2.18276C5.03322 1.7787 6.098 1.24253 6.76746 0.851763C7.27191 0.557326 7.38533 0.504758 7.75266 0.395098C8.24122 0.249284 8.67719 0.228038 9.98524 0.286329C10.6217 0.314703 11.1565 0.346847 11.1736 0.357779C11.2438 0.4025 11.1958 0.466754 11.0421 0.533681C10.8788 0.604823 10.791 0.705573 10.8332 0.773596C10.8628 0.821367 12.164 1.41189 12.4756 1.51898C12.6085 1.56469 12.837 1.62809 12.9833 1.65992C13.5575 1.78487 13.8101 1.72322 13.9718 1.41881C14.0934 1.18989 14.1197 1.08811 14.1978 0.544955Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/avatars/icaro.svg?'
)
},
'./plugin/assets/icons/back.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M23.3758 14.9511H11.5981L16.7436 9.80561C17.1548 9.39439 17.1548 8.71957 16.7436 8.30835C16.646 8.21061 16.5302 8.13306 16.4026 8.08015C16.2751 8.02723 16.1383 8 16.0002 8C15.8621 8 15.7254 8.02723 15.5978 8.08015C15.4703 8.13306 15.3544 8.21061 15.2569 8.30835L8.30835 15.2569C8.21061 15.3544 8.13306 15.4703 8.08015 15.5978C8.02724 15.7254 8 15.8621 8 16.0002C8 16.1383 8.02724 16.2751 8.08015 16.4026C8.13306 16.5302 8.21061 16.646 8.30835 16.7436L15.2569 23.6921C15.3545 23.7897 15.4704 23.8671 15.5979 23.92C15.7255 23.9728 15.8622 24 16.0002 24C16.1383 24 16.275 23.9728 16.4025 23.92C16.5301 23.8671 16.646 23.7897 16.7436 23.6921C16.8412 23.5945 16.9186 23.4786 16.9715 23.351C17.0243 23.2235 17.0515 23.0868 17.0515 22.9487C17.0515 22.8107 17.0243 22.674 16.9715 22.5464C16.9186 22.4189 16.8412 22.303 16.7436 22.2054L11.5981 17.0599H23.3758C23.9557 17.0599 24.4302 16.5854 24.4302 16.0055C24.4302 15.4256 23.9557 14.9511 23.3758 14.9511Z\\" fill=\\"#0F2B54\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/back.svg?'
)
},
'./plugin/assets/icons/facebook.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M18.808 10.656H20.312V8.11202C19.5838 8.0363 18.8521 7.99892 18.12 8.00002C15.944 8.00002 14.456 9.32802 14.456 11.76V13.856H12V16.704H14.456V24H17.4V16.704H19.848L20.216 13.856H17.4V12.04C17.4 11.2 17.624 10.656 18.808 10.656Z\\" fill=\\"#0D459D\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/facebook.svg?'
)
},
'./plugin/assets/icons/feedback/arrow-up.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M22.6317 19.8897C22.5157 20.0059 22.3779 20.0981 22.2262 20.161C22.0745 20.224 21.9119 20.2563 21.7477 20.2563C21.5835 20.2563 21.4209 20.224 21.2692 20.161C21.1175 20.0981 20.9798 20.0059 20.8638 19.8897L15.9989 15.0248L11.134 19.8897C10.8996 20.1241 10.5816 20.2558 10.2501 20.2558C9.91855 20.2558 9.60058 20.1241 9.36614 19.8897C9.1317 19.6552 9 19.3373 9 19.0057C9 18.6742 9.1317 18.3562 9.36614 18.1218L15.1212 12.3667C15.2372 12.2505 15.375 12.1582 15.5267 12.0953C15.6784 12.0324 15.841 12 16.0052 12C16.1694 12 16.332 12.0324 16.4837 12.0953C16.6353 12.1582 16.7731 12.2505 16.8891 12.3667L22.6442 18.1218C23.1207 18.5982 23.1207 19.4007 22.6317 19.8897Z\\" fill=\\"#0F2B54\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/feedback/arrow-up.svg?'
)
},
'./plugin/assets/icons/feedback/like-line.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M27.4162 16.6862C27.9462 15.9858 28.2396 15.1277 28.2396 14.2348C28.2396 12.8182 27.4477 11.4774 26.1731 10.7297C25.845 10.5372 25.4714 10.4359 25.091 10.4363H17.5254L17.7147 6.55881C17.7589 5.62179 17.4276 4.73209 16.784 4.05378C16.4681 3.71944 16.0871 3.45343 15.6644 3.27219C15.2416 3.09094 14.7862 2.99831 14.3263 3.00002C12.6857 3.00002 11.2344 4.10426 10.799 5.68489L8.08894 15.4968H4.00959C3.45116 15.4968 3 15.948 3 16.5064V27.9904C3 28.5488 3.45116 29 4.00959 29H22.9803C23.2706 29 23.5545 28.9432 23.8164 28.8296C25.3181 28.1892 26.2867 26.7221 26.2867 25.0942C26.2867 24.6966 26.2299 24.3054 26.1164 23.9268C26.6464 23.2264 26.9398 22.3683 26.9398 21.4754C26.9398 21.0779 26.883 20.6867 26.7694 20.3081C27.2995 19.6077 27.5929 18.7496 27.5929 17.8567C27.5866 17.4592 27.5298 17.0648 27.4162 16.6862ZM5.27157 26.7284V17.7684H7.82708V26.7284H5.27157ZM25.3497 15.5914L24.6588 16.1909L25.0973 16.9922C25.2418 17.2562 25.3167 17.5526 25.315 17.8535C25.315 18.3741 25.0878 18.8694 24.6966 19.2102L24.0057 19.8096L24.4442 20.611C24.5887 20.875 24.6636 21.1714 24.6619 21.4723C24.6619 21.9928 24.4348 22.4882 24.0435 22.8289L23.3526 23.4284L23.7911 24.2297C23.9356 24.4937 24.0105 24.7901 24.0088 25.091C24.0088 25.7977 23.5924 26.435 22.9488 26.7253H9.84625V17.6674L12.9854 6.2938C13.0664 6.00228 13.2401 5.74509 13.4804 5.5612C13.7206 5.37732 14.0143 5.27675 14.3168 5.27475C14.5566 5.27475 14.7932 5.34415 14.9825 5.48613C15.2949 5.71959 15.4621 6.07295 15.4431 6.44839L15.1403 12.7078H25.0594C25.621 13.0517 25.9681 13.6322 25.9681 14.2348C25.9681 14.7554 25.7409 15.2476 25.3497 15.5914Z\\" fill=\\"#838891\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/feedback/like-line.svg?'
)
},
'./plugin/assets/icons/feedback/like-solid.svg': function (
module,
exports
) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M27.4162 16.6862C27.9462 15.9858 28.2396 15.1277 28.2396 14.2348C28.2396 12.8182 27.4477 11.4774 26.1731 10.7297C25.845 10.5372 25.4714 10.4359 25.091 10.4363H17.5254L17.7147 6.55881C17.7589 5.62179 17.4276 4.73209 16.784 4.05378C16.4681 3.71944 16.0871 3.45343 15.6644 3.27219C15.2416 3.09094 14.7862 2.99831 14.3263 3.00002C12.6857 3.00002 11.2344 4.10426 10.799 5.68489L8.08894 15.4968H8.07948V29H22.9803C23.2706 29 23.5545 28.9432 23.8164 28.8296C25.3181 28.1892 26.2867 26.7221 26.2867 25.0942C26.2867 24.6966 26.2299 24.3054 26.1163 23.9268C26.6464 23.2264 26.9398 22.3683 26.9398 21.4754C26.9398 21.0779 26.883 20.6867 26.7694 20.3081C27.2995 19.6077 27.5929 18.7496 27.5929 17.8567C27.5866 17.4592 27.5298 17.0648 27.4162 16.6862ZM3 16.5064V27.9904C3 28.5488 3.45116 29 4.00959 29H6.06031V15.4968H4.00959C3.45116 15.4968 3 15.948 3 16.5064Z\\" fill=\\"#0D459D\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/feedback/like-solid.svg?'
)
},
'./plugin/assets/icons/fullscreen.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M8 10.5L8 8L10.5 8L10.5 6L6 6L6 10.5L8 10.5Z\\" fill=\\"black\\"></path><path d=\\"M16 13.5L16 16L13.5 16L13.5 18H18L18 13.5H16Z\\" fill=\\"black\\"></path><path d=\\"M10.5 16H8L8 13.5H6L6 18H10.5V16Z\\" fill=\\"black\\"></path><path d=\\"M13.5 8L16 8L16 10.5L18 10.5V6L13.5 6V8Z\\" fill=\\"black\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/fullscreen.svg?'
)
},
'./plugin/assets/icons/header/about.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M15.12 20V20.08H15.2H16.8H16.88V20V15.2V15.12H16.8H15.2H15.12V15.2V20ZM16.6271 12.1731L16.6269 12.1729C16.4575 12.0042 16.2468 11.92 16 11.92C15.7532 11.92 15.5427 12.0042 15.3738 12.173C15.2045 12.3423 15.12 12.5531 15.12 12.8C15.12 13.0468 15.2045 13.2574 15.3738 13.4262C15.5426 13.5955 15.7532 13.68 16 13.68C16.2469 13.68 16.4577 13.5955 16.627 13.4262C16.7958 13.2573 16.88 13.0468 16.88 12.8C16.88 12.5532 16.7958 12.3425 16.6271 12.1731ZM12.8483 8.55614L12.8483 8.55615C11.8661 8.98026 11.0109 9.55599 10.2834 10.2834C9.55599 11.0109 8.98053 11.8661 8.55695 12.8483C8.13217 13.8321 7.92 14.8829 7.92 16C7.92 17.1171 8.13217 18.1679 8.55695 19.1517C8.98053 20.1339 9.55599 20.9891 10.2834 21.7166C11.0109 22.444 11.8661 23.0195 12.8483 23.443C13.8321 23.8678 14.8829 24.08 16 24.08C17.1171 24.08 18.1679 23.8678 19.1517 23.443C20.1339 23.0195 20.9891 22.444 21.7166 21.7166C22.444 20.9891 23.0195 20.1339 23.443 19.1517C23.8678 18.1679 24.08 17.1171 24.08 16C24.08 14.8829 23.8678 13.8321 23.443 12.8483C23.0195 11.8661 22.444 11.0109 21.7166 10.2834C20.9891 9.55599 20.1339 8.98026 19.1517 8.55615L19.1517 8.55614C18.1679 8.1319 17.1171 7.92 16 7.92C14.8829 7.92 13.8321 8.1319 12.8483 8.55614ZM20.4834 20.4834C19.2587 21.7081 17.7659 22.32 16 22.32C14.2341 22.32 12.7413 21.7081 11.5166 20.4834C10.2919 19.2587 9.68 17.7659 9.68 16C9.68 14.2341 10.2919 12.7413 11.5166 11.5166C12.7413 10.2919 14.2341 9.68 16 9.68C17.7659 9.68 19.2587 10.2919 20.4834 11.5166C21.7081 12.7413 22.32 14.2341 22.32 16C22.32 17.7659 21.7081 19.2587 20.4834 20.4834Z\\" fill=\\"#FDFDFD\\" stroke=\\"#FDFDFD\\" stroke-width=\\"0.16\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/header/about.svg?'
)
},
'./plugin/assets/icons/header/close.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path fill-rule=\\"evenodd\\" clip-rule=\\"evenodd\\" d=\\"M10.2733 10.2849C10.4483 10.11 10.6856 10.0117 10.9331 10.0117C11.1806 10.0117 11.418 10.11 11.593 10.2849L15.5998 14.2917L19.6066 10.2849C19.6927 10.1958 19.7957 10.1247 19.9096 10.0758C20.0234 10.0269 20.1459 10.0011 20.2698 10C20.3938 9.99896 20.5167 10.0226 20.6314 10.0695C20.7461 10.1164 20.8503 10.1857 20.9379 10.2734C21.0255 10.361 21.0948 10.4652 21.1418 10.5799C21.1887 10.6946 21.2123 10.8175 21.2112 10.9414C21.2102 11.0654 21.1844 11.1878 21.1355 11.3017C21.0866 11.4156 21.0155 11.5186 20.9263 11.6047L16.9195 15.6115L20.9263 19.6183C21.0963 19.7943 21.1904 20.0301 21.1883 20.2748C21.1862 20.5195 21.088 20.7536 20.915 20.9266C20.7419 21.0997 20.5078 21.1978 20.2631 21.2C20.0184 21.2021 19.7826 21.108 19.6066 20.938L15.5998 16.9312L11.593 20.938C11.417 21.108 11.1812 21.2021 10.9365 21.2C10.6918 21.1978 10.4577 21.0997 10.2846 20.9266C10.1116 20.7536 10.0134 20.5195 10.0113 20.2748C10.0092 20.0301 10.1033 19.7943 10.2733 19.6183L14.2801 15.6115L10.2733 11.6047C10.0983 11.4296 10 11.1923 10 10.9448C10 10.6973 10.0983 10.46 10.2733 10.2849V10.2849Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/header/close.svg?'
)
},
'./plugin/assets/icons/header/dictionary.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M19.4351 18.0629H18.7124L18.4563 17.8159C19.3838 16.7401 19.8935 15.3667 19.8925 13.9463C19.8925 12.7702 19.5438 11.6206 18.8904 10.6427C18.237 9.66484 17.3083 8.90269 16.2218 8.45263C15.1353 8.00258 13.9397 7.88482 12.7862 8.11426C11.6327 8.3437 10.5732 8.91002 9.74162 9.74162C8.91002 10.5732 8.3437 11.6327 8.11426 12.7862C7.88482 13.9397 8.00258 15.1353 8.45263 16.2218C8.90269 17.3083 9.66484 18.237 10.6427 18.8904C11.6206 19.5438 12.7702 19.8925 13.9463 19.8925C15.4191 19.8925 16.773 19.3528 17.8159 18.4563L18.0629 18.7124V19.4351L22.6369 24L24 22.6369L19.4351 18.0629ZM13.9463 18.0629C11.6684 18.0629 9.82962 16.2241 9.82962 13.9463C9.82962 11.6684 11.6684 9.82962 13.9463 9.82962C16.2241 9.82962 18.0629 11.6684 18.0629 13.9463C18.0629 16.2241 16.2241 18.0629 13.9463 18.0629Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/header/dictionary.svg?'
)
},
'./plugin/assets/icons/header/settings.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M16.1726 19.34C15.3929 19.34 14.6451 19.0303 14.0937 18.4789C13.5424 17.9275 13.2326 17.1797 13.2326 16.4C13.2326 15.6203 13.5424 14.8725 14.0937 14.3211C14.6451 13.7697 15.3929 13.46 16.1726 13.46C16.9524 13.46 17.7002 13.7697 18.2515 14.3211C18.8029 14.8725 19.1126 15.6203 19.1126 16.4C19.1126 17.1797 18.8029 17.9275 18.2515 18.4789C17.7002 19.0303 16.9524 19.34 16.1726 19.34ZM22.4138 17.2148C22.4474 16.946 22.4726 16.6772 22.4726 16.4C22.4726 16.1228 22.4474 15.8456 22.4138 15.56L24.1862 14.1908C24.3458 14.0648 24.3878 13.838 24.287 13.6532L22.607 10.7468C22.5062 10.562 22.2794 10.4864 22.0946 10.562L20.003 11.402C19.5662 11.0744 19.1126 10.7888 18.5834 10.5788L18.2726 8.3528C18.2556 8.25386 18.204 8.16416 18.1272 8.09958C18.0503 8.03501 17.953 7.99973 17.8526 8H14.4926C14.2826 8 14.1062 8.1512 14.0726 8.3528L13.7618 10.5788C13.2326 10.7888 12.779 11.0744 12.3422 11.402L10.2506 10.562C10.0658 10.4864 9.83904 10.562 9.73824 10.7468L8.05824 13.6532C7.94904 13.838 7.99944 14.0648 8.15904 14.1908L9.93144 15.56C9.89784 15.8456 9.87264 16.1228 9.87264 16.4C9.87264 16.6772 9.89784 16.946 9.93144 17.2148L8.15904 18.6092C7.99944 18.7352 7.94904 18.962 8.05824 19.1468L9.73824 22.0532C9.83904 22.238 10.0658 22.3052 10.2506 22.238L12.3422 21.3896C12.779 21.7256 13.2326 22.0112 13.7618 22.2212L14.0726 24.4472C14.1062 24.6488 14.2826 24.8 14.4926 24.8H17.8526C18.0626 24.8 18.239 24.6488 18.2726 24.4472L18.5834 22.2212C19.1126 22.0028 19.5662 21.7256 20.003 21.3896L22.0946 22.238C22.2794 22.3052 22.5062 22.238 22.607 22.0532L24.287 19.1468C24.3878 18.962 24.3458 18.7352 24.1862 18.6092L22.4138 17.2148Z\\" fill=\\"#FDFDFD\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/header/settings.svg?'
)
},
'./plugin/assets/icons/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
'const playIcon = __webpack_require__(/*! ./play.svg */ "./plugin/assets/icons/play.svg");\nconst pauseIcon = __webpack_require__(/*! ./pause.svg */ "./plugin/assets/icons/pause.svg");\nconst restartIcon = __webpack_require__(/*! ./restart.svg */ "./plugin/assets/icons/restart.svg");\nconst subtitleIcon = __webpack_require__(/*! ./subtitle.svg */ "./plugin/assets/icons/subtitle.svg");\nconst IcaroIcon = __webpack_require__(/*! ./avatars/icaro.svg */ "./plugin/assets/icons/avatars/icaro.svg");\nconst hozanaIcon = __webpack_require__(/*! ./avatars/hozana.svg */ "./plugin/assets/icons/avatars/hozana.svg");\nconst gugaIcon = __webpack_require__(/*! ./avatars/guga.svg */ "./plugin/assets/icons/avatars/guga.svg");\nconst aboutIcon = __webpack_require__(/*! ./header/about.svg */ "./plugin/assets/icons/header/about.svg");\nconst closeIcon = __webpack_require__(/*! ./header/close.svg */ "./plugin/assets/icons/header/close.svg");\nconst dictionaryIcon = __webpack_require__(/*! ./header/dictionary.svg */ "./plugin/assets/icons/header/dictionary.svg");\nconst settingsIcon = __webpack_require__(/*! ./header/settings.svg */ "./plugin/assets/icons/header/settings.svg");\nconst backIcon = __webpack_require__(/*! ./back.svg */ "./plugin/assets/icons/back.svg");\nconst arrowIcon = __webpack_require__(/*! ./feedback/arrow-up.svg */ "./plugin/assets/icons/feedback/arrow-up.svg");\nconst likeLineIcon = __webpack_require__(/*! ./feedback/like-line.svg */ "./plugin/assets/icons/feedback/like-line.svg");\nconst likeSolidIcon = __webpack_require__(/*! ./feedback/like-solid.svg */ "./plugin/assets/icons/feedback/like-solid.svg");\nconst loadingIcon = __webpack_require__(/*! ./loading.svg */ "./plugin/assets/icons/loading.svg");\nconst fullscreenIcon = __webpack_require__(/*! ./fullscreen.svg */ "./plugin/assets/icons/fullscreen.svg");\nconst translatorIcon = __webpack_require__(/*! ./additionalOptions/translator.svg */ "./plugin/assets/icons/additionalOptions/translator.svg");\nconst helpIcon = __webpack_require__(/*! ./additionalOptions/help.svg */ "./plugin/assets/icons/additionalOptions/help.svg");\n\nconst socialIcons = {\n face: __webpack_require__(/*! ./facebook.svg */ "./plugin/assets/icons/facebook.svg"),\n web: __webpack_require__(/*! ./web.svg */ "./plugin/assets/icons/web.svg"),\n twitter: __webpack_require__(/*! ./twitter.svg */ "./plugin/assets/icons/twitter.svg"),\n insta: __webpack_require__(/*! ./instagram.svg */ "./plugin/assets/icons/instagram.svg"),\n youtube: __webpack_require__(/*! ./youtube.svg */ "./plugin/assets/icons/youtube.svg"),\n}\n\nconst positionIcons = [\n __webpack_require__(/*! ./positions/top-left.svg */ "./plugin/assets/icons/positions/top-left.svg"), __webpack_require__(/*! ./positions/top.svg */ "./plugin/assets/icons/positions/top.svg"),\n __webpack_require__(/*! ./positions/top-right.svg */ "./plugin/assets/icons/positions/top-right.svg"), __webpack_require__(/*! ./positions/left.svg */ "./plugin/assets/icons/positions/left.svg"),\n null, __webpack_require__(/*! ./positions/right.svg */ "./plugin/assets/icons/positions/right.svg"), __webpack_require__(/*! ./positions/bottom-left.svg */ "./plugin/assets/icons/positions/bottom-left.svg"),\n __webpack_require__(/*! ./positions/bottom.svg */ "./plugin/assets/icons/positions/bottom.svg"), __webpack_require__(/*! ./positions/bottom-right.svg */ "./plugin/assets/icons/positions/bottom-right.svg")\n]\n\nmodule.exports = {\n playIcon, pauseIcon, restartIcon, subtitleIcon, IcaroIcon,\n hozanaIcon, gugaIcon, aboutIcon, closeIcon, dictionaryIcon,\n settingsIcon, backIcon, socialIcons, positionIcons,\n arrowIcon, likeLineIcon, likeSolidIcon, loadingIcon,\n fullscreenIcon, translatorIcon, helpIcon\n}\n\n\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/index.js?'
)
},
'./plugin/assets/icons/instagram.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M16 13.6C15.3635 13.6 14.753 13.8529 14.3029 14.3029C13.8529 14.753 13.6 15.3635 13.6 16C13.6 16.6365 13.8529 17.247 14.3029 17.6971C14.753 18.1471 15.3635 18.4 16 18.4C16.6365 18.4 17.247 18.1471 17.6971 17.6971C18.1471 17.247 18.4 16.6365 18.4 16C18.4 15.3635 18.1471 14.753 17.6971 14.3029C17.247 13.8529 16.6365 13.6 16 13.6ZM16 12C17.0609 12 18.0783 12.4214 18.8284 13.1716C19.5786 13.9217 20 14.9391 20 16C20 17.0609 19.5786 18.0783 18.8284 18.8284C18.0783 19.5786 17.0609 20 16 20C14.9391 20 13.9217 19.5786 13.1716 18.8284C12.4214 18.0783 12 17.0609 12 16C12 14.9391 12.4214 13.9217 13.1716 13.1716C13.9217 12.4214 14.9391 12 16 12ZM21.2 11.8C21.2 12.0652 21.0946 12.3196 20.9071 12.5071C20.7196 12.6946 20.4652 12.8 20.2 12.8C19.9348 12.8 19.6804 12.6946 19.4929 12.5071C19.3054 12.3196 19.2 12.0652 19.2 11.8C19.2 11.5348 19.3054 11.2804 19.4929 11.0929C19.6804 10.9054 19.9348 10.8 20.2 10.8C20.4652 10.8 20.7196 10.9054 20.9071 11.0929C21.0946 11.2804 21.2 11.5348 21.2 11.8ZM16 9.6C14.0208 9.6 13.6976 9.6056 12.7768 9.6464C12.1496 9.676 11.7288 9.76 11.3384 9.912C11.0117 10.032 10.7163 10.2242 10.4744 10.4744C10.224 10.7163 10.0315 11.0117 9.9112 11.3384C9.7592 11.7304 9.6752 12.1504 9.6464 12.7768C9.6048 13.66 9.6 13.9688 9.6 16C9.6 17.9792 9.6056 18.3024 9.6464 19.2232C9.676 19.8496 9.76 20.2712 9.9112 20.6608C10.0472 21.0088 10.2072 21.2592 10.4728 21.5248C10.7424 21.7936 10.9928 21.9544 11.3368 22.0872C11.732 22.24 12.1528 22.3248 12.7768 22.3536C13.66 22.3952 13.9688 22.4 16 22.4C17.9792 22.4 18.3024 22.3944 19.2232 22.3536C19.8488 22.324 20.2704 22.24 20.6608 22.0888C20.987 21.9682 21.2822 21.7764 21.5248 21.5272C21.7944 21.2576 21.9552 21.0072 22.088 20.6632C22.24 20.2688 22.3248 19.8472 22.3536 19.2232C22.3952 18.34 22.4 18.0312 22.4 16C22.4 14.0208 22.3944 13.6976 22.3536 12.7768C22.324 12.1512 22.24 11.7288 22.088 11.3384C21.9674 11.012 21.7753 10.7168 21.5256 10.4744C21.2838 10.2239 20.9884 10.0313 20.6616 9.9112C20.2696 9.7592 19.8488 9.6752 19.2232 9.6464C18.34 9.6048 18.0312 9.6 16 9.6ZM16 8C18.1736 8 18.4448 8.008 19.2976 8.048C20.1496 8.088 20.7296 8.2216 21.24 8.42C21.768 8.6232 22.2128 8.8984 22.6576 9.3424C23.0644 9.74232 23.3792 10.2261 23.58 10.76C23.7776 11.2696 23.912 11.8504 23.952 12.7024C23.9896 13.5552 24 13.8264 24 16C24 18.1736 23.992 18.4448 23.952 19.2976C23.912 20.1496 23.7776 20.7296 23.58 21.24C23.3797 21.7742 23.0649 22.2581 22.6576 22.6576C22.2576 23.0643 21.7738 23.379 21.24 23.58C20.7304 23.7776 20.1496 23.912 19.2976 23.952C18.4448 23.9896 18.1736 24 16 24C13.8264 24 13.5552 23.992 12.7024 23.952C11.8504 23.912 11.2704 23.7776 10.76 23.58C10.2259 23.3796 9.74202 23.0648 9.3424 22.6576C8.93553 22.2577 8.62075 21.774 8.42 21.24C8.2216 20.7304 8.088 20.1496 8.048 19.2976C8.0104 18.4448 8 18.1736 8 16C8 13.8264 8.008 13.5552 8.048 12.7024C8.088 11.8496 8.2216 11.2704 8.42 10.76C8.62019 10.2257 8.93504 9.74186 9.3424 9.3424C9.74214 8.93538 10.2259 8.62058 10.76 8.42C11.2704 8.2216 11.8496 8.088 12.7024 8.048C13.5552 8.0104 13.8264 8 16 8Z\\" fill=\\"#0D459D\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/instagram.svg?'
)
},
'./plugin/assets/icons/loading.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M6 12C6 8.68629 8.68629 6 12 6C15.3137 6 18 8.68629 18 12V12.5C18 12.7761 17.7761 13 17.5 13C17.2239 13 17 12.7761 17 12.5V12C17 9.23858 14.7614 7 12 7C9.23858 7 7 9.23858 7 12V12.5C7 12.7761 6.77614 13 6.5 13C6.22386 13 6 12.7761 6 12.5V12Z\\" fill=\\"#0F2B54\\" stroke=\\"#0F2B54\\" stroke-width=\\"0.5\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/loading.svg?'
)
},
'./plugin/assets/icons/pause.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M18 23V9H22V23H18ZM10 23V9H14V23H10Z\\" fill=\\"#0F2B54\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/pause.svg?'
)
},
'./plugin/assets/icons/play.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M11.067 24.5665C10.6152 24.8601 10.1575 24.8768 9.69396 24.6166C9.23132 24.3573 9 23.9565 9 23.4144V9.38601C9 8.84386 9.23132 8.44266 9.69396 8.18242C10.1575 7.92309 10.6152 7.94026 11.067 8.23393L22.1135 15.2481C22.5201 15.5192 22.7234 15.9032 22.7234 16.4002C22.7234 16.8972 22.5201 17.2812 22.1135 17.5523L11.067 24.5665Z\\" fill=\\"#0F2B54\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/play.svg?'
)
},
'./plugin/assets/icons/positions/bottom-left.svg': function (
module,
exports
) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect y=\\"4\\" width=\\"8\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"11\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"18\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/bottom-left.svg?'
)
},
'./plugin/assets/icons/positions/bottom-right.svg': function (
module,
exports
) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect x=\\"16\\" y=\\"4\\" width=\\"8\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect x=\\"8\\" y=\\"11\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"18\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/bottom-right.svg?'
)
},
'./plugin/assets/icons/positions/bottom.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect x=\\"8\\" y=\\"4\\" width=\\"8\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect x=\\"4\\" y=\\"11\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"18\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/bottom.svg?'
)
},
'./plugin/assets/icons/positions/left.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect y=\\"4\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"11\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"18\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/left.svg?'
)
},
'./plugin/assets/icons/positions/right.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect x=\\"8\\" y=\\"4\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"11\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect x=\\"8\\" y=\\"18\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/right.svg?'
)
},
'./plugin/assets/icons/positions/top-left.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect y=\\"4\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"11\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect y=\\"18\\" width=\\"8\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/top-left.svg?'
)
},
'./plugin/assets/icons/positions/top-right.svg': function (
module,
exports
) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect y=\\"4\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect x=\\"8\\" y=\\"11\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect x=\\"16\\" y=\\"18\\" width=\\"8\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/top-right.svg?'
)
},
'./plugin/assets/icons/positions/top.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 24 24\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><rect y=\\"4\\" width=\\"24\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect x=\\"4\\" y=\\"11\\" width=\\"16\\" height=\\"3\\" fill=\\"#2470E0\\"></rect><rect x=\\"8\\" y=\\"18\\" width=\\"8\\" height=\\"3\\" fill=\\"#2470E0\\"></rect></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/positions/top.svg?'
)
},
'./plugin/assets/icons/restart.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M21.0249 12.9H17H16.9V13V15V15.1H17H24H24.1V15V8V7.9H24H22H21.9V8V10.4844C21.1769 9.6871 20.3237 9.06605 19.3412 8.62188C18.2783 8.14071 17.1642 7.9 16 7.9C13.7407 7.9 11.8234 8.68514 10.2543 10.2543C8.68514 11.8234 7.9 13.7407 7.9 16C7.9 18.2593 8.68514 20.1766 10.2543 21.7457C11.8234 23.3149 13.7407 24.1 16 24.1C17.8554 24.1 19.5104 23.5344 20.9615 22.4039C22.4122 21.2737 23.3745 19.8132 23.8467 18.0255L23.8798 17.9H23.75H21.65H21.5789L21.5555 17.9672C21.1457 19.1476 20.4334 20.0972 19.4171 20.8184C18.4009 21.5396 17.2629 21.9 16 21.9C14.3596 21.9 12.9684 21.327 11.8207 20.1793C10.673 19.0316 10.1 17.6404 10.1 16C10.1 14.3596 10.673 12.9684 11.8207 11.8207C12.9684 10.673 14.3596 10.1 16 10.1C17.0661 10.1 18.0531 10.3622 18.9631 10.8866C19.8223 11.3822 20.5092 12.0529 21.0249 12.9Z\\" fill=\\"#0F2B54\\" stroke=\\"#0F2B54\\" stroke-width=\\"0.2\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/restart.svg?'
)
},
'./plugin/assets/icons/subtitle.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M10.4 15.8H12.1V14.1H10.4V15.8ZM10.4 19.2H17.2V17.5H10.4V19.2ZM18.9 19.2H20.6V17.5H18.9V19.2ZM13.8 15.8H20.6V14.1H13.8V15.8ZM8.7 22.6C8.2325 22.6 7.83243 22.4337 7.4998 22.1011C7.1666 21.7679 7 21.3675 7 20.9V10.7C7 10.2325 7.1666 9.83243 7.4998 9.4998C7.83243 9.1666 8.2325 9 8.7 9H22.3C22.7675 9 23.1679 9.1666 23.5011 9.4998C23.8337 9.83243 24 10.2325 24 10.7V20.9C24 21.3675 23.8337 21.7679 23.5011 22.1011C23.1679 22.4337 22.7675 22.6 22.3 22.6H8.7Z\\" fill=\\"#0F2B54\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/subtitle.svg?'
)
},
'./plugin/assets/icons/twitter.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M19.3647 9.92352C18.6342 9.9234 17.9328 10.2101 17.4115 10.7218C16.8903 11.2336 16.5907 11.9295 16.5774 12.6599L16.5505 14.1737C16.5489 14.255 16.5301 14.335 16.4955 14.4085C16.4608 14.482 16.4109 14.5474 16.3492 14.6003C16.2875 14.6532 16.2153 14.6925 16.1374 14.7155C16.0594 14.7386 15.9774 14.7449 15.8969 14.734L14.3965 14.5303C12.4224 14.2612 10.5308 13.3519 8.71619 11.84C8.14142 15.0214 9.26404 17.2253 11.9677 18.9256L13.6468 19.9809C13.7266 20.031 13.7929 20.1 13.8399 20.1816C13.8869 20.2633 13.9131 20.3553 13.9163 20.4494C13.9196 20.5436 13.8997 20.6371 13.8584 20.7218C13.8171 20.8066 13.7557 20.8798 13.6795 20.9353L12.1494 22.0531C13.0596 22.1098 13.9237 22.0695 14.6407 21.9272C19.1753 21.0218 22.1904 17.6098 22.1904 11.9813C22.1904 11.5219 21.2178 9.92352 19.3647 9.92352ZM14.6551 12.6243C14.6719 11.6978 14.9616 10.7969 15.488 10.0343C16.0144 9.27165 16.754 8.68126 17.6144 8.33703C18.4747 7.99279 19.4175 7.91 20.3246 8.09903C21.2318 8.28806 22.063 8.74049 22.7143 9.3997C23.3976 9.39489 23.9791 9.5679 25.2795 8.77976C24.9576 10.356 24.799 11.0404 24.1127 11.9813C24.1127 19.3264 19.5982 22.898 15.0174 23.812C11.8764 24.4387 7.30908 23.4093 6 22.0426C6.66703 21.9907 9.37745 21.6994 10.9441 20.5528C9.6187 19.6791 4.34299 16.5746 7.80983 8.22807C9.43704 10.1282 11.0873 11.4219 12.7597 12.1082C13.8727 12.5647 14.1457 12.5551 14.656 12.6253L14.6551 12.6243Z\\" fill=\\"#0D459D\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/twitter.svg?'
)
},
'./plugin/assets/icons/web.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M19.488 17.6C19.552 17.072 19.6 16.544 19.6 16C19.6 15.456 19.552 14.928 19.488 14.4H22.192C22.32 14.912 22.4 15.448 22.4 16C22.4 16.552 22.32 17.088 22.192 17.6M18.072 22.048C18.552 21.16 18.92 20.2 19.176 19.2H21.536C20.7609 20.5346 19.5313 21.5456 18.072 22.048ZM17.872 17.6H14.128C14.048 17.072 14 16.544 14 16C14 15.456 14.048 14.92 14.128 14.4H17.872C17.944 14.92 18 15.456 18 16C18 16.544 17.944 17.072 17.872 17.6ZM16 22.368C15.336 21.408 14.8 20.344 14.472 19.2H17.528C17.2 20.344 16.664 21.408 16 22.368ZM12.8 12.8H10.464C11.2311 11.4618 12.4598 10.4492 13.92 9.952C13.44 10.84 13.08 11.8 12.8 12.8ZM10.464 19.2H12.8C13.08 20.2 13.44 21.16 13.92 22.048C12.4629 21.5453 11.2359 20.5342 10.464 19.2ZM9.808 17.6C9.68 17.088 9.6 16.552 9.6 16C9.6 15.448 9.68 14.912 9.808 14.4H12.512C12.448 14.928 12.4 15.456 12.4 16C12.4 16.544 12.448 17.072 12.512 17.6M16 9.624C16.664 10.584 17.2 11.656 17.528 12.8H14.472C14.8 11.656 15.336 10.584 16 9.624ZM21.536 12.8H19.176C18.9256 11.8092 18.5549 10.8527 18.072 9.952C19.544 10.456 20.768 11.472 21.536 12.8ZM16 8C11.576 8 8 11.6 8 16C8 18.1217 8.84285 20.1566 10.3431 21.6569C11.086 22.3997 11.9679 22.989 12.9385 23.391C13.9091 23.7931 14.9494 24 16 24C18.1217 24 20.1566 23.1571 21.6569 21.6569C23.1571 20.1566 24 18.1217 24 16C24 14.9494 23.7931 13.9091 23.391 12.9385C22.989 11.9679 22.3997 11.086 21.6569 10.3431C20.914 9.60028 20.0321 9.011 19.0615 8.60896C18.0909 8.20693 17.0506 8 16 8Z\\" fill=\\"#0D459D\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/web.svg?'
)
},
'./plugin/assets/icons/youtube.svg': function (module, exports) {
eval(
'module.exports = "<svg viewBox=\\"0 0 32 32\\" fill=\\"none\\" xmlns=\\"http://www.w3.org/2000/svg\\"><path d=\\"M23.606 10.995C23.53 10.697 23.314 10.472 23.067 10.403C22.63 10.28 20.5 10 16 10C11.5 10 9.372 10.28 8.931 10.403C8.687 10.471 8.471 10.696 8.394 10.995C8.285 11.419 8 13.196 8 16C8 18.804 8.285 20.58 8.394 21.006C8.47 21.303 8.686 21.528 8.932 21.596C9.372 21.72 11.5 22 16 22C20.5 22 22.629 21.72 23.069 21.597C23.313 21.529 23.529 21.304 23.606 21.005C23.715 20.581 24 18.8 24 16C24 13.2 23.715 11.42 23.606 10.995ZM25.543 10.498C26 12.28 26 16 26 16C26 16 26 19.72 25.543 21.502C25.289 22.487 24.546 23.262 23.605 23.524C21.896 24 16 24 16 24C16 24 10.107 24 8.395 23.524C7.45 23.258 6.708 22.484 6.457 21.502C6 19.72 6 16 6 16C6 16 6 12.28 6.457 10.498C6.711 9.513 7.454 8.738 8.395 8.476C10.107 8 16 8 16 8C16 8 21.896 8 23.605 8.476C24.55 8.742 25.292 9.516 25.543 10.498ZM14 19.5V12.5L20 16L14 19.5Z\\" fill=\\"#0D459D\\"></path></svg>"\n\n//# sourceURL=webpack://VLibras/./plugin/assets/icons/youtube.svg?'
)
},
'./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.html':
function (module, __webpack_exports__, __webpack_require__) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<button class=\\"vp-button-change-avatar avatar-icaro\\" avatar-name=\\"Ícaro\\"></button>\\r\\n<button class=\\"vp-button-change-avatar avatar-hozana\\" avatar-name=\\"Hozana\\"></button>\\r\\n<button class=\\"vp-button-change-avatar avatar-guga\\" avatar-name=\\"Guga\\"></button>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.html?'
)
},
'./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.scss':
function (module, exports, __webpack_require__) {
eval(
'var api = __webpack_require__(/*! ../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../../node_modules/css-loader/dist/cjs.js!../../../../node_modules/sass-loader/dist/cjs.js!./change-avatar.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.scss?'
)
},
'./plugin/components/AdditionalOptions/ChangeAvatar/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const template = __webpack_require__(/*! ./change-avatar.html */ \"./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.html\").default;\r\n__webpack_require__(/*! ./change-avatar.scss */ \"./plugin/components/AdditionalOptions/ChangeAvatar/change-avatar.scss\");\r\n\r\nconst { IcaroIcon, hozanaIcon, gugaIcon } = __webpack_require__(/*! ../../../assets/icons */ \"./plugin/assets/icons/index.js\");\r\n\r\nconst avatars = ['icaro', 'hozana', 'guga'];\r\n\r\nfunction ChangeAvatar(player, callbackWelcome) {\r\n this.player = player;\r\n this.element = null;\r\n}\r\n\r\nChangeAvatar.prototype.load = function (element) {\r\n this.element = element;\r\n this.element.innerHTML = template;\r\n const buttons = this.element.querySelectorAll('.vp-button-change-avatar');\r\n\r\n buttons.forEach((button, i) => {\r\n button.innerHTML = [IcaroIcon, hozanaIcon, gugaIcon][i];\r\n\r\n button.onclick = () => {\r\n if (button.classList.contains('vp-selected')) return;\r\n this.player.changeAvatar(avatars[i]);\r\n selectButton(button);\r\n }\r\n });\r\n\r\n this.element.onclick = () => this.element.classList.toggle('vp-change-avatar-openned');\r\n this.element.onmouseenter = () => !onMobile() && this.element.classList.add('vp-change-avatar-openned');\r\n this.element.onmouseleave = () => !onMobile() && this.element.classList.remove('vp-change-avatar-openned');\r\n\r\n function onMobile() {\r\n return window.innerWidth < 450;\r\n }\r\n\r\n function selectButton(button) {\r\n button.classList.add('vp-selected');\r\n buttons.forEach(btn => {\r\n if (btn !== button) btn.classList.remove('vp-selected');\r\n })\r\n }\r\n\r\n this.player.on(\r\n 'GetAvatar',\r\n function (avatar) {\r\n buttons[avatars.indexOf(avatar)]\r\n .classList.add('vp-selected');\r\n\r\n this.player.playWellcome();\r\n }.bind(this)\r\n );\r\n\r\n this.player.on(\r\n 'stop:welcome',\r\n function () {\r\n this.element.classList.add('active');\r\n }.bind(this)\r\n );\r\n};\r\n\r\nChangeAvatar.prototype.show = function () {\r\n this.enabled = true;\r\n this.element.classList.add('active');\r\n};\r\n\r\nChangeAvatar.prototype.hide = function () {\r\n if (this.element != undefined) {\r\n this.enabled = false;\r\n this.element.classList.remove('active');\r\n }\r\n};\r\n\r\nmodule.exports = ChangeAvatar;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/ChangeAvatar/index.js?"
)
},
'./plugin/components/AdditionalOptions/TranslatorScreen/index.js':
function (module, exports, __webpack_require__) {
eval(
"const template = __webpack_require__(/*! ./translator-screen.html */ \"./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.html\").default;\r\n__webpack_require__(/*! ./translator-screen.scss */ \"./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.scss\");\r\n\r\nfunction TranslatorScreen(player) {\r\n this.element = null;\r\n this.player = player;\r\n}\r\n\r\nconst { closeIcon } = __webpack_require__(/*! ../../../assets/icons */ \"./plugin/assets/icons/index.js\")\r\n\r\nTranslatorScreen.prototype.load = function (element) {\r\n this.element = element;\r\n this.element.innerHTML = template;\r\n\r\n const closeBtn = this.element.querySelector('.vp-translator-screen-header button');\r\n const userText = this.element.querySelector('.vp-text');\r\n const visualizeBtn = this.element.querySelector('.vp-visualize-signal-button');\r\n\r\n // Add icons\r\n closeBtn.innerHTML = closeIcon;\r\n\r\n // Add actions\r\n closeBtn.onclick = function () {\r\n this.hide();\r\n }.bind(this);\r\n\r\n visualizeBtn.onclick = function () {\r\n this.player.translate(userText.value);\r\n }.bind(this);\r\n\r\n userText.addEventListener('input', function () {\r\n\r\n if (!userText.value.replace(/[^a-z0-9]/gi, '')) {\r\n visualizeBtn.setAttribute('disabled', true);\r\n } else {\r\n visualizeBtn.removeAttribute('disabled');\r\n }\r\n\r\n });\r\n\r\n userText.addEventListener('keypress', e => {\r\n if (e.key === 'Enter' && !visualizeBtn.disabled) {\r\n this.player.translate(userText.value);\r\n }\r\n })\r\n\r\n}\r\n\r\nTranslatorScreen.prototype.show = function () {\r\n this.element.classList.add('vp-enabled');\r\n}\r\n\r\nTranslatorScreen.prototype.hide = function () {\r\n this.element.classList.remove('vp-enabled');\r\n}\r\n\r\nTranslatorScreen.prototype.toggle = function () {\r\n this.element.classList.toggle('vp-enabled');\r\n}\r\n\r\nmodule.exports = TranslatorScreen;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/TranslatorScreen/index.js?"
)
},
'./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.html':
function (module, __webpack_exports__, __webpack_require__) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div class=\\"vp-translator-screen-header\\">\\r\\n <span>Tradutor</span>\\r\\n <button></button>\\r\\n</div>\\r\\n\\r\\n<div class=\\"vp-translator-screen-content\\">\\r\\n\\r\\n <span class=\\"vp-title\\">Insira seu texto</span>\\r\\n\\r\\n <textarea class=\\"vp-text\\"></textarea>\\r\\n\\r\\n <div vp-sugestion-area class=\\"vp-translator-buttons-container\\">\\r\\n <button disabled vp-visualize-signal-button class=\\"vp-visualize-signal-button\\">\\r\\n Traduzir\\r\\n </button>\\r\\n </div>\\r\\n\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.html?'
)
},
'./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.scss':
function (module, exports, __webpack_require__) {
eval(
'var api = __webpack_require__(/*! ../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../../node_modules/css-loader/dist/cjs.js!../../../../node_modules/sass-loader/dist/cjs.js!./translator-screen.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/TranslatorScreen/translator-screen.scss?'
)
},
'./plugin/components/AdditionalOptions/WidgetHelp/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const template = __webpack_require__(/*! ./widget-help.html */ \"./plugin/components/AdditionalOptions/WidgetHelp/widget-help.html\").default;\n__webpack_require__(/*! ./widget-help.scss */ \"./plugin/components/AdditionalOptions/WidgetHelp/widget-help.scss\");\n\nfunction WidgetHelp(player) {\n this.element = null;\n this.player = player;\n}\n\nWidgetHelp.prototype.load = function (element) {\n this.element = element;\n this.element.innerHTML = template;\n\n}\n\nWidgetHelp.prototype.show = function () {\n this.element.classList.add('vp-enabled');\n}\n\nWidgetHelp.prototype.hide = function () {\n this.element.classList.remove('vp-enabled');\n}\n\nWidgetHelp.prototype.toggle = function () {\n this.element.classList.toggle('vp-enabled');\n alert('test')\n}\n\nmodule.exports = WidgetHelp;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/WidgetHelp/index.js?"
)
},
'./plugin/components/AdditionalOptions/WidgetHelp/widget-help.html':
function (module, __webpack_exports__, __webpack_require__) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div class=\\"vpw-tutorial\\">\\n <div class=\\"vpw-tutorial__message\\">\\n\\n </div>\\n\\n <div class=\\"vpw-tutorial__footer\\">\\n <button class=\\"vpw-tutorial__back-btn\\"></button>\\n <div class=\\"vpw-tutorial__tab-slider\\"></div>\\n <button class=\\"vpw-tutorial__next-btn\\"></button>\\n </div>\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/WidgetHelp/widget-help.html?'
)
},
'./plugin/components/AdditionalOptions/WidgetHelp/widget-help.scss':
function (module, exports, __webpack_require__) {
eval(
'var api = __webpack_require__(/*! ../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../../node_modules/css-loader/dist/cjs.js!../../../../node_modules/sass-loader/dist/cjs.js!./widget-help.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/WidgetHelp/widget-help.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/WidgetHelp/widget-help.scss?'
)
},
'./plugin/components/AdditionalOptions/additional-options.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<button class=\\"vpw-translator-button\\" data-title=\\"Tradutor\\"></button>\\n\x3c!-- <button class=\\"vpw-help-button\\" data-title=\\"Ajuda\\"></button> --\x3e");\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/additional-options.html?'
)
},
'./plugin/components/AdditionalOptions/additional-options.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./additional-options.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/AdditionalOptions/additional-options.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/additional-options.scss?'
)
},
'./plugin/components/AdditionalOptions/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const template = __webpack_require__(/*! ./additional-options.html */ \"./plugin/components/AdditionalOptions/additional-options.html\").default;\n__webpack_require__(/*! ./additional-options.scss */ \"./plugin/components/AdditionalOptions/additional-options.scss\");\n\nconst { translatorIcon, helpIcon } = __webpack_require__(/*! ../../assets/icons/ */ \"./plugin/assets/icons/index.js\")\n\nfunction AdditionalOptions(player, translatorScreen, widgetHelp) {\n this.player = player;\n this.element = null;\n this.translatorScreen = translatorScreen;\n this.widgetHelp = widgetHelp;\n}\n\nAdditionalOptions.prototype.load = function (element) {\n this.element = element;\n this.element.innerHTML = template;\n\n const translatorBtn = this.element.querySelector('.vpw-translator-button');\n // const helpBtn = this.element.querySelector('.vpw-help-button');\n\n // Add icons\n translatorBtn.innerHTML = translatorIcon;\n // helpBtn.innerHTML = helpIcon;\n\n // Add actions\n translatorBtn.onclick = () => this.translatorScreen.toggle();\n // helpBtn.onclick = () => this.widgetHelp.toggle();\n\n this.player.on('translate:start', _start.bind(this));\n this.player.on('gloss:start', _start.bind(this));\n\n this.player.on('gloss:end', _end.bind(this));\n this.player.on('stop:welcome', _end.bind(this));\n\n function _start() {\n translatorBtn.style.display = 'none';\n // helpBtn.style.display = 'none';\n }\n\n function _end() {\n translatorBtn.style.display = 'flex';\n // helpBtn.style.display = 'flex';\n }\n\n}\n\nAdditionalOptions.prototype.show = function () {\n this.element.classList.add('vp-enabled');\n}\n\nAdditionalOptions.prototype.hide = function () {\n this.element.classList.remove('vp-enabled');\n}\n\nmodule.exports = AdditionalOptions;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/AdditionalOptions/index.js?"
)
},
'./plugin/components/Box/box.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<span class=\\"vpw-mes\\">VLIBRAS</span>\\r\\n<div settings-btn></div>\\r\\n<div settings-btn-close></div>\\r\\n\\r\\n<div class=\\"vpw-container-dict\\">\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/Box/box.html?'
)
},
'./plugin/components/Box/box.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./box.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Box/box.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/Box/box.scss?'
)
},
'./plugin/components/Box/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
'const BoxTlp = __webpack_require__(/*! ./box.html */ "./plugin/components/Box/box.html").default;\r\n__webpack_require__(/*! ./box.scss */ "./plugin/components/Box/box.scss");\r\n\r\nfunction Box() {\r\n this.element = null;\r\n this.message = null;\r\n}\r\n\r\nBox.prototype.load = function (element) {\r\n this.element = element;\r\n this.element.classList.add(\'vpw-box\');\r\n this.element.innerHTML = BoxTlp;\r\n};\r\n\r\nmodule.exports = Box;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Box/index.js?'
)
},
'./plugin/components/CloseScreen/index.js': function (module, exports) {
eval(
"function CloseScreen(dictionary, info, settings, settingsBtnClose) {\r\n this.dictionary = dictionary;\r\n this.info = info;\r\n this.settings = settings;\r\n this.settingsBtnClose = settingsBtnClose;\r\n}\r\n\r\nCloseScreen.prototype.closeDict = function () {\r\n if (this.dictionary.visible) {\r\n this.dictionary.hide();\r\n }\r\n};\r\n\r\nCloseScreen.prototype.closeInfo = function () {\r\n if (this.info.visible) {\r\n this.info.hide();\r\n }\r\n};\r\n\r\n\r\nCloseScreen.prototype.closeSettings = function () {\r\n if (this.settings.visible) {\r\n this.settings.hide(true);\r\n }\r\n};\r\n\r\nCloseScreen.prototype.closeAll = function () {\r\n this.closeDict();\r\n this.closeInfo();\r\n this.closeSettings();\r\n this.settingsBtnClose.element.classList.remove('active');\r\n};\r\n\r\nmodule.exports = CloseScreen;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/CloseScreen/index.js?"
)
},
'./plugin/components/Controls/controls.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<span class=\\"vpw-selectTextLabel\\">Selecione um texto para traduzir.</span>\\n\\n<button class=\\"vpw-controls-button\\">\\n\\t<span class=\\"vpw-component-play\\"></span>\\n\\t<span class=\\"vpw-component-pause\\"></span>\\n\\t<span class=\\"vpw-component-restart\\"></span>\\n</button>\\n\\n<div class=\\"vpw-controls-slider\\">\\n\\t<div class=\\"vpw-slider\\"></div>\\n</div>\\n<button class=\\"vpw-button-speed\\">1x</button>\\n<button class=\\"vpw-controls-subtitles actived-subtitle\\"></button>\\n<button class=\\"vpw-controls-fullscreen\\">a</button>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/Controls/controls.html?'
)
},
'./plugin/components/Controls/controls.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./controls.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Controls/controls.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/Controls/controls.scss?'
)
},
'./plugin/components/Controls/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const noUiSlider = __webpack_require__(/*! nouislider */ \"./node_modules/nouislider/distribute/nouislider.js\");\r\n__webpack_require__(/*! nouislider/distribute/nouislider.min.css */ \"./node_modules/nouislider/distribute/nouislider.min.css\");\r\n\r\nconst controlsTpl = __webpack_require__(/*! ./controls.html */ \"./plugin/components/Controls/controls.html\").default;\r\n__webpack_require__(/*! ./controls.scss */ \"./plugin/components/Controls/controls.scss\");\r\n\r\nconst { playIcon, pauseIcon, restartIcon, subtitleIcon, fullscreenIcon } = __webpack_require__(/*! ../../assets/icons */ \"./plugin/assets/icons/index.js\");\r\n\r\nlet firstTranslation = false;\r\nconst availableSpeeds = [0.5, 1, 1.5, 2, 3];\r\n\r\nfunction Controls(player, dictionary) {\r\n this.player = player;\r\n this.dictionary = dictionary;\r\n\r\n this.player.on(\r\n 'animation:play',\r\n function () {\r\n this.element.classList.remove('vpw-selectText');\r\n this.element.classList.remove('vpw-stopped');\r\n this.element.classList.add('vpw-playing');\r\n }.bind(this)\r\n );\r\n\r\n this.player.on(\r\n 'animation:pause',\r\n function () {\r\n this.element.classList.remove('vpw-playing');\r\n this.element.classList.remove('vpw-stopped');\r\n }.bind(this)\r\n );\r\n\r\n this.player.on(\r\n 'animation:end',\r\n function () {\r\n this.element.classList.remove('vpw-playing');\r\n this.element.classList.add('vpw-stopped');\r\n }.bind(this)\r\n );\r\n\r\n this.player.on(\r\n 'response:glosa',\r\n function (counter, glosaLenght) {\r\n counter = counter - 2;\r\n\r\n if (counter != -1) {\r\n const slider = this.element.querySelector(\r\n '.vpw-controls-slider .vpw-slider'\r\n );\r\n\r\n slider.noUiSlider.updateOptions({\r\n range: {\r\n min: 0,\r\n max: glosaLenght,\r\n },\r\n });\r\n\r\n slider.noUiSlider.set([counter, glosaLenght]);\r\n }\r\n }.bind(this)\r\n );\r\n\r\n this.player.on(\r\n 'gloss:end',\r\n function (globalGlosaLenght) {\r\n globalGlosaLenght = globalGlosaLenght;\r\n const slider = this.element.querySelector(\r\n '.vpw-controls-slider .vpw-slider'\r\n );\r\n\r\n slider.noUiSlider.updateOptions({\r\n range: {\r\n min: 0,\r\n max: globalGlosaLenght,\r\n },\r\n });\r\n\r\n slider.noUiSlider.set([globalGlosaLenght, globalGlosaLenght]);\r\n this.element.classList.remove('vpw-selectText');\r\n }.bind(this)\r\n );\r\n\r\n\r\n this.player.on(\r\n 'stop:welcome',\r\n function () {\r\n if (!firstTranslation) this.element.classList.add('vpw-selectText');\r\n firstTranslation = true;\r\n }.bind(this)\r\n );\r\n}\r\n\r\nControls.prototype.load = function (element) {\r\n this.element = element;\r\n this.element.innerHTML = controlsTpl;\r\n this.element.classList.add('vpw-controls');\r\n this.element.classList.add('vpw-subtitles');\r\n this.rateBox = document.querySelector('div[vp-rate-box]');\r\n\r\n const play = this.element.querySelector('.vpw-controls-button');\r\n const slider = this.element.querySelector('.vpw-controls-slider .vpw-slider');\r\n const speed = this.element.querySelector('.vpw-button-speed');\r\n const subtitles = this.element.querySelector('.vpw-controls-subtitles');\r\n const fullscreen = this.element.querySelector('.vpw-controls-fullscreen');\r\n\r\n // Add icons\r\n play.querySelector('.vpw-component-play').innerHTML = playIcon;\r\n play.querySelector('.vpw-component-pause').innerHTML = pauseIcon;\r\n play.querySelector('.vpw-component-restart').innerHTML = restartIcon;\r\n subtitles.innerHTML = subtitleIcon;\r\n fullscreen.innerHTML = fullscreenIcon;\r\n\r\n noUiSlider.create(slider, {\r\n start: 0.0,\r\n step: 0.05,\r\n connect: 'lower',\r\n range: {\r\n min: 0.2,\r\n max: 200,\r\n },\r\n });\r\n slider.setAttribute('disabled', true);\r\n\r\n play.addEventListener('click', function () {\r\n if (this.element.classList.contains('vpw-playing')) {\r\n this.player.pause();\r\n } else if (this.element.classList.contains('vpw-stopped')) {\r\n this.player.repeat();\r\n this.player.on('gloss:end', () => {\r\n if (!this.player.translated) this.rateBox.classList.add('vp-enabled');\r\n })\r\n } else {\r\n this.player.continue();\r\n }\r\n }.bind(this)\r\n );\r\n\r\n subtitles.addEventListener('click', function () {\r\n this.element.classList.toggle('vpw-subtitles');\r\n subtitles.classList.toggle('actived-subtitle');\r\n this.player.toggleSubtitle();\r\n }.bind(this)\r\n );\r\n\r\n fullscreen.addEventListener('click', () =>\r\n document.body.classList.toggle('vpw-fullscreen'));\r\n\r\n window.addEventListener('vp-widget-close', () =>\r\n document.body.classList.remove('vpw-fullscreen'));\r\n\r\n speed.addEventListener('click', function () {\r\n this.setSpeed(speed);\r\n }.bind(this)\r\n );\r\n\r\n};\r\n\r\nControls.prototype.setSpeed = function (button) {\r\n const speedValue = parseFloat(button.textContent.replace('x', ''));\r\n let speedIndex = availableSpeeds.indexOf(speedValue);\r\n if (speedIndex === availableSpeeds.length - 1) speedIndex = -1;\r\n const newSpeed = availableSpeeds[speedIndex + 1];\r\n button.innerHTML = newSpeed + 'x';\r\n\r\n this.player.setSpeed(newSpeed);\r\n this.player.pause();\r\n this.player.continue();\r\n};\r\n\r\nControls.prototype.setProgress = function () {\r\n if (this.element != undefined) {\r\n const slider = this.element.querySelector(\r\n '.vpw-controls-slider .vpw-slider'\r\n );\r\n\r\n slider.noUiSlider.updateOptions({\r\n range: {\r\n min: 0,\r\n max: 2,\r\n },\r\n });\r\n\r\n slider.noUiSlider.set([0, 0]);\r\n }\r\n};\r\n\r\nmodule.exports = Controls;\r\n\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Controls/index.js?"
)
},
'./plugin/components/Dictionary/dictionary.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div class=\\"vpw-loading-dictionary\\">\\r\\n <div>\\r\\n <span class=\\"vpw-loading__img\\"></span>\\r\\n <span class=\\"vpw-dict-msg--loading\\">\\r\\n Carregando<br>\\r\\n Dicionário\\r\\n </span>\\r\\n <span class=\\"vpw-dict-msg--error\\">\\r\\n Falha no<br>\\r\\n Carregamento\\r\\n </span>\\r\\n <button>Tentar novamente</button>\\r\\n </div>\\r\\n</div>\\r\\n\\r\\n<div class=\\"vpw-panel\\">\\r\\n <div class=\\"vpw-bar\\">\\r\\n <button class=\\"vpw-btn-close\\"></button>\\r\\n <span class=\\"vpw-title\\">Dicionário</span>\\r\\n </div>\\r\\n\\r\\n <div class=\\"vpw-search\\">\\r\\n <input type=\\"text\\" placeholder=\\"Pesquisar por um sinal\\">\\r\\n <span class=\\"vpw-icon\\"></span>\\r\\n </div>\\r\\n</div>\\r\\n\\r\\n<div class=\\"buttons-container\\">\\r\\n <button class=\\"vp-selected\\">A-Z</button>\\r\\n <button>Recentes</button>\\r\\n</div>\\r\\n\\r\\n<div class=\\"vpw-recents-container\\">\\r\\n <ul></ul>\\r\\n</div>\\r\\n\\r\\n<div class=\\"vpw-dict-container enabled\\">\\r\\n <ul></ul>\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/Dictionary/dictionary.html?'
)
},
'./plugin/components/Dictionary/dictionary.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./dictionary.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Dictionary/dictionary.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/Dictionary/dictionary.scss?'
)
},
'./plugin/components/Dictionary/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const { backIcon, loadingIcon } = __webpack_require__(/*! ../../assets/icons */ \"./plugin/assets/icons/index.js\")\r\n\r\nconst inherits = __webpack_require__(/*! inherits */ \"./node_modules/inherits/inherits_browser.js\");\r\nconst EventEmitter = __webpack_require__(/*! events */ \"./node_modules/events/events.js\").EventEmitter;\r\n\r\nconst dictionaryTpl = __webpack_require__(/*! ./dictionary.html */ \"./plugin/components/Dictionary/dictionary.html\").default;\r\n__webpack_require__(/*! ./dictionary.scss */ \"./plugin/components/Dictionary/dictionary.scss\");\r\n\r\nconst { dictionaryIcon } = __webpack_require__(/*! ../../assets/icons */ \"./plugin/assets/icons/index.js\")\r\nconst { DICTIONARY_URL } = __webpack_require__(/*! ../../config */ \"./plugin/config.js\");\r\n\r\nconst Trie = __webpack_require__(/*! ./trie.js */ \"./plugin/components/Dictionary/trie.js\");\r\n\r\nfunction Dictionary(player) {\r\n this.visible = false;\r\n this.player = player;\r\n this.closeScreen = null;\r\n}\r\n\r\ninherits(Dictionary, EventEmitter);\r\n\r\nDictionary.prototype.load = function (element, closeScreen) {\r\n this.element = element;\r\n this.element.innerHTML = dictionaryTpl;\r\n this.element.classList.add('vpw-dictionary');\r\n this.closeScreen = closeScreen;\r\n\r\n const backButton = this.element.querySelector('.vpw-btn-close');\r\n const buttons = this.element.querySelectorAll('.buttons-container button');\r\n const recentWords = this.element.querySelector('.vpw-recents-container');\r\n const dictWords = this.element.querySelector('.vpw-dict-container');\r\n const loadingScreen = this.element.querySelector('.vpw-loading-dictionary');\r\n const reloadDictButton = loadingScreen.querySelector('div button');\r\n\r\n reloadDictButton.onclick = getSigns.bind(this);\r\n\r\n this.loadRecentWords = function () {\r\n let value = localStorage.getItem('@vp-dict-history');\r\n if (value) value = JSON.parse(value);\r\n else return;\r\n\r\n const list = recentWords.querySelector('ul');\r\n list.innerHTML = \"\";\r\n\r\n for (word of value.reverse()) {\r\n const item = document.createElement('li');\r\n item.innerHTML = word;\r\n list.appendChild(item);\r\n\r\n item.addEventListener('click', this._onItemClick.bind(this, word));\r\n }\r\n }.bind(this);\r\n\r\n buttons[0].onclick = () => {\r\n toggleWords('dict');\r\n }\r\n\r\n buttons[1].onclick = () => {\r\n toggleWords('recents');\r\n this.loadRecentWords();\r\n }\r\n\r\n function toggleWords(words) {\r\n if (words === 'dict') {\r\n buttons[0].classList.add('vp-selected');\r\n buttons[1].classList.remove('vp-selected');\r\n recentWords.classList.remove('enabled');\r\n dictWords.classList.add('enabled');\r\n }\r\n else if (words === 'recents') {\r\n buttons[1].classList.add('vp-selected');\r\n buttons[0].classList.remove('vp-selected');\r\n recentWords.classList.add('enabled');\r\n dictWords.classList.remove('enabled');\r\n } else return;\r\n }\r\n\r\n // Add icon\r\n this.element.querySelector('.vpw-icon').innerHTML = dictionaryIcon;\r\n this.element.querySelector('.vpw-btn-close').innerHTML = backIcon;\r\n document.querySelector('.vpw-loading__img').innerHTML = loadingIcon;\r\n\r\n backButton.addEventListener(\r\n 'click',\r\n function () {\r\n this.hide();\r\n document.querySelector('.vpw-header-btn-dictionary')\r\n .classList.remove('selected');\r\n }.bind(this)\r\n );\r\n\r\n\r\n // Signs trie\r\n this.signs = null;\r\n\r\n // List\r\n this.list = dictWords.querySelector('ul');\r\n\r\n // Insert item method\r\n this.list._insert = function (word) {\r\n const item = document.createElement('li');\r\n\r\n if (word.indexOf('&') != -1) {\r\n regex = word.replace('&', '(');\r\n regex = regex + ')';\r\n item.innerHTML = regex;\r\n item.addEventListener('click', this._onItemClick.bind(this, word));\r\n this.list.appendChild(item);\r\n } else {\r\n item.innerHTML = word;\r\n item.addEventListener('click', this._onItemClick.bind(this, word));\r\n this.list.appendChild(item);\r\n }\r\n }.bind(this);\r\n\r\n // Request and load list\r\n function getSigns() {\r\n loadingScreen.classList.remove('vpw-dict--error');\r\n const xhr = new XMLHttpRequest();\r\n xhr.open('get', DICTIONARY_URL, true);\r\n xhr.responseType = 'text';\r\n xhr.onload = function () {\r\n try {\r\n if (xhr.status == 200) {\r\n const json = JSON.parse(xhr.response);\r\n\r\n this.signs = new Trie(json);\r\n\r\n this.signs.loadSigns('', this.list._insert.bind(this.list));\r\n loadingScreen.remove();\r\n } else {\r\n loadingScreen.classList.add('vpw-dict--error');\r\n console.error('Bad answer for signs, status: ' + xhr.status);\r\n }\r\n } catch (err) {\r\n loadingScreen.classList.add('vpw-dict--error');\r\n console.log(err);\r\n }\r\n }.bind(this);\r\n xhr.send();\r\n }\r\n\r\n getSigns.bind(this)();\r\n\r\n this.defaultItem = this.list.querySelector('li');\r\n\r\n // Clear list method\r\n this.list._clear = function () {\r\n this.list.innerHTML = '';\r\n }.bind(this);\r\n\r\n // Search\r\n this.element.querySelector('.vpw-panel .vpw-search input').addEventListener(\r\n 'keydown',\r\n function (event) {\r\n this.list._clear();\r\n this.signs.loadSigns(\r\n event.target.value.toUpperCase(),\r\n this.list._insert.bind(this.list)\r\n );\r\n if (this.list.childNodes.length === 0) {\r\n this.list.innerHTML = '<span>Nenhum sinal encontrado :(</span>';\r\n }\r\n\r\n toggleWords('dict');\r\n\r\n }.bind(this)\r\n );\r\n};\r\n\r\nDictionary.prototype._onItemClick = function (event, word) {\r\n this.closeScreen.closeAll();\r\n this.player.play(event);\r\n\r\n if (this.element.querySelectorAll('.buttons-container button')[1]\r\n .classList.contains('vp-selected')\r\n ) return;\r\n\r\n let value = localStorage.getItem(\"@vp-dict-history\");\r\n if (value) {\r\n value = JSON.parse(value);\r\n value.push(event)\r\n } else value = [event];\r\n\r\n localStorage.setItem(\"@vp-dict-history\", JSON.stringify(value));\r\n this.loadRecentWords();\r\n};\r\n\r\nDictionary.prototype.toggle = function () {\r\n if (this.visible) this.hide();\r\n else this.show();\r\n};\r\n\r\nDictionary.prototype.hide = function () {\r\n this.visible = false;\r\n this.element.classList.remove('active');\r\n this.emit('hide');\r\n};\r\n\r\nDictionary.prototype.show = function () {\r\n this.visible = true;\r\n this.element.classList.add('active');\r\n this.emit('show');\r\n};\r\n\r\nmodule.exports = Dictionary;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Dictionary/index.js?"
)
},
'./plugin/components/Dictionary/trie.js': function (module, exports) {
eval(
"const Trie = function(jsonData) {\r\n try {\r\n if (typeof jsonData === 'string') {\r\n this.root = JSON.parse(jsonData).root;\r\n } else {\r\n this.root = jsonData.root;\r\n }\r\n } catch (error) {\r\n this.root = {children: {}, end: true};\r\n console.error('Failed to parse Prefix Tree from JSON\\n' + error);\r\n }\r\n};\r\n\r\nTrie.prototype.loadSigns = function(keyWord, insertElement) {\r\n const search = function(node, word) {\r\n if (node.end) {\r\n insertElement(word);\r\n }\r\n\r\n const childrenKeys = Object.keys(node.children);\r\n\r\n for (let i = 0, len = childrenKeys.length; i < len; ++i) {\r\n search(node.children[childrenKeys[i]], word + childrenKeys[i]);\r\n }\r\n };\r\n\r\n let currentNode = this.root;\r\n keyWord = keyWord.toUpperCase();\r\n\r\n if (keyWord !== undefined) {\r\n for (let i = 0, len = keyWord.length; i < len; ++i) {\r\n try {\r\n currentNode = currentNode.children[keyWord[i]];\r\n } catch (error) {\r\n return;\r\n }\r\n }\r\n\r\n if (currentNode === undefined) {\r\n return;\r\n }\r\n }\r\n\r\n search(currentNode, keyWord);\r\n};\r\n\r\nmodule.exports = Trie;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Dictionary/trie.js?"
)
},
'./plugin/components/InfoScreen/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const { socialIcons, backIcon } = __webpack_require__(/*! ../../assets/icons */ \"./plugin/assets/icons/index.js\")\r\n\r\nconst inherits = __webpack_require__(/*! inherits */ \"./node_modules/inherits/inherits_browser.js\");\r\nconst EventEmitter = __webpack_require__(/*! events */ \"./node_modules/events/events.js\").EventEmitter;\r\n\r\nconst infoScreenTpl = __webpack_require__(/*! ./info-screen.html */ \"./plugin/components/InfoScreen/info-screen.html\").default;\r\n__webpack_require__(/*! ./info-screen.scss */ \"./plugin/components/InfoScreen/info-screen.scss\");\r\n\r\nfunction InfoScreen(box) {\r\n this.visible = false;\r\n this.box = box;\r\n}\r\n\r\ninherits(InfoScreen, EventEmitter);\r\n\r\nInfoScreen.prototype.load = function (element) {\r\n this.element = element;\r\n this.element.innerHTML = infoScreenTpl;\r\n this.element.classList.add('vpw-info-screen');\r\n\r\n const backButton = this.element.querySelector('.vpw-back-button');\r\n\r\n // ADD ICONS\r\n const social = this.element.querySelector('.vpw-logo-networks').children;\r\n social[0].innerHTML = socialIcons.web;\r\n social[1].innerHTML = socialIcons.face;\r\n social[2].innerHTML = socialIcons.insta;\r\n social[3].innerHTML = socialIcons.twitter;\r\n social[4].innerHTML = socialIcons.youtube;\r\n this.element.querySelector('.vpw-back-button').innerHTML = backIcon;\r\n\r\n backButton.addEventListener(\r\n 'click',\r\n function () {\r\n this.hide();\r\n document.querySelector('.vpw-header-btn-about')\r\n .classList.remove('selected');\r\n }.bind(this)\r\n );\r\n};\r\n\r\nInfoScreen.prototype.toggle = function () {\r\n if (this.visible) this.hide();\r\n else this.show();\r\n};\r\n\r\nInfoScreen.prototype.hide = function () {\r\n this.visible = false;\r\n this.element.classList.remove('active');\r\n this.emit('hide');\r\n};\r\n\r\nInfoScreen.prototype.show = function () {\r\n this.visible = true;\r\n this.element.classList.add('active');\r\n this.emit('show');\r\n};\r\n\r\nmodule.exports = InfoScreen;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/InfoScreen/index.js?"
)
},
'./plugin/components/InfoScreen/info-screen.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("\x3c!----------------------------------------------------------------------------\x3e\\n<div class=\\"vpw-info-header\\">\\n <button class=\\"vpw-back-button\\"></button>\\n <span class=\\"text-black-header\\">Quem Somos</span>\\n</div>\\n\\n<div id=\\"vpw-info-main\\" class=\\"vpw-text-logo-main\\">\\n\\n <div id=\\"vpw-text-svl\\">\\n <span class=\\"text-black\\">Sobre o VLibras</span>\\n <p class=\\"format-text\\">\\n A suíte VLibras é um conjunto de ferramentas\\n gratuitas de código aberto\\n que traduz conteúdo digital (texto, áudio\\n e vídeo) em Português para Libras.\\n </p>\\n </div>\\n <div class=\\"vpw-info-realizadores\\">\\n <span class=\\"text-black\\">Realizadores</span>\\n <div class=\\"vpw-logo-group\\">\\n <img class=\\"vpw-logo\\" data-src=\\"assets/ministerioDireitosHumanos.svg\\" />\\n <img class=\\"vpw-logo\\" data-src=\\"assets/ministerioGestao.svg\\" />\\n </div>\\n\\n <div class=\\"vpw-logo-group\\">\\n <img class=\\"vpw-logo\\" data-src=\\"assets/lavid.svg\\" />\\n <img class=\\"vpw-logo\\" data-src=\\"assets/rnp.svg\\" />\\n <img class=\\"vpw-logo\\" data-src=\\"assets/camDeputados.svg\\" />\\n </div>\\n </div>\\n\\n <div id=\\"vpw-info-footer\\" class=\\"vpw-icons\\">\\n <span class=\\"text-black\\">Redes sociais</span>\\n <div class=\\"vpw-logo-networks\\">\\n <a target=\\"_blank\\" class=\\"vpw-networks\\" href=\\"https://www.gov.br/governodigital/pt-br/vlibras/\\"></a>\\n <a target=\\"_blank\\" class=\\"vpw-networks\\" href=\\"https://facebook.com/vlibras\\"></a>\\n <a target=\\"_blank\\" class=\\"vpw-networks\\" href=\\"https://instagram.com/vlibrasoficial\\"></a>\\n <a target=\\"_blank\\" class=\\"vpw-networks\\" href=\\"https://twitter.com/VLibrasoficial\\"></a>\\n <a target=\\"_blank\\" class=\\"vpw-networks\\" href=\\"https://youtube.com/@vlibras-lavid3180\\"></a>\\n </div>\\n\\n </div>\\n</div>\\n\x3c!----------------------------------------------------------------------------\x3e");\n\n//# sourceURL=webpack://VLibras/./plugin/components/InfoScreen/info-screen.html?'
)
},
'./plugin/components/InfoScreen/info-screen.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./info-screen.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/InfoScreen/info-screen.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/InfoScreen/info-screen.scss?'
)
},
'./plugin/components/MessageBox/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"__webpack_require__(/*! ./message-box.scss */ \"./plugin/components/MessageBox/message-box.scss\");\r\n\r\nconst messageBoxTlp = '<span class=\"vpw-message\"></span>';\r\n\r\nfunction MessageBox() {\r\n this.element = null;\r\n this.message = null;\r\n}\r\n\r\nMessageBox.LEVELS = ['info', 'warning', 'success', 'default'];\r\n\r\nMessageBox.prototype.load = function(element) {\r\n this.element = element;\r\n this.element.classList.add('vpw-message-box');\r\n this.element.innerHTML = messageBoxTlp;\r\n\r\n this.hide();\r\n};\r\n\r\nMessageBox.prototype.hide = function(message) {\r\n if (message !== this.message) return;\r\n\r\n this.message = null;\r\n this.element.classList.remove('active');\r\n\r\n MessageBox.LEVELS.forEach(function(level) {\r\n this.element.classList.remove(level);\r\n }, this);\r\n};\r\n\r\nMessageBox.prototype.show = function(level, message, time) {\r\n const self = this;\r\n\r\n level = MessageBox.LEVELS.indexOf(level) == -1 ? 'info' : level;\r\n\r\n this.hide();\r\n\r\n self.element.classList.add('active');\r\n self.element.classList.add(level);\r\n self.element.querySelector('.vpw-message').innerHTML = message;\r\n\r\n self.message = {\r\n text: message,\r\n };\r\n\r\n const ref = self.message;\r\n if (time) {\r\n setTimeout(function() {\r\n self.hide(ref);\r\n }, time + 1);\r\n }\r\n\r\n return this.message;\r\n};\r\n\r\nmodule.exports = MessageBox;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/MessageBox/index.js?"
)
},
'./plugin/components/MessageBox/message-box.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./message-box.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/MessageBox/message-box.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/MessageBox/message-box.scss?'
)
},
'./plugin/components/RateBox/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const template = __webpack_require__(/*! ./rate-box.html */ \"./plugin/components/RateBox/rate-box.html\").default;\r\n__webpack_require__(/*! ./rate-box.scss */ \"./plugin/components/RateBox/rate-box.scss\");\r\n\r\nconst { arrowIcon, likeLineIcon, likeSolidIcon } = __webpack_require__(/*! ../../assets/icons/ */ \"./plugin/assets/icons/index.js\");\r\n\r\nfunction RateBox(messageBox, suggestionScreen) {\r\n this.element = null;\r\n this.suggestionScreen = suggestionScreen;\r\n this.messageBox = messageBox;\r\n}\r\n\r\nRateBox.prototype.load = function(element) {\r\n this.element = element;\r\n this.element.innerHTML = template;\r\n\r\n this.headerButton = this.element.querySelector('.vp-rate-box-header button');\r\n const likeBtn = this.element.querySelector('.vp-rate-btns--like');\r\n const deslikeBtn = this.element.querySelector('.vp-rate-btns--deslike');\r\n\r\n // Add icon\r\n this.headerButton.innerHTML = arrowIcon;\r\n likeBtn.innerHTML = likeLineIcon + likeSolidIcon + likeBtn.innerHTML;\r\n deslikeBtn.innerHTML = likeLineIcon + likeSolidIcon + deslikeBtn.innerHTML;\r\n\r\n this.headerButton.addEventListener('click', function () {\r\n this.element.classList.toggle('vp-expanded');\r\n }.bind(this));\r\n\r\n likeBtn.addEventListener('click', function () {\r\n window.plugin.sendReview('good');\r\n }.bind(this));\r\n\r\n deslikeBtn.addEventListener('click', function () {\r\n this.suggestionScreen.show();\r\n this.suggestionScreen.setGloss(window.plugin.player.gloss);\r\n }.bind(this));\r\n \r\n};\r\n\r\nRateBox.prototype.reload = function() {\r\n this.suggestionScreen.hide();\r\n this.headerButton.innerHTML = arrowIcon;\r\n};\r\n\r\nRateBox.prototype.show = function() {\r\n this.element.classList.add('vp-enabled');\r\n};\r\n\r\nRateBox.prototype.hide = function() {\r\n this.reload();\r\n this.element.classList.remove('vp-enabled');\r\n this.element.classList.remove('vp-expanded');\r\n};\r\n\r\nRateBox.prototype.getElement = function () {\r\n return this.element;\r\n}\r\n\r\nmodule.exports = RateBox;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/RateBox/index.js?"
)
},
'./plugin/components/RateBox/rate-box.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div class=\\"vp-rate-box-header\\">\\r\\n <span>Feedback</span>\\r\\n <button></button>\\r\\n</div>\\r\\n\\r\\n<div class=\\"vp-rate-box-content\\">\\r\\n <span>Gostou da tradução?</span>\\r\\n <div class=\\"vp-rate-btns\\">\\r\\n <button class=\\"vp-rate-btns--like\\">Sim</button>\\r\\n <button class=\\"vp-rate-btns--deslike\\">Não</button>\\r\\n </div>\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/RateBox/rate-box.html?'
)
},
'./plugin/components/RateBox/rate-box.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./rate-box.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/RateBox/rate-box.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/RateBox/rate-box.scss?'
)
},
'./plugin/components/Settings/data.js': function (module, exports) {
eval(
"module.exports = [\r\n { name: 'Brasil', path: 'BR', flag: 'assets/brazil.png' },\r\n { name: 'Acré', path: 'AC', flag: 'assets/1AC.png' },\r\n { name: 'Alagoas', path: 'AL', flag: 'assets/2AL.png' },\r\n { name: 'Amapá', path: 'AP', flag: 'assets/3AP.png' },\r\n { name: 'Amazonas', path: 'AM', flag: 'assets/4AM.png' },\r\n { name: 'Bahia', path: 'BA', flag: 'assets/5BA.png' },\r\n { name: 'Ceará', path: 'CE', flag: 'assets/6CE.png' },\r\n { name: 'Distrito Federal', path: 'DF', flag: 'assets/7DF.png' },\r\n { name: 'Espírito Santo', path: 'ES', flag: 'assets/8ES.png' },\r\n { name: 'Goias', path: 'GO', flag: 'assets/9GO.png' },\r\n { name: 'Maranhão', path: 'MA', flag: 'assets/10MA.png' },\r\n { name: 'Mato Grosso', path: 'MT', flag: 'assets/11MT.png' },\r\n { name: 'Mato Grosso do Sul', path: 'MS', flag: 'assets/12MS.png' },\r\n { name: 'Minas Gerais', path: 'MG', flag: 'assets/13MG.png' },\r\n { name: 'Pará', path: 'PA', flag: 'assets/14PA.png' },\r\n { name: 'Paraíba', path: 'PB', flag: 'assets/15PB.png' },\r\n { name: 'Paraná', path: 'PR', flag: 'assets/16PR.png' },\r\n { name: 'Pernambuco', path: 'PE', flag: 'assets/17PE.png' },\r\n { name: 'Piauí', path: 'PI', flag: 'assets/18PI.png' },\r\n { name: 'Rio de Janeiro', path: 'RJ', flag: 'assets/19RJ.png' },\r\n { name: 'Rio Grande do Norte', path: 'RN', flag: 'assets/20RN.png' },\r\n { name: 'Rio Grande do Sul', path: 'RS', flag: 'assets/21RS.png' },\r\n { name: 'Rondônia', path: 'RO', flag: 'assets/22RO.png' },\r\n { name: 'Roráima', path: 'RR', flag: 'assets/23RR.png' },\r\n { name: 'Santa Catarina', path: 'SC', flag: 'assets/24SC.png' },\r\n { name: 'São Paulo', path: 'SP', flag: 'assets/25SP.png' },\r\n { name: 'Sergipe', path: 'SE', flag: 'assets/26SE.png' },\r\n { name: 'Tocantins', path: 'TO', flag: 'assets/27TO.png' },\r\n];\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/data.js?"
)
},
'./plugin/components/Settings/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const inherits = __webpack_require__(/*! inherits */ \"./node_modules/inherits/inherits_browser.js\");\nconst EventEmitter = __webpack_require__(/*! events */ \"./node_modules/events/events.js\").EventEmitter;\n\nconst settingsTpl = __webpack_require__(/*! ./settings.html */ \"./plugin/components/Settings/settings.html\").default;\n__webpack_require__(/*! ./settings.scss */ \"./plugin/components/Settings/settings.scss\");\n__webpack_require__(/*! ./regionalism.scss */ \"./plugin/components/Settings/regionalism.scss\");\n__webpack_require__(/*! ./switch.scss */ \"./plugin/components/Settings/switch.scss\");\n\nconst regionsData = __webpack_require__(/*! ./data */ \"./plugin/components/Settings/data.js\");\nconst { backIcon, positionIcons } = __webpack_require__(/*! ../../assets/icons */ \"./plugin/assets/icons/index.js\")\n\nfunction Settings(player, option, opacity) {\n this.visible = false;\n this.player = player;\n\n enable = option.enableMoveWindow;\n opacityUser = opacity;\n}\n\ninherits(Settings, EventEmitter);\n\nSettings.prototype.load = function (element) {\n this.element = element;\n this.element.innerHTML = settingsTpl;\n this.element.classList.add('vpw-settings');\n this.localism = this.element.querySelector('.vpw-regions-container');\n this.toggleHeader = toggleHeader;\n\n // Header element\n const header = this.element.querySelector('.vpw-screen-header span');\n\n // Config back button\n const backButton = this.element.querySelector('.vpw-screen-header button');\n backButton.innerHTML = backIcon;\n backButton.onclick = handleReturn.bind(this);\n\n // Access regionalism button\n const regionalismBtn = this.element.querySelector('.vpw-selected-region');\n regionalismBtn.onclick = accessRegionalism.bind(this);\n setRegion.bind(this)({ path: 'BR', flag: 'assets/brazil.png', });\n\n // Opacity option\n const opacityInput = this.element.querySelector('.vpw-opacity-range input');\n const opacitySlider = this.element.querySelector('.vpw-opacity-range vpw-slider');\n const opacityValue = this.element.querySelector('.vpw-opacity-value');\n opacityInput.oninput = setOpacity;\n\n // Position option box\n const positionBox = this.element.querySelector('.vpw-position-box');\n\n // Creates regions grid\n const regionHTML = __webpack_require__(/*! ./region.html */ \"./plugin/components/Settings/region.html\").default;\n let activeRegion = null;\n\n // eslint-disable-next-line guard-for-in\n for (const region of regionsData) {\n\n const element = document.createElement('div');\n element.classList.add('vpw-region');\n element.innerHTML = regionHTML;\n\n if (region === regionsData[0]) {\n element.classList.add('selected');\n activeRegion = element;\n }\n\n element.querySelector('.vpw-flag').setAttribute('data-src', region.flag);\n element.querySelector('.vpw-name').innerHTML =\n region === regionsData[0]\n ? 'Brasil (Padrão Nacional)'\n : `${region.name} - ${region.path}`\n\n element.onclick = () => {\n if (activeRegion === element) return;\n element.classList.add('selected');\n activeRegion.classList.remove('selected');\n activeRegion = element;\n\n // Set region button/player\n setRegion.bind(this)(region);\n\n handleReturn.bind(this)();\n }\n this.localism.appendChild(element);\n }\n\n // Add positions in box\n for (const position of widgetPositions) {\n const span = document.createElement('span');\n\n if (position) span.innerHTML =\n positionIcons[widgetPositions.indexOf(position)];\n\n if (position === 'R') span.classList.add('vpw-select-pos');\n\n positionBox.appendChild(span);\n\n if (!position) span.style.visibility = 'hidden';\n else span.onclick = () => {\n window.dispatchEvent(\n new CustomEvent('vp-widget-wrapper-set-side', {\n detail: { position }\n }));\n\n positionBox.querySelector('.vpw-select-pos')\n .classList.remove('vpw-select-pos');\n\n span.classList.add('vpw-select-pos');\n }\n }\n\n // Elements to apply blur filter\n this.gameContainer = document.querySelector('div#gameContainer');\n this.controlsElement = document.querySelector('.vpw-controls');\n\n function setOpacity() {\n const value = Number(opacityInput.value);\n const percent = (value < 25 && !isFullscreen()) ? value + 5 : value;\n\n opacitySlider.style.width = percent + '%';\n opacityValue.innerHTML = value + '%';\n\n window.dispatchEvent(\n new CustomEvent('vw-change-opacity', { detail: value / 100 })\n );\n }\n\n function isFullscreen() {\n return document.body.classList.contains('vpw-fullscreen');\n }\n\n function setRegion(region) {\n regionalismBtn.querySelector('span').innerHTML = region.path;\n regionalismBtn.querySelector('img').src = window.plugin.rootPath\n ? window.plugin.rootPath + '/' + region.flag : region.flag;\n\n this.player.setRegion(region.path);\n }\n\n function accessRegionalism() {\n this.localism.classList.add('active');\n toggleHeader();\n }\n\n const panelIsOpen = function () {\n return this.localism.classList.contains('active');\n }.bind(this);\n\n function handleReturn() {\n if (panelIsOpen()) {\n this.localism.scrollTo(0, 0);\n this.localism.classList.remove('active');\n } else {\n this.hide();\n document.querySelector('.vpw-header-btn-settings')\n .classList.remove('selected');\n }\n toggleHeader();\n }\n\n function toggleHeader() {\n header.innerHTML = panelIsOpen()\n ? 'Regionalismo'\n : 'Configurações';\n }\n\n};\n\nSettings.prototype.toggle = function () {\n if (this.visible) this.hide();\n else this.show();\n};\n\nSettings.prototype.hide = function (menuOn) {\n this.visible = false;\n this.element.classList.remove('active');\n this.localism.classList.remove('active');\n\n // Removes blur filter\n this.gameContainer.classList.remove('vpw-blur');\n this.controlsElement.classList.remove('vpw-blur');\n\n this.toggleHeader();\n\n this.emit('hide');\n};\n\nSettings.prototype.show = function () {\n this.visible = true;\n this.element.classList.add('active');\n\n // Apply blur filter\n this.gameContainer.classList.add('vpw-blur');\n this.controlsElement.classList.add('vpw-blur');\n\n this.emit('show');\n};\n\nmodule.exports = Settings;\n\n\nconst widgetPositions = [\n 'TL', 'T', 'TR',\n 'L', null, 'R',\n 'BL', 'B', 'BR'\n]\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/index.js?"
)
},
'./plugin/components/Settings/region.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<img class=\\"vpw-flag\\" data-src=\\"\\">\\r\\n<span class=\\"vpw-name\\"></span>\\r\\n<span class=\\"vpw-radio\\"></span>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/region.html?'
)
},
'./plugin/components/Settings/regionalism.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./regionalism.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Settings/regionalism.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/regionalism.scss?'
)
},
'./plugin/components/Settings/settings.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div class=\\"vpw-settings-content\\">\\r\\n <div class=\\"vpw-screen-header\\">\\r\\n <button></button>\\r\\n <span>Configurações</span>\\r\\n </div>\\r\\n\\r\\n <div class=\\"vpw-options-container\\">\\r\\n\\r\\n <div class=\\"vpw-option-content\\">\\r\\n <p>Dicionário</p>\\r\\n <div>\\r\\n <span>Regionalismo</span>\\r\\n <div class=\\"vpw-selected-region\\">\\r\\n <img>\\r\\n <span></span>\\r\\n </div>\\r\\n </div>\\r\\n </div>\\r\\n\\r\\n <div class=\\"vpw-option-content\\">\\r\\n <p>Aparência</p>\\r\\n <div>\\r\\n <div class=\\"vpw-opacity-info\\">\\r\\n <span>Opacidade</span>\\r\\n <span class=\\"vpw-opacity-value\\">100%</span>\\r\\n </div>\\r\\n <div class=\\"vpw-opacity-range\\">\\r\\n <input type=\\"range\\" value=\\"100\\" min=\\"0\\" max=\\"100\\" step=\\"5\\">\\r\\n <vpw-slider></vpw-slider>\\r\\n <span></span>\\r\\n </div>\\r\\n </div>\\r\\n </div>\\r\\n\\r\\n <div class=\\"vpw-option-content\\">\\r\\n <div>\\r\\n <span>Posição na tela</span>\\r\\n <div class=\\"vpw-position-box\\">\\r\\n </div>\\r\\n </div>\\r\\n </div>\\r\\n\\r\\n </div>\\r\\n\\r\\n <div class=\\"vpw-regions-container\\"></div>\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/settings.html?'
)
},
'./plugin/components/Settings/settings.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./settings.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Settings/settings.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/settings.scss?'
)
},
'./plugin/components/Settings/switch.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./switch.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/Settings/switch.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/Settings/switch.scss?'
)
},
'./plugin/components/SettingsBtn/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const settingsBtnTpl = __webpack_require__(/*! ./settings-btn.html */ \"./plugin/components/SettingsBtn/settings-btn.html\").default;\r\n__webpack_require__(/*! ./settings-btn.scss */ \"./plugin/components/SettingsBtn/settings-btn.scss\");\r\n\r\nconst { settingsIcon, dictionaryIcon, aboutIcon, closeIcon } = __webpack_require__(/*! ../../assets/icons */ \"./plugin/assets/icons/index.js\");\r\n\r\nfunction SettingsBtn(player, screen, dictionary, infoScreen, settingsBtnClose, option) {\r\n this.player = player;\r\n this.screen = screen;\r\n this.dictionary = dictionary;\r\n this.infoScreen = infoScreen;\r\n this.settingsBtnClose = settingsBtnClose;\r\n enable = option.enableMoveWindow;\r\n}\r\n\r\nSettingsBtn.prototype.load = function(\r\n element,\r\n loadDictionary,\r\n elementDict,\r\n rootPath,\r\n) {\r\n this.element = element;\r\n this.element.innerHTML = settingsBtnTpl;\r\n this.element.classList.add('vpw-settings-btn');\r\n\r\n let loadedDict = false;\r\n\r\n const settingsBtn = this.element.querySelector('.vpw-header-btn-settings');\r\n const dictionaryBtn = this.element.querySelector('.vpw-header-btn-dictionary');\r\n const aboutBtn = this.element.querySelector('.vpw-header-btn-about');\r\n const closeBtn = this.element.querySelector('.vpw-header-btn-close');\r\n \r\n settingsBtn.classList.add('active');\r\n\r\n // Add icons\r\n settingsBtn.innerHTML = settingsIcon;\r\n dictionaryBtn.innerHTML = dictionaryIcon;\r\n aboutBtn.innerHTML = aboutIcon;\r\n closeBtn.innerHTML = closeIcon;\r\n\r\n if (enable) {\r\n closeBtn.style.display = 'flex';\r\n }\r\n\r\n settingsBtn.addEventListener(\r\n 'click',\r\n function() {\r\n showScreen(this.screen, settingsBtn);\r\n settingsBtn.blur();\r\n }.bind(this),\r\n);\r\n\r\n dictionaryBtn.addEventListener(\r\n 'click',\r\n function () {\r\n showScreen(this.dictionary, dictionaryBtn);\r\n dictionaryBtn.blur();\r\n }.bind(this)\r\n );\r\n \r\n aboutBtn.addEventListener(\r\n 'click',\r\n function () {\r\n showScreen(this.infoScreen, aboutBtn);\r\n aboutBtn.blur();\r\n }.bind(this)\r\n );\r\n\r\n closeBtn.addEventListener('click', function() {\r\n showScreen(null, null);\r\n\r\n window.dispatchEvent(\r\n new CustomEvent('vp-widget-close', {detail: {close: true}}),\r\n );\r\n });\r\n\r\n function selectButton(button) {\r\n if (button) button.classList.toggle('selected');\r\n\r\n [settingsBtn, dictionaryBtn, aboutBtn]\r\n .filter(btn => btn !== button)\r\n .forEach(btn => btn.classList.remove('selected'));\r\n }\r\n\r\n const showScreen = function (screen, btn) {\r\n if (screen == this.dictionary && !loadedDict) {\r\n loadDictionary();\r\n loadedDict = true;\r\n }\r\n\r\n [this.screen, this.dictionary,\r\n this.infoScreen]\r\n .filter(sc => sc !== screen)\r\n .forEach(sc => {\r\n if (sc == this.dictionary && !loadedDict) return;\r\n sc.hide();\r\n });\r\n\r\n if (screen) screen.toggle();\r\n selectButton(btn);\r\n this.player.pause();\r\n }.bind(this);\r\n\r\n};\r\n\r\nmodule.exports = SettingsBtn;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsBtn/index.js?"
)
},
'./plugin/components/SettingsBtn/settings-btn.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div>\\r\\n <button class=\\"vpw-header-btn-settings\\"></button>\\r\\n <button class=\\"vpw-header-btn-dictionary\\"></button>\\r\\n</div>\\r\\n<div>\\r\\n <button class=\\"vpw-header-btn-about\\"></button>\\r\\n <button class=\\"vpw-header-btn-close\\"></button>\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsBtn/settings-btn.html?'
)
},
'./plugin/components/SettingsBtn/settings-btn.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./settings-btn.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/SettingsBtn/settings-btn.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsBtn/settings-btn.scss?'
)
},
'./plugin/components/SettingsCloseBtn/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const btnCloseTpl = __webpack_require__(/*! ./settings-close-btn.html */ \"./plugin/components/SettingsCloseBtn/settings-close-btn.html\").default;\r\n__webpack_require__(/*! ./settings-close-btn.scss */ \"./plugin/components/SettingsCloseBtn/settings-close-btn.scss\");\r\n\r\nfunction SettingsCloseBtn() {\r\n this.closeScreen = null;\r\n this.element = null;\r\n}\r\n\r\nSettingsCloseBtn.prototype.load = function(element, closeScreen) {\r\n this.element = element;\r\n this.closeScreen = closeScreen;\r\n this.element.innerHTML = btnCloseTpl;\r\n this.element.classList.add('vpw-btn-close');\r\n this.element.addEventListener('click', function() {\r\n this.closeScreen.closeAll();\r\n this.element.classList.remove('active');\r\n }.bind(this));\r\n};\r\n\r\n\r\nmodule.exports = SettingsCloseBtn;\r\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsCloseBtn/index.js?"
)
},
'./plugin/components/SettingsCloseBtn/settings-close-btn.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<img class=\\"vpw-img\\" data-src=\\"assets/Close-2019.png\\">\\r\\n");\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsCloseBtn/settings-close-btn.html?'
)
},
'./plugin/components/SettingsCloseBtn/settings-close-btn.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./settings-close-btn.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/SettingsCloseBtn/settings-close-btn.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/SettingsCloseBtn/settings-close-btn.scss?'
)
},
'./plugin/components/SuggestionScreen/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const template = __webpack_require__(/*! ./suggestion-screen.html */ \"./plugin/components/SuggestionScreen/suggestion-screen.html\").default;\n__webpack_require__(/*! ./suggestion-screen.scss */ \"./plugin/components/SuggestionScreen/suggestion-screen.scss\");\n\nconst { arrowIcon } = __webpack_require__(/*! ../../assets/icons/ */ \"./plugin/assets/icons/index.js\");\nconst { SIGNS_URL } = __webpack_require__(/*! ../../config */ \"./plugin/config.js\");\n\nconst TrieSearch = __webpack_require__(/*! trie-search */ \"./node_modules/trie-search/index.js\");\nconst getCaretCoordinates = __webpack_require__(/*! textarea-caret */ \"./node_modules/textarea-caret/index.js\");\n\nfunction SuggestionScreen(player) {\n this.element = null;\n this.player = player;\n this.signsList = [];\n}\n\nfunction getInputSelection(el) {\n let start = 0;\n let end = 0;\n\n if (!el) {\n return { start: start, end: end };\n }\n\n if (\n typeof el.selectionStart == 'number' &&\n typeof el.selectionEnd == 'number'\n ) {\n return { start: el.selectionStart, end: el.selectionEnd };\n }\n\n if (!document) {\n return { start: start, end: end };\n }\n\n const range = document.selection.createRange();\n\n if (!range && range.parentElement() !== el) {\n return { start: start, end: end };\n }\n\n const len = el.value.length;\n const normalizedValue = el.value.replace(/\\r\\n/g, '\\n');\n const textInputRange = el.createTextRange();\n\n textInputRange.moveToBookmark(range.getBookmark());\n\n const endRange = el.createTextRange();\n\n endRange.collapse(false);\n\n if (textInputRange.compareEndPoints('StartToEnd', endRange) > -1) {\n start = end = len;\n } else {\n start = -textInputRange.moveStart('character', -len);\n start += normalizedValue.slice(0, start).split('\\n').length - 1;\n\n if (textInputRange.compareEndPoints('EndToEnd', endRange) > -1) {\n end = len;\n } else {\n end = -textInputRange.moveEnd('character', -len);\n end += normalizedValue.slice(0, end).split('\\n').length - 1;\n }\n }\n\n return { start: start, end: end };\n}\n\nconst getWordBySelectionIndex = (sentence, index) => {\n if (sentence.charAt(index) === ' ') {\n return { wordToSuggest: '', begin: 0, newEnd: 0 };\n }\n\n const lastSpaceBeforeSelection = sentence\n .substring(0, index + 1)\n .lastIndexOf(' ');\n const lastIndexOfSpace = sentence\n .substring(index + 1, sentence.length)\n .indexOf(' ');\n const firstSpaceAfterSelection =\n lastIndexOfSpace === -1 ? sentence.length : index + 1 + lastIndexOfSpace;\n\n return {\n wordToSuggest: sentence.substring(\n lastSpaceBeforeSelection + 1,\n firstSpaceAfterSelection\n ),\n begin: lastSpaceBeforeSelection + 1,\n newEnd: firstSpaceAfterSelection,\n };\n};\n\nconst replaceByStartAndEnd = (string, replacement, start, end) => {\n return `${string.substring(0, start)}${replacement}${string.substring(\n end,\n string.length\n )}`;\n};\n\nSuggestionScreen.prototype.load = function (element) {\n this.element = element;\n this.element.innerHTML = template;\n this.rateBox = document.querySelector('div[vp-rate-box]');\n this.gloss = null;\n\n this.textElement = this.element.querySelector('.vp-text');\n\n this.send = this.element.querySelector('.vp-send-button');\n this.visualize = this.element.querySelector('.vp-visualize-signal-button');\n\n const close = this.element.querySelector('.vp-suggestion-screen-header button');\n const dropdownSuggest = this.element.querySelector('.vp-dropdown-suggest');\n let actualBegin = 0;\n let actualEnd = 0;\n\n // Add icons\n close.innerHTML = arrowIcon;\n\n this.send.addEventListener('click', () => {\n window.plugin.sendReview('bad', this.textElement.value.trim());\n });\n\n close.addEventListener('click', function () {\n this.rateBox.classList.remove('vp-expanded');\n this.hide();\n }.bind(this));\n\n const setOption = (name) => {\n this.textElement.value = replaceByStartAndEnd(\n this.textElement.value,\n name,\n actualBegin,\n actualEnd\n ).toUpperCase();\n\n dropdownSuggest.classList.remove('vp-enabled');\n };\n\n this.visualize.addEventListener('click', () => {\n let openAfterEnd = true;\n const oldGloss = this.player.gloss;\n this.hide();\n this.player.play(this.textElement.value.trim());\n this.player.on('gloss:end', () => {\n if (openAfterEnd) {\n this.show();\n this.rateBox.classList.add('vp-enabled');\n }\n this.player.gloss = oldGloss;\n openAfterEnd = false;\n });\n });\n\n const buildSelect = (listOfSuggestions, end) => {\n const caret = getCaretCoordinates(this.textElement, end);\n\n listOfSuggestions.map((item) => {\n const opt = document.createElement('li');\n opt.appendChild(document.createTextNode(item.name));\n opt.value = item.name;\n opt.classList.add('vp-dropdown-item');\n opt.onclick = () => {\n setOption(item.name);\n };\n dropdownSuggest.appendChild(opt);\n });\n\n if (listOfSuggestions.length === 1) dropdownSuggest.style.height = '24px';\n else if (listOfSuggestions.length === 2) {\n dropdownSuggest.style.height = '40px';\n } else dropdownSuggest.style.height = '54px';\n\n dropdownSuggest.classList.add('vp-enabled');\n let left = caret.left + 25;\n if (left > 180) left = left - 50;\n dropdownSuggest.style.left = left.toString() + 'px';\n dropdownSuggest.style.top = (caret.top + 60).toString() + 'px';\n };\n\n const setWordToReplace = (begin, newEnd) => {\n actualBegin = begin;\n actualEnd = newEnd;\n };\n\n this.textElement.addEventListener('input', function () {\n const { end } = getInputSelection(this.textElement);\n\n if (!this.textElement.value.replace(/[^a-z0-9]/gi, '')) {\n this.visualize.setAttribute('disabled', true);\n this.send.setAttribute('disabled', true);\n } else {\n this.visualize.removeAttribute('disabled');\n this.send.removeAttribute('disabled');\n }\n\n const { wordToSuggest, begin, newEnd } = getWordBySelectionIndex(\n this.textElement.value,\n end - 1\n );\n setWordToReplace(begin, newEnd);\n\n while (dropdownSuggest.firstChild) {\n dropdownSuggest.removeChild(dropdownSuggest.firstChild);\n }\n\n if (wordToSuggest && wordToSuggest.length >= 2) {\n const ts = new TrieSearch('name');\n ts.addAll(this.signsList);\n const listOfSuggestions = ts.get(wordToSuggest);\n if (listOfSuggestions.length == 0) {\n dropdownSuggest.classList.remove('vp-enabled');\n } else buildSelect(listOfSuggestions, end);\n } else {\n dropdownSuggest.classList.remove('vp-enabled');\n }\n }.bind(this));\n\n this.textElement.addEventListener('keypress', function (e) {\n if (e.key === 'Enter' && !this.send.disabled) {\n this.player.translate(this.textElement.value);\n }\n }.bind(this))\n\n const xhr = new XMLHttpRequest();\n xhr.open('get', SIGNS_URL, true);\n xhr.responseType = 'text';\n xhr.onload = function () {\n if (xhr.status == 200) {\n this.signsList = JSON.parse(xhr.response).map((item) => ({ name: item }));\n } else {\n console.error('Bad answer for get signs list, status: ' + xhr.status);\n }\n }.bind(this);\n xhr.send();\n};\n\nSuggestionScreen.prototype.setGloss = function (gloss) {\n this.textElement.value = this.gloss || gloss;\n this.gloss = gloss;\n this.send.removeAttribute('disabled');\n this.visualize.removeAttribute('disabled');\n};\n\nSuggestionScreen.prototype.show = function () {\n // this.element.querySelector('.vp-text').style.display = 'block';\n this.element.classList.add('vp-enabled');\n this.element.classList.add('vp-expanded');\n this.element.querySelector('.vp-dropdown-suggest').classList.remove('vp-enabled');\n};\n\nSuggestionScreen.prototype.hide = function () {\n // this.element.querySelector('.vp-text').style.display = 'none';\n this.element.classList.remove('vp-enabled');\n};\n\nmodule.exports = SuggestionScreen;\n\n\n//# sourceURL=webpack://VLibras/./plugin/components/SuggestionScreen/index.js?"
)
},
'./plugin/components/SuggestionScreen/suggestion-screen.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div class=\\"vp-suggestion-screen-header\\">\\r\\n <span>Feedback</span>\\r\\n <button></button>\\r\\n</div>\\r\\n\\r\\n<div class=\\"vp-suggestion-screen-content\\">\\r\\n\\r\\n <span class=\\"vp-title\\">Informe a glosa correta</span>\\r\\n\\r\\n <textarea class=\\"vp-text\\"> </textarea>\\r\\n <ul class=\\"vp-dropdown-suggest\\"></ul>\\r\\n\\r\\n <div vp-sugestion-area class=\\"vp-suggestion-buttons-container\\">\\r\\n <button vp-visualize-signal-button class=\\"vp-visualize-signal-button\\">\\r\\n Reproduzir\\r\\n </button>\\r\\n <button vp-blue-button class=\\"vp-send-button\\">Enviar sugestão</button>\\r\\n </div>\\r\\n\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./plugin/components/SuggestionScreen/suggestion-screen.html?'
)
},
'./plugin/components/SuggestionScreen/suggestion-screen.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./suggestion-screen.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/components/SuggestionScreen/suggestion-screen.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/components/SuggestionScreen/suggestion-screen.scss?'
)
},
'./plugin/config.js': function (module, exports) {
eval(
"// prod urls\nexports.DICTIONARY_URL = 'https://dicionario2.vlibras.gov.br/signs?version=2018.3.1';\nexports.REVIEW_URL = 'https://traducao2.vlibras.gov.br/review';\nexports.SIGNS_URL = 'https://repositorio.vlibras.gov.br/api/signs';\n\n// homolog urls\n// exports.DICTIONARY_URL = 'https://dicionario2-dth.vlibras.gov.br/signs?version=2018.3.1';\n// exports.REVIEW_URL = 'https://traducao2-dth.vlibras.gov.br/dl/review';\n// exports.SIGNS_URL = 'https://repositorio-dth.vlibras.gov.br/api/signs';\n\n\n//# sourceURL=webpack://VLibras/./plugin/config.js?"
)
},
'./plugin/scss/styles.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../node_modules/css-loader/dist/cjs.js!../../node_modules/sass-loader/dist/cjs.js!./styles.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./plugin/scss/styles.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./plugin/scss/styles.scss?'
)
},
'./widget/src/Widget.js': function (module, exports, __webpack_require__) {
eval(
"const AccessButton = __webpack_require__(/*! ./components/AccessButton */ \"./widget/src/components/AccessButton/index.js\");\r\nconst PluginWrapper = __webpack_require__(/*! ./components/PluginWrapper */ \"./widget/src/components/PluginWrapper/index.js\");\r\n\r\n__webpack_require__(/*! ./scss/reset.scss */ \"./widget/src/scss/reset.scss\");\r\n__webpack_require__(/*! ./scss/styles.scss */ \"./widget/src/scss/styles.scss\");\r\n\r\nconst widgetPosition = ['TL', 'T', 'TR', 'L', 'R', 'BL', 'B', 'BR'];\r\n\r\nmodule.exports = function Widget(rootPath, personalization, opacity) {\r\n const widgetWrapper = new PluginWrapper();\r\n const accessButton = new AccessButton(\r\n rootPath,\r\n widgetWrapper,\r\n personalization,\r\n opacity\r\n );\r\n let tempF;\r\n\r\n if (window.onload) {\r\n tempF = window.onload;\r\n }\r\n\r\n window.onload = () => {\r\n if (tempF) {\r\n tempF();\r\n }\r\n\r\n this.element = document.querySelector('[vw]');\r\n\r\n const wrapper = document.querySelector('[vw-plugin-wrapper]');\r\n const access = document.querySelector('[vw-access-button]');\r\n\r\n accessButton.load(\r\n document.querySelector('[vw-access-button]'),\r\n this.element\r\n );\r\n widgetWrapper.load(document.querySelector('[vw-plugin-wrapper]'));\r\n\r\n window.addEventListener('vp-widget-wrapper-set-side', (event) => {\r\n const { position } = event.detail;\r\n if (!position || !widgetPosition.includes(position)) return;\r\n\r\n this.element.style.left = position.includes('L')\r\n ? '0' : ['T', 'B'].includes(position) ? '50%' : 'initial';\r\n\r\n this.element.style.right = position.includes('R')\r\n ? '0' : 'initial';\r\n \r\n this.element.style.top = position.includes('T') \r\n ? '0' : ['L', 'R'].includes(position) ? '50%' : 'initial';\r\n\r\n this.element.style.bottom = position.includes('B')\r\n ? '0' : 'initial';\r\n\r\n this.element.style.transform = ['L', 'R'].includes(position)\r\n ? 'translateY(calc(-50% - 10px))' : ['T', 'B'].includes(position) \r\n ? 'translateX(calc(-50% - 10px))' : 'initial';\r\n\r\n document.querySelector('[vw-access-button]')\r\n .style.margin = position.includes('R')\r\n ? '0' : '0px 0px 0px -120px';\r\n\r\n if (position.includes('R')) access.querySelector('.pop-up')\r\n .classList.remove('left')\r\n\r\n else access.querySelector('.pop-up')\r\n .classList.add('left')\r\n });\r\n\r\n window.addEventListener('vp-widget-close', (event) => {\r\n access.classList.toggle('active');\r\n wrapper.classList.toggle('active');\r\n\r\n document.body.removeChild(document.querySelector('.vw-links'));\r\n\r\n const tagsTexts = document.querySelectorAll('.vw-text');\r\n for (let i = 0; i < tagsTexts.length; i++) {\r\n const parent = tagsTexts[i].parentNode;\r\n parent.innerHTML = tagsTexts[i].innerHTML;\r\n }\r\n });\r\n\r\n window.addEventListener('vw-change-opacity', (event) => {\r\n wrapper.style.background = `rgba(235,235,235, ${event.detail})`;\r\n });\r\n\r\n this.element.querySelectorAll('img[data-src]').forEach((image) => {\r\n const imagePath = image.attributes['data-src'].value;\r\n image.src = rootPath ? rootPath + '/' + imagePath : imagePath;\r\n });\r\n };\r\n};\r\n\r\nnew MutationObserver((mutations) => {\r\n if (!document.querySelector('vlibraswidget')) return;\r\n const vw = document.querySelector('[vw]');\r\n\r\n mutations.forEach(mut => {\r\n if (mut.addedNodes.length === 0) return;\r\n\r\n try {\r\n mut.addedNodes.forEach(node => {\r\n node.querySelectorAll(\r\n 'span, h1, h2, h3, h4, h5, h6, label, p, button, div'\r\n ).forEach(el => {\r\n if (vw.contains(el)) return;\r\n const firstChild = el.children[0];\r\n \r\n if(firstChild || !el.textContent) return;\r\n \r\n el.innerHTML = '<vlibraswidget class=\"vw-text\">'\r\n + el.textContent + '</vlibraswidget>';\r\n\r\n el.addEventListener('click', \r\n () => window.plugin.player.translate(el.textContent));\r\n });\r\n });\r\n } catch {}\r\n })\r\n\r\n}).observe(document.body, { childList: true, subtree: true });\r\n\n\n//# sourceURL=webpack://VLibras/./widget/src/Widget.js?"
)
},
'./widget/src/components/AccessButton/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
"const template = __webpack_require__(/*! ./template.html */ \"./widget/src/components/AccessButton/template.html\").default;\r\n__webpack_require__(/*! ./styles.scss */ \"./widget/src/components/AccessButton/styles.scss\");\r\n\r\nfunction AccessButton(rootPath, pluginWrapper, personalization, opacity) {\r\n this.personalization = personalization;\r\n this.rootPath = rootPath;\r\n this.pluginWrapper = pluginWrapper;\r\n this.vw_links = null;\r\n this.currentElement = null;\r\n this.currentSpanElement = null;\r\n this.opacity = opacity;\r\n}\r\n\r\nAccessButton.prototype.load = function (element, vw) {\r\n this.element = element;\r\n this.element.innerHTML = template;\r\n this.element.addEventListener('click', () => {\r\n this.element.classList.toggle('active');\r\n this.pluginWrapper.element.classList.toggle('active');\r\n\r\n window.plugin =\r\n window.plugin ||\r\n new window.VLibras.Plugin({\r\n enableMoveWindow: true,\r\n playWellcome: true,\r\n rootPath: this.rootPath,\r\n personalization: this.personalization,\r\n opacity: this.opacity,\r\n wrapper: this.pluginWrapper.element,\r\n });\r\n\r\n this.addTagsTexts(vw);\r\n });\r\n};\r\n\r\nmodule.exports = AccessButton;\r\n\r\nlet control = 0;\r\n\r\nfunction updatePosition() {\r\n if (\r\n this.currentElement != null &&\r\n this.vw_links != null &&\r\n this.currentSpanElement != null\r\n ) {\r\n positionElement = getPosition(this.currentElement);\r\n const width = this.currentSpanElement.offsetWidth;\r\n const height = this.currentSpanElement.offsetHeight;\r\n this.vw_links.style.top = positionElement.y + height / 2 + 'px';\r\n this.vw_links.style.left = positionElement.x + width / 2 + 'px';\r\n }\r\n}\r\n\r\nfunction hasParent(el, fn) {\r\n let node = el.parentElement;\r\n\r\n while (node != null) {\r\n if (fn(node)) return node;\r\n node = node.parentElement;\r\n }\r\n\r\n return false;\r\n}\r\n\r\nfunction getPosition(elem) {\r\n const box = elem.getBoundingClientRect();\r\n\r\n const body = document.body;\r\n const docEl = document.documentElement;\r\n\r\n const scrollTop = window.pageYOffset || docEl.scrollTop || body.scrollTop;\r\n const scrollLeft = window.pageXOffset || docEl.scrollLeft || body.scrollLeft;\r\n\r\n const clientTop = docEl.clientTop || body.clientTop || 0;\r\n const clientLeft = docEl.clientLeft || body.clientLeft || 0;\r\n\r\n const top = box.top + scrollTop - clientTop;\r\n const left = box.left + scrollLeft - clientLeft;\r\n\r\n return { y: Math.round(top), x: Math.round(left) };\r\n}\r\n\r\nfunction createAccessLinkBox() {\r\n const template = __webpack_require__(/*! ./tooltip.html */ \"./widget/src/components/AccessButton/tooltip.html\").default;\r\n const div = document.createElement('div');\r\n div.className = 'vw-links';\r\n div.innerHTML = template;\r\n document.body.appendChild(div);\r\n}\r\n\r\nAccessButton.prototype.divBox = function (linkContent, event) {\r\n nodeAnchor = hasParent(linkContent, function (parent) {\r\n return parent.nodeName == 'A';\r\n });\r\n if (!nodeAnchor) {\r\n return;\r\n }\r\n event.stopPropagation();\r\n this.currentElement = nodeAnchor;\r\n this.currentSpanElement = linkContent;\r\n positionElement = getPosition(nodeAnchor);\r\n const width = linkContent.offsetWidth;\r\n const height = linkContent.offsetHeight;\r\n\r\n anchorElement = this.vw_links.querySelector('a');\r\n anchorElement.href = nodeAnchor.href;\r\n this.vw_links.style.top = positionElement.y + height / 2 + 'px';\r\n this.vw_links.style.left = positionElement.x + width / 2 + 'px';\r\n this.vw_links.firstChild.classList.add('active');\r\n};\r\n\r\nAccessButton.prototype.addTagsTexts = function (vw) {\r\n self = this;\r\n getAllNodeTexts(\r\n document.body,\r\n function (node) {\r\n if (vw.contains(node)) return;\r\n node.innerHTML = '<vlibraswidget>' + node.innerHTML + '</vlibraswidget>';\r\n const span = node.querySelector('vlibraswidget');\r\n if (!span) {\r\n return;\r\n }\r\n span.classList.add('vw-text');\r\n span.addEventListener('click', function (e) {\r\n e.preventDefault();\r\n self.divBox(this, e);\r\n if (control) window.plugin.player.stop();\r\n window.plugin.player.translate(this.textContent);\r\n deactivateAll();\r\n this.classList.add('vw-text-active');\r\n control++;\r\n });\r\n },\r\n function (textNode, parent) {\r\n if (/^\\s+$/.test(textNode.nodeValue)) {\r\n return true;\r\n }\r\n return false;\r\n }\r\n );\r\n createAccessLinkBox();\r\n this.vw_links = document.body.getElementsByClassName('vw-links')[0];\r\n document.body.onclick = function (e) {\r\n if (this.vw_links != null) {\r\n this.vw_links.firstChild.classList.remove('active');\r\n }\r\n }.bind(this);\r\n window.addEventListener('scroll', updatePosition.bind(this), false);\r\n window.addEventListener('resize', updatePosition.bind(this), false);\r\n};\r\n\r\nfunction getAllNodeTexts(root, callback) {\r\n const noop = function () {};\r\n const headElements = ['SCRIPT', 'TITLE', 'META', 'STYLE', 'LINK', 'BASE'];\r\n\r\n for (let i = 0; i < root.childNodes.length; i++) {\r\n const node = root.childNodes[i];\r\n let anyText = false;\r\n\r\n if (headElements.indexOf(node.tagName) != -1) {\r\n continue;\r\n }\r\n\r\n for (let j = 0; j < node.childNodes.length; j++) {\r\n const child = node.childNodes[j];\r\n if (child.nodeType == Node.TEXT_NODE && child.nodeValue.trim() != '') {\r\n anyText = true;\r\n break;\r\n }\r\n }\r\n\r\n if (anyText) {\r\n (callback || noop)(node);\r\n } else {\r\n getAllNodeTexts(node, callback);\r\n }\r\n }\r\n}\r\n\r\nfunction deactivateAll() {\r\n const active = document.querySelector('.vw-text.vw-text-active');\r\n if (active) {\r\n active.classList.remove('vw-text-active');\r\n }\r\n}\r\n\n\n//# sourceURL=webpack://VLibras/./widget/src/components/AccessButton/index.js?"
)
},
'./widget/src/components/AccessButton/styles.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../../node_modules/css-loader/dist/cjs.js!../../../../node_modules/sass-loader/dist/cjs.js!./styles.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/components/AccessButton/styles.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./widget/src/components/AccessButton/styles.scss?'
)
},
'./widget/src/components/AccessButton/template.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<img class=\\"access-button\\" data-src=\\"assets/component-ac.png\\" alt=\\"Conteúdo acessível em libras usando o VLibras Widget com opções dos Avatares Ícaro ou Hozana.\\" />\\r\\n<img class=\\"pop-up\\"data-src=\\"assets/popup.png\\" alt=\\"Conteúdo acessível em libras usando o VLibras Widget com opções dos Avatares Ícaro ou Hozana.\\" />");\n\n//# sourceURL=webpack://VLibras/./widget/src/components/AccessButton/template.html?'
)
},
'./widget/src/components/AccessButton/tooltip.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div class=\\"vw-tooltip\\">\\r\\n <div class=\\"vw-tooltip__item\\">\\r\\n <a href=\\"\\" target=\\"_blank\\" rel=\\"noopener noreferrer\\" >Acessar Link</a>\\r\\n </div>\\r\\n</div>");\n\n//# sourceURL=webpack://VLibras/./widget/src/components/AccessButton/tooltip.html?'
)
},
'./widget/src/components/PluginWrapper/index.js': function (
module,
exports,
__webpack_require__
) {
eval(
'const template = __webpack_require__(/*! ./template.html */ "./widget/src/components/PluginWrapper/template.html").default;\r\n__webpack_require__(/*! ./styles.scss */ "./widget/src/components/PluginWrapper/styles.scss");\r\nfunction PluginWrapper() {}\r\n\r\nPluginWrapper.prototype.load = function (element) {\r\n this.element = element;\r\n this.element.innerHTML = template;\r\n};\r\n\r\nmodule.exports = PluginWrapper;\r\n\n\n//# sourceURL=webpack://VLibras/./widget/src/components/PluginWrapper/index.js?'
)
},
'./widget/src/components/PluginWrapper/styles.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../../node_modules/css-loader/dist/cjs.js!../../../../node_modules/sass-loader/dist/cjs.js!./styles.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/components/PluginWrapper/styles.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./widget/src/components/PluginWrapper/styles.scss?'
)
},
'./widget/src/components/PluginWrapper/template.html': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony default export */ __webpack_exports__["default"] = ("<div vp>\\n <div vp-box></div>\\n <div vp-message-box></div>\\n <div vp-settings></div>\\n <div vp-settings-btn></div>\\n <div vp-info-screen></div>\\n <div vp-dictionary></div>\\n <div vp-suggestion-screen></div>\\n <div vp-translator-screen></div>\\n <div vp-widget-help></div>\\n <div vp-suggestion-button></div>\\n <div vp-rate-box></div>\\n <div vp-rate-button></div>\\n <div vp-controls></div>\\n <div vp-change-avatar></div>\\n <div vp-additional-options></div>\\n</div>");\n\n//# sourceURL=webpack://VLibras/./widget/src/components/PluginWrapper/template.html?'
)
},
'./widget/src/index.js': function (
module,
__webpack_exports__,
__webpack_require__
) {
'use strict'
eval(
'__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Widget", function() { return Widget; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Plugin", function() { return Plugin; });\nconst Plugin = __webpack_require__(/*! ../../plugin/Plugin */ "./plugin/Plugin.js");\r\nconst Widget = __webpack_require__(/*! ./Widget */ "./widget/src/Widget.js");\r\n\r\n\r\n\n\n//# sourceURL=webpack://VLibras/./widget/src/index.js?'
)
},
'./widget/src/scss/reset.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./reset.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/scss/reset.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./widget/src/scss/reset.scss?'
)
},
'./widget/src/scss/styles.scss': function (
module,
exports,
__webpack_require__
) {
eval(
'var api = __webpack_require__(/*! ../../../node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js */ "./node_modules/style-loader/dist/runtime/injectStylesIntoStyleTag.js");\n var content = __webpack_require__(/*! !../../../node_modules/css-loader/dist/cjs.js!../../../node_modules/sass-loader/dist/cjs.js!./styles.scss */ "./node_modules/css-loader/dist/cjs.js!./node_modules/sass-loader/dist/cjs.js!./widget/src/scss/styles.scss");\n\n content = content.__esModule ? content.default : content;\n\n if (typeof content === \'string\') {\n content = [[module.i, content, \'\']];\n }\n\nvar options = {};\n\noptions.insert = "head";\noptions.singleton = false;\n\nvar update = api(content, options);\n\n\n\nmodule.exports = content.locals || {};\n\n//# sourceURL=webpack://VLibras/./widget/src/scss/styles.scss?'
)
},
window: function (module, exports) {
eval(
'(function() { module.exports = window["window"]; }());\n\n//# sourceURL=webpack://VLibras/external_%22window%22?'
)
},
})
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment