From a0f9ce255906a9f54bee2f712e380ed16852c609 Mon Sep 17 00:00:00 2001 From: amartya-dev Date: Wed, 31 May 2023 16:36:14 +0530 Subject: [PATCH 1/2] add events and fix feedback api url --- build/index.asset.php | 2 +- build/index.css | 260 +- build/index.css.map | 1 + build/index.js | 13891 ++++++++++++++++++- build/index.js.map | 1 + includes/HelpCenter.php | 10 +- package-lock.json | 21784 +----------------------------- package.json | 1 + src/components/Feedback.js | 3 +- src/components/SearchResults.js | 3 +- src/index.js | 12 +- src/utils.js | 10 +- 12 files changed, 14468 insertions(+), 21510 deletions(-) create mode 100644 build/index.css.map create mode 100644 build/index.js.map diff --git a/build/index.asset.php b/build/index.asset.php index 8b17eb0..b905b7e 100644 --- a/build/index.asset.php +++ b/build/index.asset.php @@ -1 +1 @@ - array('lodash', 'react', 'wp-api-fetch', 'wp-edit-post', 'wp-element', 'wp-i18n', 'wp-plugins'), 'version' => '1876b438a02bb7ce3409'); + array('lodash', 'react', 'wp-api-fetch', 'wp-data', 'wp-edit-post', 'wp-element', 'wp-i18n', 'wp-plugins'), 'version' => '21548868e6ca22bc2d01'); diff --git a/build/index.css b/build/index.css index d5ce561..2fa4575 100644 --- a/build/index.css +++ b/build/index.css @@ -1 +1,259 @@ -#nfd-help-center .modal{padding-bottom:32px}#nfd-help-center .modal h3,#nfd-help-center .modal h4{margin:0!important}#nfd-help-center .modal .modal-header{display:flex;justify-content:space-between;padding:16px}#nfd-help-center .modal .modal-header .heading{align-items:center;color:#394150;display:flex;font-size:20px;font-weight:400;line-height:24px}#nfd-help-center .modal .modal-header .heading .icon{margin-right:10px;padding-top:3px}#nfd-help-center .modal .modal-header .close-button{background:none;border:0}.nfd-help-center{padding:0 16px}.nfd-help-center h3,.nfd-help-center h4{margin:0!important}.nfd-help-center .launch-help-center{text-align:center}.nfd-help-center .launch-help-center .launch-description{margin:24px 0}.nfd-help-center .launch-help-center .launch-action{align-items:center;display:flex;justify-content:center}.nfd-help-center .launch-help-center button{background-color:#196bde;border:1px solid #196bde;color:#fff;cursor:grab;height:36px;width:146px}.nfd-help-center .launch-help-center p{font-size:18px}.nfd-help-center .launch-help-center a{cursor:grab;display:block;margin-top:16px}.nfd-help-center .suggestions-container .section-header{margin-bottom:8px!important}.nfd-help-center .suggestions-container .article .description,.nfd-help-center .suggestions-container .video .description{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;line-height:1.2em;margin:8px 0;overflow:hidden;text-overflow:ellipsis}.nfd-help-center .suggestions-container .article:hover,.nfd-help-center .suggestions-container .video:hover{background:rgba(57,172,229,.1)}.nfd-help-center .suggestion[data-variant=video] iframe{height:146px;width:248px}.nfd-help-center .search-container{background-color:#f0f3f5;border-radius:8px;display:flex;height:42px;margin:16px 0 0;padding-right:5px}.nfd-help-center .search-container input{background-color:#f0f3f5;border:none;color:#1d1d1f;font-size:15px;padding-left:0}.nfd-help-center .search-container input:focus{box-shadow:none!important;outline:none!important}.nfd-help-center .search-container button{background-color:#f0f3f5;background:transparent;border:none;box-shadow:none;cursor:text;padding-top:3px}.nfd-help-center .attribute{color:rgba(57,65,80,.6);display:flex;justify-content:flex-end;margin-top:0;padding-left:2px;padding-right:2px}.nfd-help-center .attribute span{color:#394150;font-size:12px;font-weight:500;line-height:14px;text-align:right}.nfd-help-center .algoliaResult{border-radius:24px;box-shadow:0 0 0 1px #dddfe0;box-sizing:border-box;color:#394150;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:8px;padding:12px 16px;position:relative;transition:box-shadow .2s ease}.nfd-help-center .algoliaResult p{margin:0!important}.nfd-help-center .algoliaResult .svg{position:absolute;right:16px;top:50%;transform:translateY(-50%);transition:right .2s ease}.nfd-help-center .algoliaResult:hover{box-shadow:0 0 0 2px #3575d3}.nfd-help-center .algoliaResult:hover .svg{right:14px}.nfd-help-center .feedback-container{background-color:#f0f3f5;border-radius:4px;display:flex;justify-content:space-between;margin-bottom:8%;margin-top:6%;padding-left:4%;padding-right:4%}.nfd-help-center .feedback-container button{border-color:#b2bcc2;border-radius:20px;border-width:1px;box-shadow:none;cursor:pointer;padding-bottom:5%;padding-top:5%}.nfd-help-center .feedback-container .feedback-button{padding:6px 13px}.nfd-help-center .feedback-container .button-icon{height:20px;margin-right:4px;width:20px}.nfd-help-center .feedback-container .yes{border-bottom-right-radius:0;border-right-width:0;border-top-right-radius:0}.nfd-help-center .feedback-container .no{border-bottom-left-radius:0;border-top-left-radius:0}.nfd-help-center .feedback-container .selected-yes{background:linear-gradient(0deg,#e6fff4,#e6fff4),#fff;padding-bottom:4.4px;padding-top:5.8px}.nfd-help-center .feedback-container .selected-no{background-color:#ffdcdc;padding-bottom:4.4px;padding-top:5.8px}.nfd-help-center .feedback-container .icon{cursor:pointer;margin-top:8px}.help-container{background:#fff;border:1px solid #dcdcdc;box-shadow:-5px 0 36px rgba(0,0,0,.25);display:block!important;height:100vh;overflow:auto;position:fixed;right:0;width:350px}.wpcontent-container{display:flex}@media screen and (min-width:1814px){.toplevel_page_bluehost .wpcontent-container{display:flex}.toplevel_page_bluehost .wpcontent-container #wpbody{flex:1}.toplevel_page_bluehost .wpcontent-container #wpbody #bwa-app{margin-left:20px!important}.toplevel_page_bluehost .wpcontent-container #wpbody #bwa-app #bluehost-logo-wrap{padding:14px 0 0 12px}}body:is(.page,.post-php,.post-new-php) #wp-admin-bar-help-center{display:none}.mobile #wpadminbar ul#wp-admin-bar-root-default li{width:40px!important}.mobile #wpadminbar li#wp-admin-bar-help-center{display:block}.icon-button{cursor:pointer} +/*!************************************************************************************************************************************************************************************************************************************!*\ + !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[3].use[1]!./node_modules/postcss-loader/dist/cjs.js??ruleSet[1].rules[3].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[3].use[3]!./styles.scss ***! + \************************************************************************************************************************************************************************************************************************************/ +#nfd-help-center .modal { + padding-bottom: 32px; +} +#nfd-help-center .modal h4, +#nfd-help-center .modal h3 { + margin: 0 0 !important; +} +#nfd-help-center .modal .modal-header { + padding: 16px; + display: flex; + justify-content: space-between; +} +#nfd-help-center .modal .modal-header .heading { + display: flex; + align-items: center; + font-size: 20px; + line-height: 24px; + font-weight: normal; + color: #394150; +} +#nfd-help-center .modal .modal-header .heading .icon { + margin-right: 10px; + padding-top: 3px; +} +#nfd-help-center .modal .modal-header .close-button { + border: 0; + background: none; +} + +.nfd-help-center { + padding: 0 16px; +} +.nfd-help-center h4, +.nfd-help-center h3 { + margin: 0 0 !important; +} +.nfd-help-center .launch-help-center { + text-align: center; +} +.nfd-help-center .launch-help-center .launch-description { + margin: 24px 0; +} +.nfd-help-center .launch-help-center .launch-action { + display: flex; + justify-content: center; + align-items: center; +} +.nfd-help-center .launch-help-center button { + width: 146px; + height: 36px; + background-color: #196bde; + border: 1px solid #196bde; + color: #ffffff; + cursor: grab; +} +.nfd-help-center .launch-help-center p { + font-size: 18px; +} +.nfd-help-center .launch-help-center a { + margin-top: 16px; + display: block; + cursor: grab; +} +.nfd-help-center .suggestions-container .section-header { + margin-bottom: 8px !important; +} +.nfd-help-center .suggestions-container .video .description, +.nfd-help-center .suggestions-container .article .description { + line-height: 1.2em; + display: -webkit-box; + -webkit-line-clamp: 2; + -webkit-box-orient: vertical; + overflow: hidden; + text-overflow: ellipsis; + margin: 8px 0; +} +.nfd-help-center .suggestions-container .video:hover, +.nfd-help-center .suggestions-container .article:hover { + background: rgba(57, 172, 229, 0.1); +} +.nfd-help-center .suggestion[data-variant=video] iframe { + height: 146px; + width: 248px; +} +.nfd-help-center .search-container { + display: flex; + height: 42px; + border-radius: 8px; + padding-right: 5px; + background-color: #F0F3F5; + margin: 16px 0px 0px; +} +.nfd-help-center .search-container input { + border: none; + background-color: #F0F3F5; + font-size: 15px; + color: #1D1D1F; + padding-left: 0px; +} +.nfd-help-center .search-container input:focus { + outline: none !important; + box-shadow: none !important; +} +.nfd-help-center .search-container button { + box-shadow: none; + padding-top: 3px; + background-color: #F0F3F5; + border: none; + background: transparent; + cursor: text; +} +.nfd-help-center .attribute { + display: flex; + justify-content: flex-end; + margin-top: 0px; + padding-left: 2px; + padding-right: 2px; + color: rgba(57, 65, 80, 0.6); +} +.nfd-help-center .attribute span { + font-weight: 500; + font-size: 12px; + line-height: 14px; + text-align: right; + color: #394150; +} +.nfd-help-center .algoliaResult { + border-radius: 24px; + display: flex; + margin-bottom: 8px; + padding: 12px 16px; + box-shadow: 0 0 0 1px #DDDFE0; + transition: box-shadow 0.2s ease; + box-sizing: border-box; + cursor: pointer; + position: relative; + justify-content: space-between; + color: #394150; +} +.nfd-help-center .algoliaResult p { + margin: 0 !important; +} +.nfd-help-center .algoliaResult .svg { + position: absolute; + right: 16px; + top: 50%; + transform: translateY(-50%); + transition: right 0.2s ease; +} +.nfd-help-center .algoliaResult:hover { + box-shadow: 0 0 0 2px #3575d3; +} +.nfd-help-center .algoliaResult:hover .svg { + right: 14px; +} +.nfd-help-center .feedback-container { + display: flex; + justify-content: space-between; + background-color: #F0F3F5; + padding-left: 4%; + padding-right: 4%; + border-radius: 4px; + margin-top: 6%; + margin-bottom: 8%; +} +.nfd-help-center .feedback-container button { + border-radius: 20px; + border-color: #B2BCC2; + border-width: 1px; + padding-top: 5%; + padding-bottom: 5%; + cursor: pointer; + box-shadow: none; +} +.nfd-help-center .feedback-container .feedback-button { + padding-left: 13px; + padding-right: 13px; + padding-bottom: 6px; + padding-top: 6px; +} +.nfd-help-center .feedback-container .button-icon { + height: 20px; + width: 20px; + margin-right: 4px; +} +.nfd-help-center .feedback-container .yes { + border-bottom-right-radius: 0px; + border-top-right-radius: 0px; + border-right-width: 0px; +} +.nfd-help-center .feedback-container .no { + border-bottom-left-radius: 0px; + border-top-left-radius: 0px; +} +.nfd-help-center .feedback-container .selected-yes { + background: linear-gradient(0deg, #E6FFF4, #E6FFF4), #FFFFFF; + padding-bottom: 4.4px; + padding-top: 5.8px; +} +.nfd-help-center .feedback-container .selected-no { + background-color: #FFDCDC; + padding-bottom: 4.4px; + padding-top: 5.8px; +} +.nfd-help-center .feedback-container .icon { + margin-top: 8px; + cursor: pointer; +} + +.help-container { + width: 350px; + height: 100vh; + overflow: auto; + position: fixed; + right: 0; + background: white; + display: block !important; + border: 1px solid #DCDCDC; + box-shadow: -5px 0px 36px rgba(0, 0, 0, 0.25); +} + +.wpcontent-container { + display: flex; +} + +@media screen and (min-width: 1814px) { + .toplevel_page_bluehost .wpcontent-container { + display: flex; + } + .toplevel_page_bluehost .wpcontent-container #wpbody { + flex: 1; + } + .toplevel_page_bluehost .wpcontent-container #wpbody #bwa-app { + margin-left: 20px !important; + } + .toplevel_page_bluehost .wpcontent-container #wpbody #bwa-app #bluehost-logo-wrap { + padding: 14px 0 0 12px; + } +} + +body:is(.page, .post-php, .post-new-php) #wp-admin-bar-help-center { + display: none; +} + +.mobile #wpadminbar ul#wp-admin-bar-root-default li { + width: 40px !important; +} +.mobile #wpadminbar li#wp-admin-bar-help-center { + display: block; +} + +.icon-button { + cursor: pointer; +} + +/*# sourceMappingURL=index.css.map*/ \ No newline at end of file diff --git a/build/index.css.map b/build/index.css.map new file mode 100644 index 0000000..6ee8f55 --- /dev/null +++ b/build/index.css.map @@ -0,0 +1 @@ +{"version":3,"file":"index.css","mappings":";;;AACE;EACE;ACAJ;ADEI;;EAEE;ACAN;ADGI;EACE;EACA;EACA;ACDN;ADEM;EACE;EACA;EACA;EACA;EACA;EACA;ACAR;ADCQ;EACE;EACA;ACCV;ADGM;EACE;EACA;ACDR;;AAzBA;EAKE;AAwBF;AA5BE;;EAEE;AA8BJ;AA3BE;EACE;AA6BJ;AA5BI;EACE;AA8BN;AA5BI;EACE;EACA;EACA;AA8BN;AA5BI;EACE;EACA;EACA;EACA;EACA;EACA;AA8BN;AA5BI;EACE;AA8BN;AA5BI;EACE;EACA;EACA;AA8BN;AAzBI;EACE;AA2BN;AAvBM;;EACE;EACA;EACA;EACA;EACA;EACA;EACA;AA0BR;AAxBM;;EACE;AA2BR;AArBI;EACE;EACA;AAuBN;AAnBE;EACE;EACA;EACA;EACA;EACA;EACA;AAqBJ;AApBI;EACE;EACA;EACA;EACA;EACA;AAsBN;AArBM;EACE;EACA;AAuBR;AApBI;EACE;EACA;EACA;EACA;EACA;EACA;AAsBN;AAlBE;EACE;EACA;EACA;EACA;EACA;EACA;AAoBJ;AAnBI;EACE;EACA;EACA;EACA;EACA;AAqBN;AAjBE;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAmBJ;AAlBI;EACE;AAoBN;AAlBI;EACE;EACA;EACA;EACA;EACA;AAoBN;AAlBI;EACE;AAoBN;AAnBM;EACE;AAqBR;AAhBE;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAkBJ;AAjBI;EACE;EACA;EACA;EACA;EACA;EACA;EACA;AAmBN;AAjBI;EACE;EACA;EACA;EACA;AAmBN;AAjBI;EACE;EACA;EACA;AAmBN;AAjBI;EACE;EACA;EACA;AAmBN;AAjBI;EACE;EACA;AAmBN;AAjBI;EACE;EACA;EACA;AAmBN;AAjBI;EACE;EACA;EACA;AAmBN;AAjBI;EACE;EACA;AAmBN;;AAdA;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;AAiBF;;AAdA;EACE;AAiBF;;AAXE;EACE;IACE;EAcJ;EAZI;IACE;EAcN;EAbM;IACE;EAeR;EAdQ;IACE;EAgBV;AACF;;AARE;EACE;AAWJ;;AAJM;EACE;AAOR;AAJI;EACE;AAMN;;AADA;EACE;AAIF,C","sources":["webpack://@newfold-labs/wp-module-help-center/./modal.scss","webpack://@newfold-labs/wp-module-help-center/./styles.scss"],"sourcesContent":["#nfd-help-center {\n .modal {\n padding-bottom: 32px;\n\n h4,\n h3 {\n margin: 0 0 !important;\n }\n\n .modal-header {\n padding: 16px;\n display: flex;\n justify-content: space-between;\n .heading {\n display: flex;\n align-items: center;\n font-size: 20px;\n line-height: 24px;\n font-weight: normal;\n color: #394150;\n .icon {\n margin-right: 10px;\n padding-top: 3px;\n }\n }\n\n .close-button {\n border: 0;\n background: none;\n }\n }\n }\n}\n","@import \"./modal.scss\";\n\n.nfd-help-center {\n h4,\n h3 {\n margin: 0 0 !important;\n }\n padding: 0 16px;\n .launch-help-center {\n text-align: center;\n .launch-description {\n margin: 24px 0;\n }\n .launch-action {\n display: flex;\n justify-content: center;\n align-items: center;\n }\n button {\n width: 146px;\n height: 36px;\n background-color: #196bde;\n border: 1px solid #196bde;\n color: #ffffff;\n cursor: grab;\n }\n p {\n font-size: 18px;\n }\n a {\n margin-top: 16px;\n display: block;\n cursor: grab;\n }\n }\n\n .suggestions-container {\n .section-header {\n margin-bottom: 8px !important;\n }\n .video,\n .article {\n .description {\n line-height: 1.2em;\n display: -webkit-box;\n -webkit-line-clamp: 2;\n -webkit-box-orient: vertical;\n overflow: hidden;\n text-overflow: ellipsis;\n margin: 8px 0;\n }\n &:hover {\n background: rgb(57, 172, 229, 0.1);\n }\n }\n }\n\n .suggestion[data-variant=\"video\"] {\n iframe {\n height: 146px;\n width: 248px;\n }\n }\n\n .search-container {\n display: flex;\n height: 42px;\n border-radius: 8px;\n padding-right: 5px;\n background-color: #F0F3F5;\n margin: 16px 0px 0px;\n input {\n border: none;\n background-color: #F0F3F5;\n font-size: 15px;\n color: #1D1D1F;\n padding-left: 0px ;\n &:focus {\n outline: none !important;\n box-shadow: none !important;\n }\n }\n button {\n box-shadow: none;\n padding-top: 3px;\n background-color: #F0F3F5;\n border: none;\n background: transparent;\n cursor: text;\n }\n }\n\n .attribute {\n display: flex;\n justify-content: flex-end;\n margin-top: 0px;\n padding-left: 2px;\n padding-right: 2px;\n color: #39415099;\n span {\n font-weight: 500;\n font-size: 12px;\n line-height: 14px;\n text-align: right;\n color: #394150;\n }\n }\n\n .algoliaResult {\n border-radius: 24px;\n display: flex;\n margin-bottom: 8px;\n padding: 12px 16px;\n box-shadow: 0 0 0 1px #DDDFE0;\n transition: box-shadow .2s ease;\n box-sizing: border-box;\n cursor: pointer;\n position: relative;\n justify-content: space-between;\n color: #394150;\n p {\n margin: 0 !important;\n }\n .svg {\n position: absolute;\n right: 16px;\n top: 50%;\n transform: translateY(-50%);\n transition: right .2s ease;\n }\n &:hover {\n box-shadow: 0 0 0 2px #3575d3;\n .svg {\n right: 14px;\n }\n }\n }\n\n .feedback-container {\n display: flex;\n justify-content: space-between;\n background-color: #F0F3F5;\n padding-left: 4%;\n padding-right: 4%;\n border-radius: 4px;\n margin-top: 6%;\n margin-bottom: 8%;\n button {\n border-radius: 20px;\n border-color: #B2BCC2;\n border-width: 1px;\n padding-top: 5%;\n padding-bottom: 5%;\n cursor: pointer;\n box-shadow: none;\n }\n .feedback-button {\n padding-left: 13px;\n padding-right: 13px;\n padding-bottom: 6px;\n padding-top: 6px;\n }\n .button-icon {\n height: 20px;\n width: 20px;\n margin-right: 4px;\n }\n .yes {\n border-bottom-right-radius: 0px;\n border-top-right-radius: 0px;\n border-right-width: 0px;\n }\n .no {\n border-bottom-left-radius: 0px;\n border-top-left-radius: 0px;\n }\n .selected-yes {\n background: linear-gradient(0deg, #E6FFF4, #E6FFF4), #FFFFFF;\n padding-bottom: 4.4px;\n padding-top: 5.8px;\n }\n .selected-no {\n background-color: #FFDCDC;\n padding-bottom: 4.4px;\n padding-top: 5.8px;\n }\n .icon {\n margin-top: 8px;\n cursor: pointer\n }\n }\n}\n\n.help-container {\n width: 350px;\n height: 100vh;\n overflow: auto;\n position: fixed;\n right: 0;\n background: white;\n display: block !important;\n border: 1px solid #DCDCDC;\n box-shadow: -5px 0px 36px rgba(0, 0, 0, 0.25);\n}\n\n.wpcontent-container {\n display: flex;\n // display: flex;\n // margin-right: 300px;\n}\n\n.toplevel_page_bluehost {\n @media screen and (min-width: 1814px) {\n .wpcontent-container {\n display: flex;\n\n #wpbody {\n flex: 1;\n #bwa-app {\n margin-left: 20px !important;\n #bluehost-logo-wrap {\n padding: 14px 0 0 12px;\n }\n }\n }\n }\n }\n}\n\nbody:is(.page, .post-php, .post-new-php) {\n #wp-admin-bar-help-center {\n display: none;\n }\n}\n\n.mobile {\n #wpadminbar {\n ul#wp-admin-bar-root-default {\n li {\n width: 40px !important;\n }\n }\n li#wp-admin-bar-help-center {\n display: block;\n }\n }\n}\n\n.icon-button {\n cursor: pointer; \n}\n"],"names":[],"sourceRoot":""} \ No newline at end of file diff --git a/build/index.js b/build/index.js index 77f2409..8550c0e 100644 --- a/build/index.js +++ b/build/index.js @@ -1 +1,13890 @@ -(()=>{var e={331:e=>{function t(){this._events=this._events||{},this._maxListeners=this._maxListeners||void 0}function r(e){return"function"==typeof e}function n(e){return"object"==typeof e&&null!==e}function i(e){return void 0===e}e.exports=t,t.prototype._events=void 0,t.prototype._maxListeners=void 0,t.defaultMaxListeners=10,t.prototype.setMaxListeners=function(e){if("number"!=typeof e||e<0||isNaN(e))throw TypeError("n must be a positive number");return this._maxListeners=e,this},t.prototype.emit=function(e){var t,a,c,s,o,u;if(this._events||(this._events={}),"error"===e&&(!this._events.error||n(this._events.error)&&!this._events.error.length)){if((t=arguments[1])instanceof Error)throw t;var l=new Error('Uncaught, unspecified "error" event. ('+t+")");throw l.context=t,l}if(i(a=this._events[e]))return!1;if(r(a))switch(arguments.length){case 1:a.call(this);break;case 2:a.call(this,arguments[1]);break;case 3:a.call(this,arguments[1],arguments[2]);break;default:s=Array.prototype.slice.call(arguments,1),a.apply(this,s)}else if(n(a))for(s=Array.prototype.slice.call(arguments,1),c=(u=a.slice()).length,o=0;o0&&this._events[e].length>c&&(this._events[e].warned=!0,console.error("(node) warning: possible EventEmitter memory leak detected. %d listeners added. Use emitter.setMaxListeners() to increase limit.",this._events[e].length),"function"==typeof console.trace&&console.trace()),this},t.prototype.on=t.prototype.addListener,t.prototype.once=function(e,t){if(!r(t))throw TypeError("listener must be a function");var n=!1;function i(){this.removeListener(e,i),n||(n=!0,t.apply(this,arguments))}return i.listener=t,this.on(e,i),this},t.prototype.removeListener=function(e,t){var i,a,c,s;if(!r(t))throw TypeError("listener must be a function");if(!this._events||!this._events[e])return this;if(c=(i=this._events[e]).length,a=-1,i===t||r(i.listener)&&i.listener===t)delete this._events[e],this._events.removeListener&&this.emit("removeListener",e,t);else if(n(i)){for(s=c;s-- >0;)if(i[s]===t||i[s].listener&&i[s].listener===t){a=s;break}if(a<0)return this;1===i.length?(i.length=0,delete this._events[e]):i.splice(a,1),this._events.removeListener&&this.emit("removeListener",e,t)}return this},t.prototype.removeAllListeners=function(e){var t,n;if(!this._events)return this;if(!this._events.removeListener)return 0===arguments.length?this._events={}:this._events[e]&&delete this._events[e],this;if(0===arguments.length){for(t in this._events)"removeListener"!==t&&this.removeAllListeners(t);return this.removeAllListeners("removeListener"),this._events={},this}if(r(n=this._events[e]))this.removeListener(e,n);else if(n)for(;n.length;)this.removeListener(e,n[n.length-1]);return delete this._events[e],this},t.prototype.listeners=function(e){return this._events&&this._events[e]?r(this._events[e])?[this._events[e]]:this._events[e].slice():[]},t.prototype.listenerCount=function(e){if(this._events){var t=this._events[e];if(r(t))return 1;if(t)return t.length}return 0},t.listenerCount=function(e,t){return e.listenerCount(t)}},131:(e,t,r)=>{"use strict";var n=r(374),i=r(775),a=r(76);function c(e,t,r){return new n(e,t,r)}c.version=r(336),c.AlgoliaSearchHelper=n,c.SearchParameters=i,c.SearchResults=a,e.exports=c},78:(e,t,r)=>{"use strict";var n=r(331);function i(e,t){this.main=e,this.fn=t,this.lastResults=null}r(853)(i,n),i.prototype.detach=function(){this.removeAllListeners(),this.main.detachDerivedHelper(this)},i.prototype.getModifiedState=function(e){return this.fn(e)},e.exports=i},437:(e,t,r)=>{"use strict";var n=r(344),i=r(803),a=r(116),c={addRefinement:function(e,t,r){if(c.isRefined(e,t,r))return e;var i=""+r,a=e[t]?e[t].concat(i):[i],s={};return s[t]=a,n({},s,e)},removeRefinement:function(e,t,r){if(void 0===r)return c.clearRefinement(e,(function(e,r){return t===r}));var n=""+r;return c.clearRefinement(e,(function(e,r){return t===r&&n===e}))},toggleRefinement:function(e,t,r){if(void 0===r)throw new Error("toggleRefinement should be used with a value");return c.isRefined(e,t,r)?c.removeRefinement(e,t,r):c.addRefinement(e,t,r)},clearRefinement:function(e,t,r){if(void 0===t)return a(e)?{}:e;if("string"==typeof t)return i(e,[t]);if("function"==typeof t){var n=!1,c=Object.keys(e).reduce((function(i,a){var c=e[a]||[],s=c.filter((function(e){return!t(e,a,r)}));return s.length!==c.length&&(n=!0),i[a]=s,i}),{});return n?c:e}},isRefined:function(e,t,r){var n=!!e[t]&&e[t].length>0;if(void 0===r||!n)return n;var i=""+r;return-1!==e[t].indexOf(i)}};e.exports=c},775:(e,t,r)=>{"use strict";var n=r(185),i=r(344),a=r(686),c=r(888),s=r(23),o=r(803),u=r(116),l=r(801),f=r(437);function h(e,t){return Array.isArray(e)&&Array.isArray(t)?e.length===t.length&&e.every((function(e,r){return h(t[r],e)})):e===t}function d(e){var t=e?d._parseNumbers(e):{};void 0===t.userToken||l(t.userToken)||console.warn("[algoliasearch-helper] The `userToken` parameter is invalid. This can lead to wrong analytics.\n - Format: [a-zA-Z0-9_-]{1,64}"),this.facets=t.facets||[],this.disjunctiveFacets=t.disjunctiveFacets||[],this.hierarchicalFacets=t.hierarchicalFacets||[],this.facetsRefinements=t.facetsRefinements||{},this.facetsExcludes=t.facetsExcludes||{},this.disjunctiveFacetsRefinements=t.disjunctiveFacetsRefinements||{},this.numericRefinements=t.numericRefinements||{},this.tagRefinements=t.tagRefinements||[],this.hierarchicalFacetsRefinements=t.hierarchicalFacetsRefinements||{};var r=this;Object.keys(t).forEach((function(e){var n=-1!==d.PARAMETERS.indexOf(e),i=void 0!==t[e];!n&&i&&(r[e]=t[e])}))}d.PARAMETERS=Object.keys(new d),d._parseNumbers=function(e){if(e instanceof d)return e;var t={};if(["aroundPrecision","aroundRadius","getRankingInfo","minWordSizefor2Typos","minWordSizefor1Typo","page","maxValuesPerFacet","distinct","minimumAroundRadius","hitsPerPage","minProximity"].forEach((function(r){var n=e[r];if("string"==typeof n){var i=parseFloat(n);t[r]=isNaN(i)?n:i}})),Array.isArray(e.insideBoundingBox)&&(t.insideBoundingBox=e.insideBoundingBox.map((function(e){return Array.isArray(e)?e.map((function(e){return parseFloat(e)})):e}))),e.numericRefinements){var r={};Object.keys(e.numericRefinements).forEach((function(t){var n=e.numericRefinements[t]||{};r[t]={},Object.keys(n).forEach((function(e){var i=n[e].map((function(e){return Array.isArray(e)?e.map((function(e){return"string"==typeof e?parseFloat(e):e})):"string"==typeof e?parseFloat(e):e}));r[t][e]=i}))})),t.numericRefinements=r}return n({},e,t)},d.make=function(e){var t=new d(e);return(e.hierarchicalFacets||[]).forEach((function(e){if(e.rootPath){var r=t.getHierarchicalRefinement(e.name);r.length>0&&0!==r[0].indexOf(e.rootPath)&&(t=t.clearRefinements(e.name)),0===(r=t.getHierarchicalRefinement(e.name)).length&&(t=t.toggleHierarchicalFacetRefinement(e.name,e.rootPath))}})),t},d.validate=function(e,t){var r=t||{};return e.tagFilters&&r.tagRefinements&&r.tagRefinements.length>0?new Error("[Tags] Cannot switch from the managed tag API to the advanced API. It is probably an error, if it is really what you want, you should first clear the tags with clearTags method."):e.tagRefinements.length>0&&r.tagFilters?new Error("[Tags] Cannot switch from the advanced tag API to the managed API. It is probably an error, if it is not, you should first clear the tags with clearTags method."):e.numericFilters&&r.numericRefinements&&u(r.numericRefinements)?new Error("[Numeric filters] Can't switch from the advanced to the managed API. It is probably an error, if this is really what you want, you have to first clear the numeric filters."):u(e.numericRefinements)&&r.numericFilters?new Error("[Numeric filters] Can't switch from the managed API to the advanced. It is probably an error, if this is really what you want, you have to first clear the numeric filters."):null},d.prototype={constructor:d,clearRefinements:function(e){var t={numericRefinements:this._clearNumericRefinements(e),facetsRefinements:f.clearRefinement(this.facetsRefinements,e,"conjunctiveFacet"),facetsExcludes:f.clearRefinement(this.facetsExcludes,e,"exclude"),disjunctiveFacetsRefinements:f.clearRefinement(this.disjunctiveFacetsRefinements,e,"disjunctiveFacet"),hierarchicalFacetsRefinements:f.clearRefinement(this.hierarchicalFacetsRefinements,e,"hierarchicalFacet")};return t.numericRefinements===this.numericRefinements&&t.facetsRefinements===this.facetsRefinements&&t.facetsExcludes===this.facetsExcludes&&t.disjunctiveFacetsRefinements===this.disjunctiveFacetsRefinements&&t.hierarchicalFacetsRefinements===this.hierarchicalFacetsRefinements?this:this.setQueryParameters(t)},clearTags:function(){return void 0===this.tagFilters&&0===this.tagRefinements.length?this:this.setQueryParameters({tagFilters:void 0,tagRefinements:[]})},setIndex:function(e){return e===this.index?this:this.setQueryParameters({index:e})},setQuery:function(e){return e===this.query?this:this.setQueryParameters({query:e})},setPage:function(e){return e===this.page?this:this.setQueryParameters({page:e})},setFacets:function(e){return this.setQueryParameters({facets:e})},setDisjunctiveFacets:function(e){return this.setQueryParameters({disjunctiveFacets:e})},setHitsPerPage:function(e){return this.hitsPerPage===e?this:this.setQueryParameters({hitsPerPage:e})},setTypoTolerance:function(e){return this.typoTolerance===e?this:this.setQueryParameters({typoTolerance:e})},addNumericRefinement:function(e,t,r){var i=s(r);if(this.isNumericRefined(e,t,i))return this;var a=n({},this.numericRefinements);return a[e]=n({},a[e]),a[e][t]?(a[e][t]=a[e][t].slice(),a[e][t].push(i)):a[e][t]=[i],this.setQueryParameters({numericRefinements:a})},getConjunctiveRefinements:function(e){return this.isConjunctiveFacet(e)&&this.facetsRefinements[e]||[]},getDisjunctiveRefinements:function(e){return this.isDisjunctiveFacet(e)&&this.disjunctiveFacetsRefinements[e]||[]},getHierarchicalRefinement:function(e){return this.hierarchicalFacetsRefinements[e]||[]},getExcludeRefinements:function(e){return this.isConjunctiveFacet(e)&&this.facetsExcludes[e]||[]},removeNumericRefinement:function(e,t,r){return void 0!==r?this.isNumericRefined(e,t,r)?this.setQueryParameters({numericRefinements:this._clearNumericRefinements((function(n,i){return i===e&&n.op===t&&h(n.val,s(r))}))}):this:void 0!==t?this.isNumericRefined(e,t)?this.setQueryParameters({numericRefinements:this._clearNumericRefinements((function(r,n){return n===e&&r.op===t}))}):this:this.isNumericRefined(e)?this.setQueryParameters({numericRefinements:this._clearNumericRefinements((function(t,r){return r===e}))}):this},getNumericRefinements:function(e){return this.numericRefinements[e]||{}},getNumericRefinement:function(e,t){return this.numericRefinements[e]&&this.numericRefinements[e][t]},_clearNumericRefinements:function(e){if(void 0===e)return u(this.numericRefinements)?{}:this.numericRefinements;if("string"==typeof e)return o(this.numericRefinements,[e]);if("function"==typeof e){var t=!1,r=this.numericRefinements,n=Object.keys(r).reduce((function(n,i){var a=r[i],c={};return a=a||{},Object.keys(a).forEach((function(r){var n=a[r]||[],s=[];n.forEach((function(t){e({val:t,op:r},i,"numeric")||s.push(t)})),s.length!==n.length&&(t=!0),c[r]=s})),n[i]=c,n}),{});return t?n:this.numericRefinements}},addFacet:function(e){return this.isConjunctiveFacet(e)?this:this.setQueryParameters({facets:this.facets.concat([e])})},addDisjunctiveFacet:function(e){return this.isDisjunctiveFacet(e)?this:this.setQueryParameters({disjunctiveFacets:this.disjunctiveFacets.concat([e])})},addHierarchicalFacet:function(e){if(this.isHierarchicalFacet(e.name))throw new Error("Cannot declare two hierarchical facets with the same name: `"+e.name+"`");return this.setQueryParameters({hierarchicalFacets:this.hierarchicalFacets.concat([e])})},addFacetRefinement:function(e,t){if(!this.isConjunctiveFacet(e))throw new Error(e+" is not defined in the facets attribute of the helper configuration");return f.isRefined(this.facetsRefinements,e,t)?this:this.setQueryParameters({facetsRefinements:f.addRefinement(this.facetsRefinements,e,t)})},addExcludeRefinement:function(e,t){if(!this.isConjunctiveFacet(e))throw new Error(e+" is not defined in the facets attribute of the helper configuration");return f.isRefined(this.facetsExcludes,e,t)?this:this.setQueryParameters({facetsExcludes:f.addRefinement(this.facetsExcludes,e,t)})},addDisjunctiveFacetRefinement:function(e,t){if(!this.isDisjunctiveFacet(e))throw new Error(e+" is not defined in the disjunctiveFacets attribute of the helper configuration");return f.isRefined(this.disjunctiveFacetsRefinements,e,t)?this:this.setQueryParameters({disjunctiveFacetsRefinements:f.addRefinement(this.disjunctiveFacetsRefinements,e,t)})},addTagRefinement:function(e){if(this.isTagRefined(e))return this;var t={tagRefinements:this.tagRefinements.concat(e)};return this.setQueryParameters(t)},removeFacet:function(e){return this.isConjunctiveFacet(e)?this.clearRefinements(e).setQueryParameters({facets:this.facets.filter((function(t){return t!==e}))}):this},removeDisjunctiveFacet:function(e){return this.isDisjunctiveFacet(e)?this.clearRefinements(e).setQueryParameters({disjunctiveFacets:this.disjunctiveFacets.filter((function(t){return t!==e}))}):this},removeHierarchicalFacet:function(e){return this.isHierarchicalFacet(e)?this.clearRefinements(e).setQueryParameters({hierarchicalFacets:this.hierarchicalFacets.filter((function(t){return t.name!==e}))}):this},removeFacetRefinement:function(e,t){if(!this.isConjunctiveFacet(e))throw new Error(e+" is not defined in the facets attribute of the helper configuration");return f.isRefined(this.facetsRefinements,e,t)?this.setQueryParameters({facetsRefinements:f.removeRefinement(this.facetsRefinements,e,t)}):this},removeExcludeRefinement:function(e,t){if(!this.isConjunctiveFacet(e))throw new Error(e+" is not defined in the facets attribute of the helper configuration");return f.isRefined(this.facetsExcludes,e,t)?this.setQueryParameters({facetsExcludes:f.removeRefinement(this.facetsExcludes,e,t)}):this},removeDisjunctiveFacetRefinement:function(e,t){if(!this.isDisjunctiveFacet(e))throw new Error(e+" is not defined in the disjunctiveFacets attribute of the helper configuration");return f.isRefined(this.disjunctiveFacetsRefinements,e,t)?this.setQueryParameters({disjunctiveFacetsRefinements:f.removeRefinement(this.disjunctiveFacetsRefinements,e,t)}):this},removeTagRefinement:function(e){if(!this.isTagRefined(e))return this;var t={tagRefinements:this.tagRefinements.filter((function(t){return t!==e}))};return this.setQueryParameters(t)},toggleRefinement:function(e,t){return this.toggleFacetRefinement(e,t)},toggleFacetRefinement:function(e,t){if(this.isHierarchicalFacet(e))return this.toggleHierarchicalFacetRefinement(e,t);if(this.isConjunctiveFacet(e))return this.toggleConjunctiveFacetRefinement(e,t);if(this.isDisjunctiveFacet(e))return this.toggleDisjunctiveFacetRefinement(e,t);throw new Error("Cannot refine the undeclared facet "+e+"; it should be added to the helper options facets, disjunctiveFacets or hierarchicalFacets")},toggleConjunctiveFacetRefinement:function(e,t){if(!this.isConjunctiveFacet(e))throw new Error(e+" is not defined in the facets attribute of the helper configuration");return this.setQueryParameters({facetsRefinements:f.toggleRefinement(this.facetsRefinements,e,t)})},toggleExcludeFacetRefinement:function(e,t){if(!this.isConjunctiveFacet(e))throw new Error(e+" is not defined in the facets attribute of the helper configuration");return this.setQueryParameters({facetsExcludes:f.toggleRefinement(this.facetsExcludes,e,t)})},toggleDisjunctiveFacetRefinement:function(e,t){if(!this.isDisjunctiveFacet(e))throw new Error(e+" is not defined in the disjunctiveFacets attribute of the helper configuration");return this.setQueryParameters({disjunctiveFacetsRefinements:f.toggleRefinement(this.disjunctiveFacetsRefinements,e,t)})},toggleHierarchicalFacetRefinement:function(e,t){if(!this.isHierarchicalFacet(e))throw new Error(e+" is not defined in the hierarchicalFacets attribute of the helper configuration");var r=this._getHierarchicalFacetSeparator(this.getHierarchicalFacetByName(e)),n={};return void 0!==this.hierarchicalFacetsRefinements[e]&&this.hierarchicalFacetsRefinements[e].length>0&&(this.hierarchicalFacetsRefinements[e][0]===t||0===this.hierarchicalFacetsRefinements[e][0].indexOf(t+r))?-1===t.indexOf(r)?n[e]=[]:n[e]=[t.slice(0,t.lastIndexOf(r))]:n[e]=[t],this.setQueryParameters({hierarchicalFacetsRefinements:i({},n,this.hierarchicalFacetsRefinements)})},addHierarchicalFacetRefinement:function(e,t){if(this.isHierarchicalFacetRefined(e))throw new Error(e+" is already refined.");if(!this.isHierarchicalFacet(e))throw new Error(e+" is not defined in the hierarchicalFacets attribute of the helper configuration.");var r={};return r[e]=[t],this.setQueryParameters({hierarchicalFacetsRefinements:i({},r,this.hierarchicalFacetsRefinements)})},removeHierarchicalFacetRefinement:function(e){if(!this.isHierarchicalFacetRefined(e))return this;var t={};return t[e]=[],this.setQueryParameters({hierarchicalFacetsRefinements:i({},t,this.hierarchicalFacetsRefinements)})},toggleTagRefinement:function(e){return this.isTagRefined(e)?this.removeTagRefinement(e):this.addTagRefinement(e)},isDisjunctiveFacet:function(e){return this.disjunctiveFacets.indexOf(e)>-1},isHierarchicalFacet:function(e){return void 0!==this.getHierarchicalFacetByName(e)},isConjunctiveFacet:function(e){return this.facets.indexOf(e)>-1},isFacetRefined:function(e,t){return!!this.isConjunctiveFacet(e)&&f.isRefined(this.facetsRefinements,e,t)},isExcludeRefined:function(e,t){return!!this.isConjunctiveFacet(e)&&f.isRefined(this.facetsExcludes,e,t)},isDisjunctiveFacetRefined:function(e,t){return!!this.isDisjunctiveFacet(e)&&f.isRefined(this.disjunctiveFacetsRefinements,e,t)},isHierarchicalFacetRefined:function(e,t){if(!this.isHierarchicalFacet(e))return!1;var r=this.getHierarchicalRefinement(e);return t?-1!==r.indexOf(t):r.length>0},isNumericRefined:function(e,t,r){if(void 0===r&&void 0===t)return!!this.numericRefinements[e];var n=this.numericRefinements[e]&&void 0!==this.numericRefinements[e][t];if(void 0===r||!n)return n;var i,a,o=s(r),u=void 0!==(i=this.numericRefinements[e][t],a=o,c(i,(function(e){return h(e,a)})));return n&&u},isTagRefined:function(e){return-1!==this.tagRefinements.indexOf(e)},getRefinedDisjunctiveFacets:function(){var e=this,t=a(Object.keys(this.numericRefinements).filter((function(t){return Object.keys(e.numericRefinements[t]).length>0})),this.disjunctiveFacets);return Object.keys(this.disjunctiveFacetsRefinements).filter((function(t){return e.disjunctiveFacetsRefinements[t].length>0})).concat(t).concat(this.getRefinedHierarchicalFacets())},getRefinedHierarchicalFacets:function(){var e=this;return a(this.hierarchicalFacets.map((function(e){return e.name})),Object.keys(this.hierarchicalFacetsRefinements).filter((function(t){return e.hierarchicalFacetsRefinements[t].length>0})))},getUnrefinedDisjunctiveFacets:function(){var e=this.getRefinedDisjunctiveFacets();return this.disjunctiveFacets.filter((function(t){return-1===e.indexOf(t)}))},managedParameters:["index","facets","disjunctiveFacets","facetsRefinements","hierarchicalFacets","facetsExcludes","disjunctiveFacetsRefinements","numericRefinements","tagRefinements","hierarchicalFacetsRefinements"],getQueryParams:function(){var e=this.managedParameters,t={},r=this;return Object.keys(this).forEach((function(n){var i=r[n];-1===e.indexOf(n)&&void 0!==i&&(t[n]=i)})),t},setQueryParameter:function(e,t){if(this[e]===t)return this;var r={};return r[e]=t,this.setQueryParameters(r)},setQueryParameters:function(e){if(!e)return this;var t=d.validate(this,e);if(t)throw t;var r=this,n=d._parseNumbers(e),i=Object.keys(this).reduce((function(e,t){return e[t]=r[t],e}),{}),a=Object.keys(n).reduce((function(e,t){var r=void 0!==e[t],i=void 0!==n[t];return r&&!i?o(e,[t]):(i&&(e[t]=n[t]),e)}),i);return new this.constructor(a)},resetPage:function(){return void 0===this.page?this:this.setPage(0)},_getHierarchicalFacetSortBy:function(e){return e.sortBy||["isRefined:desc","name:asc"]},_getHierarchicalFacetSeparator:function(e){return e.separator||" > "},_getHierarchicalRootPath:function(e){return e.rootPath||null},_getHierarchicalShowParentLevel:function(e){return"boolean"!=typeof e.showParentLevel||e.showParentLevel},getHierarchicalFacetByName:function(e){return c(this.hierarchicalFacets,(function(t){return t.name===e}))},getHierarchicalFacetBreadcrumb:function(e){if(!this.isHierarchicalFacet(e))return[];var t=this.getHierarchicalRefinement(e)[0];if(!t)return[];var r=this._getHierarchicalFacetSeparator(this.getHierarchicalFacetByName(e));return t.split(r).map((function(e){return e.trim()}))},toString:function(){return JSON.stringify(this,null,2)}},e.exports=d},210:(e,t,r)=>{"use strict";e.exports=function(e){return function(t,r){var c=e.hierarchicalFacets[r],u=e.hierarchicalFacetsRefinements[c.name]&&e.hierarchicalFacetsRefinements[c.name][0]||"",l=e._getHierarchicalFacetSeparator(c),f=e._getHierarchicalRootPath(c),h=e._getHierarchicalShowParentLevel(c),d=a(e._getHierarchicalFacetSortBy(c)),p=t.every((function(e){return e.exhaustive})),m=function(e,t,r,a,c){return function(u,l,f){var h=u;if(f>0){var d=0;for(h=u;d{"use strict";var n=r(185),i=r(344),a=r(148),c=r(587),s=r(888),o=r(725),u=r(293),l=r(39),f=l.escapeFacetValue,h=l.unescapeFacetValue,d=r(210);function p(e){var t={};return e.forEach((function(e,r){t[e]=r})),t}function m(e,t,r){t&&t[r]&&(e.stats=t[r])}function g(e,t,r){var a=t[0];this._rawResults=t;var u=this;Object.keys(a).forEach((function(e){u[e]=a[e]})),Object.keys(r||{}).forEach((function(e){u[e]=r[e]})),this.processingTimeMS=t.reduce((function(e,t){return void 0===t.processingTimeMS?e:e+t.processingTimeMS}),0),this.disjunctiveFacets=[],this.hierarchicalFacets=e.hierarchicalFacets.map((function(){return[]})),this.facets=[];var l=e.getRefinedDisjunctiveFacets(),f=p(e.facets),g=p(e.disjunctiveFacets),y=1,A=a.facets||{};Object.keys(A).forEach((function(t){var r,n,i=A[t],c=(r=e.hierarchicalFacets,n=t,s(r,(function(e){return(e.attributes||[]).indexOf(n)>-1})));if(c){var l=c.attributes.indexOf(t),h=o(e.hierarchicalFacets,(function(e){return e.name===c.name}));u.hierarchicalFacets[h][l]={attribute:t,data:i,exhaustive:a.exhaustiveFacetsCount}}else{var d,p=-1!==e.disjunctiveFacets.indexOf(t),y=-1!==e.facets.indexOf(t);p&&(d=g[t],u.disjunctiveFacets[d]={name:t,data:i,exhaustive:a.exhaustiveFacetsCount},m(u.disjunctiveFacets[d],a.facets_stats,t)),y&&(d=f[t],u.facets[d]={name:t,data:i,exhaustive:a.exhaustiveFacetsCount},m(u.facets[d],a.facets_stats,t))}})),this.hierarchicalFacets=c(this.hierarchicalFacets),l.forEach((function(r){var c=t[y],s=c&&c.facets?c.facets:{},l=e.getHierarchicalFacetByName(r);Object.keys(s).forEach((function(t){var r,f=s[t];if(l){r=o(e.hierarchicalFacets,(function(e){return e.name===l.name}));var d=o(u.hierarchicalFacets[r],(function(e){return e.attribute===t}));if(-1===d)return;u.hierarchicalFacets[r][d].data=n({},u.hierarchicalFacets[r][d].data,f)}else{r=g[t];var p=a.facets&&a.facets[t]||{};u.disjunctiveFacets[r]={name:t,data:i({},f,p),exhaustive:c.exhaustiveFacetsCount},m(u.disjunctiveFacets[r],c.facets_stats,t),e.disjunctiveFacetsRefinements[t]&&e.disjunctiveFacetsRefinements[t].forEach((function(n){!u.disjunctiveFacets[r].data[n]&&e.disjunctiveFacetsRefinements[t].indexOf(h(n))>-1&&(u.disjunctiveFacets[r].data[n]=0)}))}})),y++})),e.getRefinedHierarchicalFacets().forEach((function(r){var n=e.getHierarchicalFacetByName(r),a=e._getHierarchicalFacetSeparator(n),c=e.getHierarchicalRefinement(r);0===c.length||c[0].split(a).length<2||t.slice(y).forEach((function(t){var r=t&&t.facets?t.facets:{};Object.keys(r).forEach((function(t){var s=r[t],l=o(e.hierarchicalFacets,(function(e){return e.name===n.name})),f=o(u.hierarchicalFacets[l],(function(e){return e.attribute===t}));if(-1!==f){var h={};if(c.length>0){var d=c[0].split(a)[0];h[d]=u.hierarchicalFacets[l][f].data[d]}u.hierarchicalFacets[l][f].data=i(h,s,u.hierarchicalFacets[l][f].data)}})),y++}))})),Object.keys(e.facetsExcludes).forEach((function(t){var r=e.facetsExcludes[t],n=f[t];u.facets[n]={name:t,data:a.facets[t],exhaustive:a.exhaustiveFacetsCount},r.forEach((function(e){u.facets[n]=u.facets[n]||{name:t},u.facets[n].data=u.facets[n].data||{},u.facets[n].data[e]=0}))})),this.hierarchicalFacets=this.hierarchicalFacets.map(d(e)),this.facets=c(this.facets),this.disjunctiveFacets=c(this.disjunctiveFacets),this._state=e}function y(e,t){function r(e){return e.name===t}if(e._state.isConjunctiveFacet(t)){var n=s(e.facets,r);return n?Object.keys(n.data).map((function(r){var i=f(r);return{name:r,escapedValue:i,count:n.data[r],isRefined:e._state.isFacetRefined(t,i),isExcluded:e._state.isExcludeRefined(t,r)}})):[]}if(e._state.isDisjunctiveFacet(t)){var i=s(e.disjunctiveFacets,r);return i?Object.keys(i.data).map((function(r){var n=f(r);return{name:r,escapedValue:n,count:i.data[r],isRefined:e._state.isDisjunctiveFacetRefined(t,n)}})):[]}if(e._state.isHierarchicalFacet(t)){var a=s(e.hierarchicalFacets,r);if(!a)return a;var c=e._state.getHierarchicalFacetByName(t),o=h(e._state.getHierarchicalRefinement(t)[0]||"").split(e._state._getHierarchicalFacetSeparator(c));return o.unshift(t),A(a,o,0),a}}function A(e,t,r){e.isRefined=e.name===t[r],e.data&&e.data.forEach((function(e){A(e,t,r+1)}))}function b(e,t,r,n){if(n=n||0,Array.isArray(t))return e(t,r[n]);if(!t.data||0===t.data.length)return t;var a=t.data.map((function(t){return b(e,t,r,n+1)})),c=e(a,r[n]);return i({data:c},t)}function v(e,t){var r=s(e,(function(e){return e.name===t}));return r&&r.stats}function I(e,t,r,n,i){var a=s(i,(function(e){return e.name===r})),c=a&&a.data&&a.data[n]?a.data[n]:0,o=a&&a.exhaustive||!1;return{type:t,attributeName:r,name:n,count:c,exhaustive:o}}g.prototype.getFacetByName=function(e){function t(t){return t.name===e}return s(this.facets,t)||s(this.disjunctiveFacets,t)||s(this.hierarchicalFacets,t)},g.DEFAULT_SORT=["isRefined:desc","count:desc","name:asc"],g.prototype.getFacetValues=function(e,t){var r=y(this,e);if(r){var n=i({},t,{sortBy:g.DEFAULT_SORT,facetOrdering:!(t&&t.sortBy)}),c=this;return b((function(e,t){if(n.facetOrdering){var r=function(e,t){return e.renderingContent&&e.renderingContent.facetOrdering&&e.renderingContent.facetOrdering.values&&e.renderingContent.facetOrdering.values[t]}(c,t);if(Boolean(r))return function(e,t){var r=[],n=[],i=(t.order||[]).reduce((function(e,t,r){return e[t]=r,e}),{});e.forEach((function(e){var t=e.path||e.name;void 0!==i[t]?r[i[t]]=e:n.push(e)})),r=r.filter((function(e){return e}));var c,s=t.sortRemainingBy;return"hidden"===s?r:(c="alpha"===s?[["path","name"],["asc","asc"]]:[["count"],["desc"]],r.concat(a(n,c[0],c[1])))}(e,r)}if(Array.isArray(n.sortBy)){var i=u(n.sortBy,g.DEFAULT_SORT);return a(e,i[0],i[1])}if("function"==typeof n.sortBy)return function(e,t){return t.sort(e)}(n.sortBy,e);throw new Error("options.sortBy is optional but if defined it must be either an array of string (predicates) or a sorting function")}),r,Array.isArray(r)?[e]:c._state.getHierarchicalFacetByName(r.name).attributes)}},g.prototype.getFacetStats=function(e){return this._state.isConjunctiveFacet(e)?v(this.facets,e):this._state.isDisjunctiveFacet(e)?v(this.disjunctiveFacets,e):void 0},g.prototype.getRefinements=function(){var e=this._state,t=this,r=[];return Object.keys(e.facetsRefinements).forEach((function(n){e.facetsRefinements[n].forEach((function(e){r.push(I(0,"facet",n,e,t.facets))}))})),Object.keys(e.facetsExcludes).forEach((function(n){e.facetsExcludes[n].forEach((function(e){r.push(I(0,"exclude",n,e,t.facets))}))})),Object.keys(e.disjunctiveFacetsRefinements).forEach((function(n){e.disjunctiveFacetsRefinements[n].forEach((function(e){r.push(I(0,"disjunctive",n,e,t.disjunctiveFacets))}))})),Object.keys(e.hierarchicalFacetsRefinements).forEach((function(n){e.hierarchicalFacetsRefinements[n].forEach((function(i){r.push(function(e,t,r,n){var i=e.getHierarchicalFacetByName(t),a=e._getHierarchicalFacetSeparator(i),c=r.split(a),o=s(n,(function(e){return e.name===t})),u=c.reduce((function(e,t){var r=e&&s(e.data,(function(e){return e.name===t}));return void 0!==r?r:e}),o),l=u&&u.count||0,f=u&&u.exhaustive||!1,h=u&&u.path||"";return{type:"hierarchical",attributeName:t,name:h,count:l,exhaustive:f}}(e,n,i,t.hierarchicalFacets))}))})),Object.keys(e.numericRefinements).forEach((function(t){var n=e.numericRefinements[t];Object.keys(n).forEach((function(e){n[e].forEach((function(n){r.push({type:"numeric",attributeName:t,name:n,numericValue:n,operator:e})}))}))})),e.tagRefinements.forEach((function(e){r.push({type:"tag",attributeName:"_tags",name:e})})),r},e.exports=g},374:(e,t,r)=>{"use strict";var n=r(775),i=r(76),a=r(78),c=r(394),s=r(331),o=r(853),u=r(116),l=r(803),f=r(185),h=r(336),d=r(39).escapeFacetValue;function p(e,t,r){"function"==typeof e.addAlgoliaAgent&&e.addAlgoliaAgent("JS Helper ("+h+")"),this.setClient(e);var i=r||{};i.index=t,this.state=n.make(i),this.lastResults=null,this._queryId=0,this._lastQueryIdReceived=-1,this.derivedHelpers=[],this._currentNbQueries=0}function m(e){if(e<0)throw new Error("Page requested below 0.");return this._change({state:this.state.setPage(e),isPageReset:!1}),this}function g(){return this.state.page}o(p,s),p.prototype.search=function(){return this._search({onlyWithDerivedHelpers:!1}),this},p.prototype.searchOnlyWithDerivedHelpers=function(){return this._search({onlyWithDerivedHelpers:!0}),this},p.prototype.getQuery=function(){var e=this.state;return c._getHitsSearchParams(e)},p.prototype.searchOnce=function(e,t){var r=e?this.state.setQueryParameters(e):this.state,n=c._getQueries(r.index,r),a=this;if(this._currentNbQueries++,this.emit("searchOnce",{state:r}),!t)return this.client.search(n).then((function(e){return a._currentNbQueries--,0===a._currentNbQueries&&a.emit("searchQueueEmpty"),{content:new i(r,e.results),state:r,_originalResponse:e}}),(function(e){throw a._currentNbQueries--,0===a._currentNbQueries&&a.emit("searchQueueEmpty"),e}));this.client.search(n).then((function(e){a._currentNbQueries--,0===a._currentNbQueries&&a.emit("searchQueueEmpty"),t(null,new i(r,e.results),r)})).catch((function(e){a._currentNbQueries--,0===a._currentNbQueries&&a.emit("searchQueueEmpty"),t(e,null,r)}))},p.prototype.findAnswers=function(e){console.warn("[algoliasearch-helper] answers is no longer supported");var t=this.state,r=this.derivedHelpers[0];if(!r)return Promise.resolve([]);var n=r.getModifiedState(t),i=f({attributesForPrediction:e.attributesForPrediction,nbHits:e.nbHits},{params:l(c._getHitsSearchParams(n),["attributesToSnippet","hitsPerPage","restrictSearchableAttributes","snippetEllipsisText"])}),a="search for answers was called, but this client does not have a function client.initIndex(index).findAnswers";if("function"!=typeof this.client.initIndex)throw new Error(a);var s=this.client.initIndex(n.index);if("function"!=typeof s.findAnswers)throw new Error(a);return s.findAnswers(n.query,e.queryLanguages,i)},p.prototype.searchForFacetValues=function(e,t,r,n){var i="function"==typeof this.client.searchForFacetValues,a="function"==typeof this.client.initIndex;if(!i&&!a&&"function"!=typeof this.client.search)throw new Error("search for facet values (searchable) was called, but this client does not have a function client.searchForFacetValues or client.initIndex(index).searchForFacetValues");var s=this.state.setQueryParameters(n||{}),o=s.isDisjunctiveFacet(e),u=c.getSearchForFacetQuery(e,t,r,s);this._currentNbQueries++;var l,f=this;return i?l=this.client.searchForFacetValues([{indexName:s.index,params:u}]):a?l=this.client.initIndex(s.index).searchForFacetValues(u):(delete u.facetName,l=this.client.search([{type:"facet",facet:e,indexName:s.index,params:u}]).then((function(e){return e.results[0]}))),this.emit("searchForFacetValues",{state:s,facet:e,query:t}),l.then((function(t){return f._currentNbQueries--,0===f._currentNbQueries&&f.emit("searchQueueEmpty"),(t=Array.isArray(t)?t[0]:t).facetHits.forEach((function(t){t.escapedValue=d(t.value),t.isRefined=o?s.isDisjunctiveFacetRefined(e,t.escapedValue):s.isFacetRefined(e,t.escapedValue)})),t}),(function(e){throw f._currentNbQueries--,0===f._currentNbQueries&&f.emit("searchQueueEmpty"),e}))},p.prototype.setQuery=function(e){return this._change({state:this.state.resetPage().setQuery(e),isPageReset:!0}),this},p.prototype.clearRefinements=function(e){return this._change({state:this.state.resetPage().clearRefinements(e),isPageReset:!0}),this},p.prototype.clearTags=function(){return this._change({state:this.state.resetPage().clearTags(),isPageReset:!0}),this},p.prototype.addDisjunctiveFacetRefinement=function(e,t){return this._change({state:this.state.resetPage().addDisjunctiveFacetRefinement(e,t),isPageReset:!0}),this},p.prototype.addDisjunctiveRefine=function(){return this.addDisjunctiveFacetRefinement.apply(this,arguments)},p.prototype.addHierarchicalFacetRefinement=function(e,t){return this._change({state:this.state.resetPage().addHierarchicalFacetRefinement(e,t),isPageReset:!0}),this},p.prototype.addNumericRefinement=function(e,t,r){return this._change({state:this.state.resetPage().addNumericRefinement(e,t,r),isPageReset:!0}),this},p.prototype.addFacetRefinement=function(e,t){return this._change({state:this.state.resetPage().addFacetRefinement(e,t),isPageReset:!0}),this},p.prototype.addRefine=function(){return this.addFacetRefinement.apply(this,arguments)},p.prototype.addFacetExclusion=function(e,t){return this._change({state:this.state.resetPage().addExcludeRefinement(e,t),isPageReset:!0}),this},p.prototype.addExclude=function(){return this.addFacetExclusion.apply(this,arguments)},p.prototype.addTag=function(e){return this._change({state:this.state.resetPage().addTagRefinement(e),isPageReset:!0}),this},p.prototype.removeNumericRefinement=function(e,t,r){return this._change({state:this.state.resetPage().removeNumericRefinement(e,t,r),isPageReset:!0}),this},p.prototype.removeDisjunctiveFacetRefinement=function(e,t){return this._change({state:this.state.resetPage().removeDisjunctiveFacetRefinement(e,t),isPageReset:!0}),this},p.prototype.removeDisjunctiveRefine=function(){return this.removeDisjunctiveFacetRefinement.apply(this,arguments)},p.prototype.removeHierarchicalFacetRefinement=function(e){return this._change({state:this.state.resetPage().removeHierarchicalFacetRefinement(e),isPageReset:!0}),this},p.prototype.removeFacetRefinement=function(e,t){return this._change({state:this.state.resetPage().removeFacetRefinement(e,t),isPageReset:!0}),this},p.prototype.removeRefine=function(){return this.removeFacetRefinement.apply(this,arguments)},p.prototype.removeFacetExclusion=function(e,t){return this._change({state:this.state.resetPage().removeExcludeRefinement(e,t),isPageReset:!0}),this},p.prototype.removeExclude=function(){return this.removeFacetExclusion.apply(this,arguments)},p.prototype.removeTag=function(e){return this._change({state:this.state.resetPage().removeTagRefinement(e),isPageReset:!0}),this},p.prototype.toggleFacetExclusion=function(e,t){return this._change({state:this.state.resetPage().toggleExcludeFacetRefinement(e,t),isPageReset:!0}),this},p.prototype.toggleExclude=function(){return this.toggleFacetExclusion.apply(this,arguments)},p.prototype.toggleRefinement=function(e,t){return this.toggleFacetRefinement(e,t)},p.prototype.toggleFacetRefinement=function(e,t){return this._change({state:this.state.resetPage().toggleFacetRefinement(e,t),isPageReset:!0}),this},p.prototype.toggleRefine=function(){return this.toggleFacetRefinement.apply(this,arguments)},p.prototype.toggleTag=function(e){return this._change({state:this.state.resetPage().toggleTagRefinement(e),isPageReset:!0}),this},p.prototype.nextPage=function(){var e=this.state.page||0;return this.setPage(e+1)},p.prototype.previousPage=function(){var e=this.state.page||0;return this.setPage(e-1)},p.prototype.setCurrentPage=m,p.prototype.setPage=m,p.prototype.setIndex=function(e){return this._change({state:this.state.resetPage().setIndex(e),isPageReset:!0}),this},p.prototype.setQueryParameter=function(e,t){return this._change({state:this.state.resetPage().setQueryParameter(e,t),isPageReset:!0}),this},p.prototype.setState=function(e){return this._change({state:n.make(e),isPageReset:!1}),this},p.prototype.overrideStateWithoutTriggeringChangeEvent=function(e){return this.state=new n(e),this},p.prototype.hasRefinements=function(e){return!!u(this.state.getNumericRefinements(e))||(this.state.isConjunctiveFacet(e)?this.state.isFacetRefined(e):this.state.isDisjunctiveFacet(e)?this.state.isDisjunctiveFacetRefined(e):!!this.state.isHierarchicalFacet(e)&&this.state.isHierarchicalFacetRefined(e))},p.prototype.isExcluded=function(e,t){return this.state.isExcludeRefined(e,t)},p.prototype.isDisjunctiveRefined=function(e,t){return this.state.isDisjunctiveFacetRefined(e,t)},p.prototype.hasTag=function(e){return this.state.isTagRefined(e)},p.prototype.isTagRefined=function(){return this.hasTagRefinements.apply(this,arguments)},p.prototype.getIndex=function(){return this.state.index},p.prototype.getCurrentPage=g,p.prototype.getPage=g,p.prototype.getTags=function(){return this.state.tagRefinements},p.prototype.getRefinements=function(e){var t=[];this.state.isConjunctiveFacet(e)?(this.state.getConjunctiveRefinements(e).forEach((function(e){t.push({value:e,type:"conjunctive"})})),this.state.getExcludeRefinements(e).forEach((function(e){t.push({value:e,type:"exclude"})}))):this.state.isDisjunctiveFacet(e)&&this.state.getDisjunctiveRefinements(e).forEach((function(e){t.push({value:e,type:"disjunctive"})}));var r=this.state.getNumericRefinements(e);return Object.keys(r).forEach((function(e){var n=r[e];t.push({value:n,operator:e,type:"numeric"})})),t},p.prototype.getNumericRefinement=function(e,t){return this.state.getNumericRefinement(e,t)},p.prototype.getHierarchicalFacetBreadcrumb=function(e){return this.state.getHierarchicalFacetBreadcrumb(e)},p.prototype._search=function(e){var t=this.state,r=[],n=[];e.onlyWithDerivedHelpers||(n=c._getQueries(t.index,t),r.push({state:t,queriesCount:n.length,helper:this}),this.emit("search",{state:t,results:this.lastResults}));var i=this.derivedHelpers.map((function(e){var n=e.getModifiedState(t),i=c._getQueries(n.index,n);return r.push({state:n,queriesCount:i.length,helper:e}),e.emit("search",{state:n,results:e.lastResults}),i})),a=Array.prototype.concat.apply(n,i),s=this._queryId++;this._currentNbQueries++;try{this.client.search(a).then(this._dispatchAlgoliaResponse.bind(this,r,s)).catch(this._dispatchAlgoliaError.bind(this,s))}catch(e){this.emit("error",{error:e})}},p.prototype._dispatchAlgoliaResponse=function(e,t,r){if(!(t0},p.prototype._change=function(e){var t=e.state,r=e.isPageReset;t!==this.state&&(this.state=t,this.emit("change",{state:this.state,results:this.lastResults,isPageReset:r}))},p.prototype.clearCache=function(){return this.client.clearCache&&this.client.clearCache(),this},p.prototype.setClient=function(e){return this.client===e||("function"==typeof e.addAlgoliaAgent&&e.addAlgoliaAgent("JS Helper ("+h+")"),this.client=e),this},p.prototype.getClient=function(){return this.client},p.prototype.derive=function(e){var t=new a(this,e);return this.derivedHelpers.push(t),t},p.prototype.detachDerivedHelper=function(e){var t=this.derivedHelpers.indexOf(e);if(-1===t)throw new Error("Derived helper already detached");this.derivedHelpers.splice(t,1)},p.prototype.hasPendingRequests=function(){return this._currentNbQueries>0},e.exports=p},587:e=>{"use strict";e.exports=function(e){return Array.isArray(e)?e.filter(Boolean):[]}},344:e=>{"use strict";e.exports=function(){var e=Array.prototype.slice.call(arguments);return e.reduceRight((function(e,t){return Object.keys(Object(t)).forEach((function(r){void 0!==t[r]&&(void 0!==e[r]&&delete e[r],e[r]=t[r])})),e}),{})}},39:e=>{"use strict";e.exports={escapeFacetValue:function(e){return"string"!=typeof e?e:String(e).replace(/^-/,"\\-")},unescapeFacetValue:function(e){return"string"!=typeof e?e:e.replace(/^\\-/,"-")}}},888:e=>{"use strict";e.exports=function(e,t){if(Array.isArray(e))for(var r=0;r{"use strict";e.exports=function(e,t){if(!Array.isArray(e))return-1;for(var r=0;r{"use strict";var n=r(888);e.exports=function(e,t){var r=(t||[]).map((function(e){return e.split(":")}));return e.reduce((function(e,t){var i=t.split(":"),a=n(r,(function(e){return e[0]===i[0]}));return i.length>1||!a?(e[0].push(i[0]),e[1].push(i[1]),e):(e[0].push(a[0]),e[1].push(a[1]),e)}),[[],[]])}},853:e=>{"use strict";e.exports=function(e,t){e.prototype=Object.create(t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}})}},686:e=>{"use strict";e.exports=function(e,t){return e.filter((function(r,n){return t.indexOf(r)>-1&&e.indexOf(r)===n}))}},185:e=>{"use strict";function t(e){return"function"==typeof e||Array.isArray(e)||"[object Object]"===Object.prototype.toString.call(e)}function r(e,n){if(e===n)return e;for(var i in n)if(Object.prototype.hasOwnProperty.call(n,i)&&"__proto__"!==i&&"constructor"!==i){var a=n[i],c=e[i];void 0!==c&&void 0===a||(t(c)&&t(a)?e[i]=r(c,a):e[i]="object"==typeof(s=a)&&null!==s?r(Array.isArray(s)?[]:{},s):s)}var s;return e}e.exports=function(e){t(e)||(e={});for(var n=1,i=arguments.length;n{"use strict";e.exports=function(e){return e&&Object.keys(e).length>0}},803:e=>{"use strict";e.exports=function(e,t){if(null===e)return{};var r,n,i={},a=Object.keys(e);for(n=0;n=0||(i[r]=e[r]);return i}},148:e=>{"use strict";function t(e,t){if(e!==t){var r=void 0!==e,n=null===e,i=void 0!==t,a=null===t;if(!a&&e>t||n&&i||!r)return 1;if(!n&&e=n.length?a:"desc"===n[i]?-a:a}return e.index-r.index})),i.map((function(e){return e.value}))}},23:e=>{"use strict";e.exports=function e(t){if("number"==typeof t)return t;if("string"==typeof t)return parseFloat(t);if(Array.isArray(t))return t.map(e);throw new Error("The value should be a number, a parsable string or an array of those.")}},394:(e,t,r)=>{"use strict";var n=r(185);function i(e){return Object.keys(e).sort((function(e,t){return e.localeCompare(t)})).reduce((function(t,r){return t[r]=e[r],t}),{})}var a={_getQueries:function(e,t){var r=[];return r.push({indexName:e,params:a._getHitsSearchParams(t)}),t.getRefinedDisjunctiveFacets().forEach((function(n){r.push({indexName:e,params:a._getDisjunctiveFacetSearchParams(t,n)})})),t.getRefinedHierarchicalFacets().forEach((function(n){var i=t.getHierarchicalFacetByName(n),c=t.getHierarchicalRefinement(n),s=t._getHierarchicalFacetSeparator(i);if(c.length>0&&c[0].split(s).length>1){var o=c[0].split(s).slice(0,-1).reduce((function(e,t,r){return e.concat({attribute:i.attributes[r],value:0===r?t:[e[e.length-1].value,t].join(s)})}),[]);o.forEach((function(n,c){var s=a._getDisjunctiveFacetSearchParams(t,n.attribute,0===c);function u(e){return i.attributes.some((function(t){return t===e.split(":")[0]}))}var l=(s.facetFilters||[]).reduce((function(e,t){if(Array.isArray(t)){var r=t.filter((function(e){return!u(e)}));r.length>0&&e.push(r)}return"string"!=typeof t||u(t)||e.push(t),e}),[]),f=o[c-1];s.facetFilters=c>0?l.concat(f.attribute+":"+f.value):l.length>0?l:void 0,r.push({indexName:e,params:s})}))}})),r},_getHitsSearchParams:function(e){var t=e.facets.concat(e.disjunctiveFacets).concat(a._getHitsHierarchicalFacetsAttributes(e)),r=a._getFacetFilters(e),c=a._getNumericFilters(e),s=a._getTagFilters(e),o={facets:t.indexOf("*")>-1?["*"]:t,tagFilters:s};return r.length>0&&(o.facetFilters=r),c.length>0&&(o.numericFilters=c),i(n({},e.getQueryParams(),o))},_getDisjunctiveFacetSearchParams:function(e,t,r){var c=a._getFacetFilters(e,t,r),s=a._getNumericFilters(e,t),o=a._getTagFilters(e),u={hitsPerPage:0,page:0,analytics:!1,clickAnalytics:!1};o.length>0&&(u.tagFilters=o);var l=e.getHierarchicalFacetByName(t);return u.facets=l?a._getDisjunctiveHierarchicalFacetAttribute(e,l,r):t,s.length>0&&(u.numericFilters=s),c.length>0&&(u.facetFilters=c),i(n({},e.getQueryParams(),u))},_getNumericFilters:function(e,t){if(e.numericFilters)return e.numericFilters;var r=[];return Object.keys(e.numericRefinements).forEach((function(n){var i=e.numericRefinements[n]||{};Object.keys(i).forEach((function(e){var a=i[e]||[];t!==n&&a.forEach((function(t){if(Array.isArray(t)){var i=t.map((function(t){return n+e+t}));r.push(i)}else r.push(n+e+t)}))}))})),r},_getTagFilters:function(e){return e.tagFilters?e.tagFilters:e.tagRefinements.join(",")},_getFacetFilters:function(e,t,r){var n=[],i=e.facetsRefinements||{};Object.keys(i).forEach((function(e){(i[e]||[]).forEach((function(t){n.push(e+":"+t)}))}));var a=e.facetsExcludes||{};Object.keys(a).forEach((function(e){(a[e]||[]).forEach((function(t){n.push(e+":-"+t)}))}));var c=e.disjunctiveFacetsRefinements||{};Object.keys(c).forEach((function(e){var r=c[e]||[];if(e!==t&&r&&0!==r.length){var i=[];r.forEach((function(t){i.push(e+":"+t)})),n.push(i)}}));var s=e.hierarchicalFacetsRefinements||{};return Object.keys(s).forEach((function(i){var a=(s[i]||[])[0];if(void 0!==a){var c,o,u=e.getHierarchicalFacetByName(i),l=e._getHierarchicalFacetSeparator(u),f=e._getHierarchicalRootPath(u);if(t===i){if(-1===a.indexOf(l)||!f&&!0===r||f&&f.split(l).length===a.split(l).length)return;f?(o=f.split(l).length-1,a=f):(o=a.split(l).length-2,a=a.slice(0,a.lastIndexOf(l))),c=u.attributes[o]}else o=a.split(l).length-1,c=u.attributes[o];c&&n.push([c+":"+a])}})),n},_getHitsHierarchicalFacetsAttributes:function(e){return e.hierarchicalFacets.reduce((function(t,r){var n=e.getHierarchicalRefinement(r.name)[0];if(!n)return t.push(r.attributes[0]),t;var i=e._getHierarchicalFacetSeparator(r),a=n.split(i).length,c=r.attributes.slice(0,a+1);return t.concat(c)}),[])},_getDisjunctiveHierarchicalFacetAttribute:function(e,t,r){var n=e._getHierarchicalFacetSeparator(t);if(!0===r){var i=e._getHierarchicalRootPath(t),a=0;return i&&(a=i.split(n).length),[t.attributes[a]]}var c=(e.getHierarchicalRefinement(t.name)[0]||"").split(n).length-1;return t.attributes.slice(0,c+1)},getSearchForFacetQuery:function(e,t,r,c){var s=c.isDisjunctiveFacet(e)?c.clearRefinements(e):c,o={facetQuery:t,facetName:e};return"number"==typeof r&&(o.maxFacetHits=r),i(n({},a._getHitsSearchParams(s),o))}};e.exports=a},801:e=>{"use strict";e.exports=function(e){return null!==e&&/^[a-zA-Z0-9_-]{1,64}$/.test(e)}},336:e=>{"use strict";e.exports="3.12.0"},955:function(e){e.exports=function(){"use strict";function e(e,t,r){return t in e?Object.defineProperty(e,t,{value:r,enumerable:!0,configurable:!0,writable:!0}):e[t]=r,e}function t(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function r(r){for(var n=1;n=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}function i(e,t){return function(e){if(Array.isArray(e))return e}(e)||function(e,t){if(Symbol.iterator in Object(e)||"[object Arguments]"===Object.prototype.toString.call(e)){var r=[],n=!0,i=!1,a=void 0;try{for(var c,s=e[Symbol.iterator]();!(n=(c=s.next()).done)&&(r.push(c.value),!t||r.length!==t);n=!0);}catch(e){i=!0,a=e}finally{try{n||null==s.return||s.return()}finally{if(i)throw a}}return r}}(e,t)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function a(e){return function(e){if(Array.isArray(e)){for(var t=0,r=new Array(e.length);t2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}};return Promise.resolve().then((function(){var r=JSON.stringify(e),n=a()[r];return Promise.all([n||t(),void 0!==n])})).then((function(e){var t=i(e,2),n=t[0],a=t[1];return Promise.all([n,a||r.miss(n)])})).then((function(e){return i(e,1)[0]}))},set:function(e,t){return Promise.resolve().then((function(){var i=a();return i[JSON.stringify(e)]=t,n().setItem(r,JSON.stringify(i)),t}))},delete:function(e){return Promise.resolve().then((function(){var t=a();delete t[JSON.stringify(e)],n().setItem(r,JSON.stringify(t))}))},clear:function(){return Promise.resolve().then((function(){n().removeItem(r)}))}}}function s(e){var t=a(e.caches),r=t.shift();return void 0===r?{get:function(e,t){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}};return t().then((function(e){return Promise.all([e,r.miss(e)])})).then((function(e){return i(e,1)[0]}))},set:function(e,t){return Promise.resolve(t)},delete:function(e){return Promise.resolve()},clear:function(){return Promise.resolve()}}:{get:function(e,n){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}};return r.get(e,n,i).catch((function(){return s({caches:t}).get(e,n,i)}))},set:function(e,n){return r.set(e,n).catch((function(){return s({caches:t}).set(e,n)}))},delete:function(e){return r.delete(e).catch((function(){return s({caches:t}).delete(e)}))},clear:function(){return r.clear().catch((function(){return s({caches:t}).clear()}))}}}function o(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{serializable:!0},t={};return{get:function(r,n){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}},a=JSON.stringify(r);if(a in t)return Promise.resolve(e.serializable?JSON.parse(t[a]):t[a]);var c=n(),s=i&&i.miss||function(){return Promise.resolve()};return c.then((function(e){return s(e)})).then((function(){return c}))},set:function(r,n){return t[JSON.stringify(r)]=e.serializable?JSON.stringify(n):n,Promise.resolve(n)},delete:function(e){return delete t[JSON.stringify(e)],Promise.resolve()},clear:function(){return t={},Promise.resolve()}}}function u(e,t,r){var n={"x-algolia-api-key":r,"x-algolia-application-id":t};return{headers:function(){return e===m.WithinHeaders?n:{}},queryParameters:function(){return e===m.WithinQueryParameters?n:{}}}}function l(e){var t=0;return e((function r(){return t++,new Promise((function(n){setTimeout((function(){n(e(r))}),Math.min(100*t,1e3))}))}))}function f(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:function(e,t){return Promise.resolve()};return Object.assign(e,{wait:function(r){return f(e.then((function(e){return Promise.all([t(e,r),e])})).then((function(e){return e[1]})))}})}function h(e){for(var t=e.length-1;t>0;t--){var r=Math.floor(Math.random()*(t+1)),n=e[t];e[t]=e[r],e[r]=n}return e}function d(e,t){return t?(Object.keys(t).forEach((function(r){e[r]=t[r](e)})),e):e}function p(e){for(var t=arguments.length,r=new Array(t>1?t-1:0),n=1;n0?n:void 0,timeout:r.timeout||t,headers:r.headers||{},queryParameters:r.queryParameters||{},cacheable:r.cacheable}}var y={Read:1,Write:2,Any:3};function A(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1;return r(r({},e),{},{status:t,lastUpdate:Date.now()})}function b(e){return"string"==typeof e?{protocol:"https",url:e,accept:y.Any}:{protocol:e.protocol||"https",url:e.url,accept:e.accept||y.Any}}var v="DELETE",I="GET",S="POST",w="PUT";function R(e,t,n,i){var c=[],s=function(e,t){if(e.method!==I&&(void 0!==e.data||void 0!==t.data)){var n=Array.isArray(e.data)?e.data:r(r({},e.data),t.data);return JSON.stringify(n)}}(n,i),o=function(e,t){var n=r(r({},e.headers),t.headers),i={};return Object.keys(n).forEach((function(e){var t=n[e];i[e.toLowerCase()]=t})),i}(e,i),u=n.method,l=n.method!==I?{}:r(r({},n.data),i.data),f=r(r(r({"x-algolia-agent":e.userAgent.value},e.queryParameters),l),i.queryParameters),h=0,d=function t(r,a){var l=r.pop();if(void 0===l)throw{name:"RetryError",message:"Unreachable hosts - your application id may be incorrect. If the error persists, contact support@algolia.com.",transporterStackTrace:T(c)};var d={data:s,headers:o,method:u,url:O(l,n.path,f),connectTimeout:a(h,e.timeouts.connect),responseTimeout:a(h,i.timeout)},p=function(e){var t={request:d,response:e,host:l,triesLeft:r.length};return c.push(t),t},m={onSuccess:function(e){return function(e){try{return JSON.parse(e.content)}catch(t){throw function(e,t){return{name:"DeserializationError",message:e,response:t}}(t.message,e)}}(e)},onRetry:function(n){var i=p(n);return n.isTimedOut&&h++,Promise.all([e.logger.info("Retryable failure",H(i)),e.hostsCache.set(l,A(l,n.isTimedOut?3:2))]).then((function(){return t(r,a)}))},onFail:function(e){throw p(e),function(e,t){var r=e.content,n=e.status,i=r;try{i=JSON.parse(r).message}catch(e){}return function(e,t,r){return{name:"ApiError",message:e,status:t,transporterStackTrace:r}}(i,n,t)}(e,T(c))}};return e.requester.send(d).then((function(e){return function(e,t){return function(e){var t=e.status;return e.isTimedOut||function(e){var t=e.isTimedOut,r=e.status;return!t&&0==~~r}(e)||2!=~~(t/100)&&4!=~~(t/100)}(e)?t.onRetry(e):2==~~(e.status/100)?t.onSuccess(e):t.onFail(e)}(e,m)}))};return function(e,t){return Promise.all(t.map((function(t){return e.get(t,(function(){return Promise.resolve(A(t))}))}))).then((function(e){var r=e.filter((function(e){return function(e){return 1===e.status||Date.now()-e.lastUpdate>12e4}(e)})),n=e.filter((function(e){return function(e){return 3===e.status&&Date.now()-e.lastUpdate<=12e4}(e)})),i=[].concat(a(r),a(n));return{getTimeout:function(e,t){return(0===n.length&&0===e?1:n.length+3+e)*t},statelessHosts:i.length>0?i.map((function(e){return b(e)})):t}}))}(e.hostsCache,t).then((function(e){return d(a(e.statelessHosts).reverse(),e.getTimeout)}))}function j(e){var t=e.hostsCache,r=e.logger,n=e.requester,a=e.requestsCache,c=e.responsesCache,s=e.timeouts,o=e.userAgent,u=e.hosts,l=e.queryParameters,f={hostsCache:t,logger:r,requester:n,requestsCache:a,responsesCache:c,timeouts:s,userAgent:o,headers:e.headers,queryParameters:l,hosts:u.map((function(e){return b(e)})),read:function(e,t){var r=g(t,f.timeouts.read),n=function(){return R(f,f.hosts.filter((function(e){return 0!=(e.accept&y.Read)})),e,r)};if(!0!==(void 0!==r.cacheable?r.cacheable:e.cacheable))return n();var a={request:e,mappedRequestOptions:r,transporter:{queryParameters:f.queryParameters,headers:f.headers}};return f.responsesCache.get(a,(function(){return f.requestsCache.get(a,(function(){return f.requestsCache.set(a,n()).then((function(e){return Promise.all([f.requestsCache.delete(a),e])}),(function(e){return Promise.all([f.requestsCache.delete(a),Promise.reject(e)])})).then((function(e){var t=i(e,2);return t[0],t[1]}))}))}),{miss:function(e){return f.responsesCache.set(a,e)}})},write:function(e,t){return R(f,f.hosts.filter((function(e){return 0!=(e.accept&y.Write)})),e,g(t,f.timeouts.write))}};return f}function P(e){var t={value:"Algolia for JavaScript (".concat(e,")"),add:function(e){var r="; ".concat(e.segment).concat(void 0!==e.version?" (".concat(e.version,")"):"");return-1===t.value.indexOf(r)&&(t.value="".concat(t.value).concat(r)),t}};return t}function O(e,t,r){var n=E(r),i="".concat(e.protocol,"://").concat(e.url,"/").concat("/"===t.charAt(0)?t.substr(1):t);return n.length&&(i+="?".concat(n)),i}function E(e){return Object.keys(e).map((function(t){return p("%s=%s",t,(r=e[t],"[object Object]"===Object.prototype.toString.call(r)||"[object Array]"===Object.prototype.toString.call(r)?JSON.stringify(e[t]):e[t]));var r})).join("&")}function T(e){return e.map((function(e){return H(e)}))}function H(e){var t=e.request.headers["x-algolia-api-key"]?{"x-algolia-api-key":"*****"}:{};return r(r({},e),{},{request:r(r({},e.request),{},{headers:r(r({},e.request.headers),t)})})}var k=function(e){return function(t,r){return e.transporter.write({method:S,path:"2/abtests",data:t},r)}},x=function(e){return function(t,r){return e.transporter.write({method:v,path:p("2/abtests/%s",t)},r)}},M=function(e){return function(t,r){return e.transporter.read({method:I,path:p("2/abtests/%s",t)},r)}},Z=function(e){return function(t){return e.transporter.read({method:I,path:"2/abtests"},t)}},D=function(e){return function(t,r){return e.transporter.write({method:S,path:p("2/abtests/%s/stop",t)},r)}},B=function(e){return function(t){return e.transporter.read({method:I,path:"1/strategies/personalization"},t)}},N=function(e){return function(t,r){return e.transporter.write({method:S,path:"1/strategies/personalization",data:t},r)}};function z(e){return function t(r){return e.request(r).then((function(n){if(void 0!==e.batch&&e.batch(n.hits),!e.shouldStop(n))return n.cursor?t({cursor:n.cursor}):t({page:(r.page||0)+1})}))}({})}var U=function(e){return function(t,i){var a=i||{},c=a.queryParameters,s=n(a,["queryParameters"]),o=r({acl:t},void 0!==c?{queryParameters:c}:{});return f(e.transporter.write({method:S,path:"1/keys",data:o},s),(function(t,r){return l((function(n){return q(e)(t.key,r).catch((function(e){if(404!==e.status)throw e;return n()}))}))}))}},G=function(e){return function(t,r,n){var i=g(n);return i.queryParameters["X-Algolia-User-ID"]=t,e.transporter.write({method:S,path:"1/clusters/mapping",data:{cluster:r}},i)}},F=function(e){return function(t,r,n){return e.transporter.write({method:S,path:"1/clusters/mapping/batch",data:{users:t,cluster:r}},n)}},W=function(e){return function(t,r){return f(e.transporter.write({method:S,path:p("/1/dictionaries/%s/batch",t),data:{clearExistingDictionaryEntries:!0,requests:{action:"addEntry",body:[]}}},r),(function(t,r){return Ie(e)(t.taskID,r)}))}},Q=function(e){return function(t,r,n){return f(e.transporter.write({method:S,path:p("1/indexes/%s/operation",t),data:{operation:"copy",destination:r}},n),(function(r,n){return ne(e)(t,{methods:{waitTask:st}}).waitTask(r.taskID,n)}))}},C=function(e){return function(t,n,i){return Q(e)(t,n,r(r({},i),{},{scope:[ut.Rules]}))}},X=function(e){return function(t,n,i){return Q(e)(t,n,r(r({},i),{},{scope:[ut.Settings]}))}},J=function(e){return function(t,n,i){return Q(e)(t,n,r(r({},i),{},{scope:[ut.Synonyms]}))}},V=function(e){return function(t,r){return t.method===I?e.transporter.read(t,r):e.transporter.write(t,r)}},L=function(e){return function(t,r){return f(e.transporter.write({method:v,path:p("1/keys/%s",t)},r),(function(r,n){return l((function(r){return q(e)(t,n).then(r).catch((function(e){if(404!==e.status)throw e}))}))}))}},Y=function(e){return function(t,r,n){var i=r.map((function(e){return{action:"deleteEntry",body:{objectID:e}}}));return f(e.transporter.write({method:S,path:p("/1/dictionaries/%s/batch",t),data:{clearExistingDictionaryEntries:!1,requests:i}},n),(function(t,r){return Ie(e)(t.taskID,r)}))}},q=function(e){return function(t,r){return e.transporter.read({method:I,path:p("1/keys/%s",t)},r)}},K=function(e){return function(t,r){return e.transporter.read({method:I,path:p("1/task/%s",t.toString())},r)}},_=function(e){return function(t){return e.transporter.read({method:I,path:"/1/dictionaries/*/settings"},t)}},$=function(e){return function(t){return e.transporter.read({method:I,path:"1/logs"},t)}},ee=function(e){return function(t){return e.transporter.read({method:I,path:"1/clusters/mapping/top"},t)}},te=function(e){return function(t,r){return e.transporter.read({method:I,path:p("1/clusters/mapping/%s",t)},r)}},re=function(e){return function(t){var r=t||{},i=r.retrieveMappings,a=n(r,["retrieveMappings"]);return!0===i&&(a.getClusters=!0),e.transporter.read({method:I,path:"1/clusters/mapping/pending"},a)}},ne=function(e){return function(t){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return d({transporter:e.transporter,appId:e.appId,indexName:t},r.methods)}},ie=function(e){return function(t){return e.transporter.read({method:I,path:"1/keys"},t)}},ae=function(e){return function(t){return e.transporter.read({method:I,path:"1/clusters"},t)}},ce=function(e){return function(t){return e.transporter.read({method:I,path:"1/indexes"},t)}},se=function(e){return function(t){return e.transporter.read({method:I,path:"1/clusters/mapping"},t)}},oe=function(e){return function(t,r,n){return f(e.transporter.write({method:S,path:p("1/indexes/%s/operation",t),data:{operation:"move",destination:r}},n),(function(r,n){return ne(e)(t,{methods:{waitTask:st}}).waitTask(r.taskID,n)}))}},ue=function(e){return function(t,r){return f(e.transporter.write({method:S,path:"1/indexes/*/batch",data:{requests:t}},r),(function(t,r){return Promise.all(Object.keys(t.taskID).map((function(n){return ne(e)(n,{methods:{waitTask:st}}).waitTask(t.taskID[n],r)})))}))}},le=function(e){return function(t,r){return e.transporter.read({method:S,path:"1/indexes/*/objects",data:{requests:t}},r)}},fe=function(e){return function(t,n){var i=t.map((function(e){return r(r({},e),{},{params:E(e.params||{})})}));return e.transporter.read({method:S,path:"1/indexes/*/queries",data:{requests:i},cacheable:!0},n)}},he=function(e){return function(t,i){return Promise.all(t.map((function(t){var a=t.params,c=a.facetName,s=a.facetQuery,o=n(a,["facetName","facetQuery"]);return ne(e)(t.indexName,{methods:{searchForFacetValues:nt}}).searchForFacetValues(c,s,r(r({},i),o))})))}},de=function(e){return function(t,r){var n=g(r);return n.queryParameters["X-Algolia-User-ID"]=t,e.transporter.write({method:v,path:"1/clusters/mapping"},n)}},pe=function(e){return function(t,r,n){var i=r.map((function(e){return{action:"addEntry",body:e}}));return f(e.transporter.write({method:S,path:p("/1/dictionaries/%s/batch",t),data:{clearExistingDictionaryEntries:!0,requests:i}},n),(function(t,r){return Ie(e)(t.taskID,r)}))}},me=function(e){return function(t,r){return f(e.transporter.write({method:S,path:p("1/keys/%s/restore",t)},r),(function(r,n){return l((function(r){return q(e)(t,n).catch((function(e){if(404!==e.status)throw e;return r()}))}))}))}},ge=function(e){return function(t,r,n){var i=r.map((function(e){return{action:"addEntry",body:e}}));return f(e.transporter.write({method:S,path:p("/1/dictionaries/%s/batch",t),data:{clearExistingDictionaryEntries:!1,requests:i}},n),(function(t,r){return Ie(e)(t.taskID,r)}))}},ye=function(e){return function(t,r,n){return e.transporter.read({method:S,path:p("/1/dictionaries/%s/search",t),data:{query:r},cacheable:!0},n)}},Ae=function(e){return function(t,r){return e.transporter.read({method:S,path:"1/clusters/mapping/search",data:{query:t}},r)}},be=function(e){return function(t,r){return f(e.transporter.write({method:w,path:"/1/dictionaries/*/settings",data:t},r),(function(t,r){return Ie(e)(t.taskID,r)}))}},ve=function(e){return function(t,r){var i=Object.assign({},r),a=r||{},c=a.queryParameters,s=n(a,["queryParameters"]),o=c?{queryParameters:c}:{},u=["acl","indexes","referers","restrictSources","queryParameters","description","maxQueriesPerIPPerHour","maxHitsPerQuery"];return f(e.transporter.write({method:w,path:p("1/keys/%s",t),data:o},s),(function(r,n){return l((function(r){return q(e)(t,n).then((function(e){return function(e){return Object.keys(i).filter((function(e){return-1!==u.indexOf(e)})).every((function(t){return e[t]===i[t]}))}(e)?Promise.resolve():r()}))}))}))}},Ie=function(e){return function(t,r){return l((function(n){return K(e)(t,r).then((function(e){return"published"!==e.status?n():void 0}))}))}},Se=function(e){return function(t,r){return f(e.transporter.write({method:S,path:p("1/indexes/%s/batch",e.indexName),data:{requests:t}},r),(function(t,r){return st(e)(t.taskID,r)}))}},we=function(e){return function(t){return z(r(r({shouldStop:function(e){return void 0===e.cursor}},t),{},{request:function(r){return e.transporter.read({method:S,path:p("1/indexes/%s/browse",e.indexName),data:r},t)}}))}},Re=function(e){return function(t){var n=r({hitsPerPage:1e3},t);return z(r(r({shouldStop:function(e){return e.hits.length0&&void 0!==arguments[0]?arguments[0]:0;i=e.nbPages)throw{name:"ObjectNotFoundError",message:"Object not found."};return n()}))}()}},Ue=function(e){return function(t,r){return e.transporter.read({method:I,path:p("1/indexes/%s/%s",e.indexName,t)},r)}},Ge=function(){return function(e,t){for(var r=0,n=Object.entries(e.hits);rr.OPENED&&void 0===n&&(clearTimeout(a),n=i(e.responseTimeout,"Socket timeout"))},r.onerror=function(){0===r.status&&(clearTimeout(a),clearTimeout(n),t({content:r.responseText||"Network request failed",status:r.status,isTimedOut:!1}))},r.onload=function(){clearTimeout(a),clearTimeout(n),t({content:r.responseText,status:r.status,isTimedOut:!1})},r.send(e.data)}))}},logger:(3,{debug:function(e,t){return Promise.resolve()},info:function(e,t){return Promise.resolve()},error:function(e,t){return console.error(e,t),Promise.resolve()}}),responsesCache:o(),requestsCache:o({serializable:!1}),hostsCache:s({caches:[c({key:"".concat("4.17.0","-").concat(e)}),o()]}),userAgent:P("4.17.0").add({segment:"Browser"})},a=r(r({},i),n),l=function(){return function(e){return function(e){var t=e.region||"us",n=u(m.WithinHeaders,e.appId,e.apiKey),i=j(r(r({hosts:[{url:"personalization.".concat(t,".algolia.com")}]},e),{},{headers:r(r(r({},n.headers()),{"content-type":"application/json"}),e.headers),queryParameters:r(r({},n.queryParameters()),e.queryParameters)}));return d({appId:e.appId,transporter:i},e.methods)}(r(r(r({},i),e),{},{methods:{getPersonalizationStrategy:B,setPersonalizationStrategy:N}}))}};return function(e){var t=e.appId,n=u(void 0!==e.authMode?e.authMode:m.WithinHeaders,t,e.apiKey),i=j(r(r({hosts:[{url:"".concat(t,"-dsn.algolia.net"),accept:y.Read},{url:"".concat(t,".algolia.net"),accept:y.Write}].concat(h([{url:"".concat(t,"-1.algolianet.com")},{url:"".concat(t,"-2.algolianet.com")},{url:"".concat(t,"-3.algolianet.com")}]))},e),{},{headers:r(r(r({},n.headers()),{"content-type":"application/x-www-form-urlencoded"}),e.headers),queryParameters:r(r({},n.queryParameters()),e.queryParameters)}));return d({transporter:i,appId:t,addAlgoliaAgent:function(e,t){i.userAgent.add({segment:e,version:t})},clearCache:function(){return Promise.all([i.requestsCache.clear(),i.responsesCache.clear()]).then((function(){}))}},e.methods)}(r(r({},a),{},{methods:{search:fe,searchForFacetValues:he,multipleBatch:ue,multipleGetObjects:le,multipleQueries:fe,copyIndex:Q,copySettings:X,copySynonyms:J,copyRules:C,moveIndex:oe,listIndices:ce,getLogs:$,listClusters:ae,multipleSearchForFacetValues:he,getApiKey:q,addApiKey:U,listApiKeys:ie,updateApiKey:ve,deleteApiKey:L,restoreApiKey:me,assignUserID:G,assignUserIDs:F,getUserID:te,searchUserIDs:Ae,listUserIDs:se,getTopUserIDs:ee,removeUserID:de,hasPendingMappings:re,clearDictionaryEntries:W,deleteDictionaryEntries:Y,getDictionarySettings:_,getAppTask:K,replaceDictionaryEntries:pe,saveDictionaryEntries:ge,searchDictionaryEntries:ye,setDictionarySettings:be,waitAppTask:Ie,customRequest:V,initIndex:function(e){return function(t){return ne(e)(t,{methods:{batch:Se,delete:ke,findAnswers:Ne,getObject:Ue,getObjects:Fe,saveObject:qe,saveObjects:Ke,search:rt,searchForFacetValues:nt,waitTask:st,setSettings:ct,getSettings:Qe,partialUpdateObject:Xe,partialUpdateObjects:Je,deleteObject:xe,deleteObjects:Me,deleteBy:He,clearObjects:Oe,browseObjects:we,getObjectPosition:Ge,findObject:ze,exists:Be,saveSynonym:et,saveSynonyms:tt,getSynonym:Ce,searchSynonyms:at,browseSynonyms:je,deleteSynonym:De,clearSynonyms:Te,replaceAllObjects:Ve,replaceAllSynonyms:Ye,searchRules:it,getRule:We,deleteRule:Ze,saveRule:_e,saveRules:$e,replaceAllRules:Le,browseRules:Re,clearRules:Ee}})}},initAnalytics:function(){return function(e){return function(e){var t=e.region||"us",n=u(m.WithinHeaders,e.appId,e.apiKey),i=j(r(r({hosts:[{url:"analytics.".concat(t,".algolia.com")}]},e),{},{headers:r(r(r({},n.headers()),{"content-type":"application/json"}),e.headers),queryParameters:r(r({},n.queryParameters()),e.queryParameters)}));return d({appId:e.appId,transporter:i},e.methods)}(r(r(r({},i),e),{},{methods:{addABTest:k,getABTest:M,getABTests:Z,stopABTest:D,deleteABTest:x}}))}},initPersonalization:l,initRecommendation:function(){return function(e){return a.logger.info("The `initRecommendation` method is deprecated. Use `initPersonalization` instead."),l()(e)}}}}))}return lt.version="4.17.0",lt}()},904:e=>{"use strict";var t=String.prototype.replace,r=/%20/g,n="RFC3986";e.exports={default:n,formatters:{RFC1738:function(e){return t.call(e,r,"+")},RFC3986:function(e){return String(e)}},RFC1738:"RFC1738",RFC3986:n}},368:(e,t,r)=>{"use strict";var n=r(307),i=r(316),a=r(904);e.exports={formats:a,parse:i,stringify:n}},316:(e,t,r)=>{"use strict";var n=r(84),i=Object.prototype.hasOwnProperty,a=Array.isArray,c={allowDots:!1,allowPrototypes:!1,arrayLimit:20,charset:"utf-8",charsetSentinel:!1,comma:!1,decoder:n.decode,delimiter:"&",depth:5,ignoreQueryPrefix:!1,interpretNumericEntities:!1,parameterLimit:1e3,parseArrays:!0,plainObjects:!1,strictNullHandling:!1},s=function(e){return e.replace(/&#(\d+);/g,(function(e,t){return String.fromCharCode(parseInt(t,10))}))},o=function(e,t){return e&&"string"==typeof e&&t.comma&&e.indexOf(",")>-1?e.split(","):e},u=function(e,t,r,n){if(e){var a=r.allowDots?e.replace(/\.([^.[]+)/g,"[$1]"):e,c=/(\[[^[\]]*])/g,s=r.depth>0&&/(\[[^[\]]*])/.exec(a),u=s?a.slice(0,s.index):a,l=[];if(u){if(!r.plainObjects&&i.call(Object.prototype,u)&&!r.allowPrototypes)return;l.push(u)}for(var f=0;r.depth>0&&null!==(s=c.exec(a))&&f=0;--a){var c,s=e[a];if("[]"===s&&r.parseArrays)c=[].concat(i);else{c=r.plainObjects?Object.create(null):{};var u="["===s.charAt(0)&&"]"===s.charAt(s.length-1)?s.slice(1,-1):s,l=parseInt(u,10);r.parseArrays||""!==u?!isNaN(l)&&s!==u&&String(l)===u&&l>=0&&r.parseArrays&&l<=r.arrayLimit?(c=[])[l]=i:"__proto__"!==u&&(c[u]=i):c={0:i}}i=c}return i}(l,t,r,n)}};e.exports=function(e,t){var r=function(e){if(!e)return c;if(null!==e.decoder&&void 0!==e.decoder&&"function"!=typeof e.decoder)throw new TypeError("Decoder has to be a function.");if(void 0!==e.charset&&"utf-8"!==e.charset&&"iso-8859-1"!==e.charset)throw new TypeError("The charset option must be either utf-8, iso-8859-1, or undefined");var t=void 0===e.charset?c.charset:e.charset;return{allowDots:void 0===e.allowDots?c.allowDots:!!e.allowDots,allowPrototypes:"boolean"==typeof e.allowPrototypes?e.allowPrototypes:c.allowPrototypes,arrayLimit:"number"==typeof e.arrayLimit?e.arrayLimit:c.arrayLimit,charset:t,charsetSentinel:"boolean"==typeof e.charsetSentinel?e.charsetSentinel:c.charsetSentinel,comma:"boolean"==typeof e.comma?e.comma:c.comma,decoder:"function"==typeof e.decoder?e.decoder:c.decoder,delimiter:"string"==typeof e.delimiter||n.isRegExp(e.delimiter)?e.delimiter:c.delimiter,depth:"number"==typeof e.depth||!1===e.depth?+e.depth:c.depth,ignoreQueryPrefix:!0===e.ignoreQueryPrefix,interpretNumericEntities:"boolean"==typeof e.interpretNumericEntities?e.interpretNumericEntities:c.interpretNumericEntities,parameterLimit:"number"==typeof e.parameterLimit?e.parameterLimit:c.parameterLimit,parseArrays:!1!==e.parseArrays,plainObjects:"boolean"==typeof e.plainObjects?e.plainObjects:c.plainObjects,strictNullHandling:"boolean"==typeof e.strictNullHandling?e.strictNullHandling:c.strictNullHandling}}(t);if(""===e||null==e)return r.plainObjects?Object.create(null):{};for(var l="string"==typeof e?function(e,t){var r,u={},l=t.ignoreQueryPrefix?e.replace(/^\?/,""):e,f=t.parameterLimit===1/0?void 0:t.parameterLimit,h=l.split(t.delimiter,f),d=-1,p=t.charset;if(t.charsetSentinel)for(r=0;r-1&&(g=a(g)?[g]:g),i.call(u,m)?u[m]=n.combine(u[m],g):u[m]=g}return u}(e,r):e,f=r.plainObjects?Object.create(null):{},h=Object.keys(l),d=0;d{"use strict";var n=r(84),i=r(904),a=Object.prototype.hasOwnProperty,c={brackets:function(e){return e+"[]"},comma:"comma",indices:function(e,t){return e+"["+t+"]"},repeat:function(e){return e}},s=Array.isArray,o=String.prototype.split,u=Array.prototype.push,l=function(e,t){u.apply(e,s(t)?t:[t])},f=Date.prototype.toISOString,h=i.default,d={addQueryPrefix:!1,allowDots:!1,charset:"utf-8",charsetSentinel:!1,delimiter:"&",encode:!0,encoder:n.encode,encodeValuesOnly:!1,format:h,formatter:i.formatters[h],indices:!1,serializeDate:function(e){return f.call(e)},skipNulls:!1,strictNullHandling:!1},p=function e(t,r,i,a,c,u,f,h,p,m,g,y,A,b){var v,I=t;if("function"==typeof f?I=f(r,I):I instanceof Date?I=m(I):"comma"===i&&s(I)&&(I=n.maybeMap(I,(function(e){return e instanceof Date?m(e):e}))),null===I){if(a)return u&&!A?u(r,d.encoder,b,"key",g):r;I=""}if("string"==typeof(v=I)||"number"==typeof v||"boolean"==typeof v||"symbol"==typeof v||"bigint"==typeof v||n.isBuffer(I)){if(u){var S=A?r:u(r,d.encoder,b,"key",g);if("comma"===i&&A){for(var w=o.call(String(I),","),R="",j=0;j0?I.join(",")||null:void 0}];else if(s(f))P=f;else{var E=Object.keys(I);P=h?E.sort(h):E}for(var T=0;T0?A+y:""}},84:(e,t,r)=>{"use strict";var n=r(904),i=Object.prototype.hasOwnProperty,a=Array.isArray,c=function(){for(var e=[],t=0;t<256;++t)e.push("%"+((t<16?"0":"")+t.toString(16)).toUpperCase());return e}(),s=function(e,t){for(var r=t&&t.plainObjects?Object.create(null):{},n=0;n1;){var t=e.pop(),r=t.obj[t.prop];if(a(r)){for(var n=[],i=0;i=48&&l<=57||l>=65&&l<=90||l>=97&&l<=122||a===n.RFC1738&&(40===l||41===l)?o+=s.charAt(u):l<128?o+=c[l]:l<2048?o+=c[192|l>>6]+c[128|63&l]:l<55296||l>=57344?o+=c[224|l>>12]+c[128|l>>6&63]+c[128|63&l]:(u+=1,l=65536+((1023&l)<<10|1023&s.charCodeAt(u)),o+=c[240|l>>18]+c[128|l>>12&63]+c[128|l>>6&63]+c[128|63&l])}return o},isBuffer:function(e){return!(!e||"object"!=typeof e||!(e.constructor&&e.constructor.isBuffer&&e.constructor.isBuffer(e)))},isRegExp:function(e){return"[object RegExp]"===Object.prototype.toString.call(e)},maybeMap:function(e,t){if(a(e)){for(var r=[],n=0;n{"use strict";var n=r(196),i="function"==typeof Object.is?Object.is:function(e,t){return e===t&&(0!==e||1/e==1/t)||e!=e&&t!=t},a=n.useState,c=n.useEffect,s=n.useLayoutEffect,o=n.useDebugValue;function u(e){var t=e.getSnapshot;e=e.value;try{var r=t();return!i(e,r)}catch(e){return!0}}var l="undefined"==typeof window||void 0===window.document||void 0===window.document.createElement?function(e,t){return t()}:function(e,t){var r=t(),n=a({inst:{value:r,getSnapshot:t}}),i=n[0].inst,l=n[1];return s((function(){i.value=r,i.getSnapshot=t,u(i)&&l({inst:i})}),[e,r,t]),c((function(){return u(i)&&l({inst:i}),e((function(){u(i)&&l({inst:i})}))}),[e]),o(r),r};t.useSyncExternalStore=void 0!==n.useSyncExternalStore?n.useSyncExternalStore:l},688:(e,t,r)=>{"use strict";e.exports=r(250)},196:e=>{"use strict";e.exports=window.React}},t={};function r(n){var i=t[n];if(void 0!==i)return i.exports;var a=t[n]={exports:{}};return e[n].call(a.exports,a,a.exports,r),a.exports}r.n=e=>{var t=e&&e.__esModule?()=>e.default:()=>e;return r.d(t,{a:t}),t},r.d=(e,t)=>{for(var n in t)r.o(t,n)&&!r.o(e,n)&&Object.defineProperty(e,n,{enumerable:!0,get:t[n]})},r.o=(e,t)=>Object.prototype.hasOwnProperty.call(e,t);var n={};(()=>{"use strict";r.d(n,{z:()=>An});const e=window.wp.element,t=window.wp.editPost,i=window.wp.plugins,a=window.lodash;function c(e){var t=e.name,r=e.connector;return["https://www.algolia.com/doc/api-reference/widgets/",t,"/js/",void 0!==r&&r?"#connector":""].join("")}function s(){for(var e=arguments.length,t=new Array(e),r=0;r1&&void 0!==arguments[1]?arguments[1]:o;return u(e,p()),function(r){var n,i,a=(r||{}).queryHook,c=void 0===a?m:a;return{$$type:"ais.searchBox",init:function(t){var r=t.instantSearchInstance;e(h(h({},this.getWidgetRenderState(t)),{},{instantSearchInstance:r}),!0)},render:function(t){var r=t.instantSearchInstance;e(h(h({},this.getWidgetRenderState(t)),{},{instantSearchInstance:r}),!1)},dispose:function(e){var r=e.state;return t(),r.setQueryParameter("query",void 0)},getRenderState:function(e,t){return h(h({},e),{},{searchBox:this.getWidgetRenderState(t)})},getWidgetRenderState:function(e){var t=e.helper,a=e.searchMetadata,s=e.state;return n||(n=function(e){c(e,(function(e){return t.setQuery(e).search()}))},i=function(){t.setQuery("").search()}),{query:s.query||"",refine:n,clear:i,widgetParams:r,isSearchStalled:a.isSearchStalled}},getWidgetUiState:function(e,t){var r=t.searchParameters.query||"";return""===r||e&&e.query===r?e:h(h({},e),{},{query:r})},getWidgetSearchParameters:function(e,t){var r=t.uiState;return e.setQueryParameter("query",r.query||"")}}}};var y=r(196);function A(e){return A="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},A(e)}var b=Object.prototype.hasOwnProperty;function v(e,t,r){if(null!=r&&r(e,t))return!0;var n,i;if(e===t)return!0;if(e&&t&&(n=e.constructor)===t.constructor){if(n===Date)return e.getTime()===t.getTime();if(n===RegExp)return e.toString()===t.toString();if(n===Array){if((i=e.length)===t.length)for(;i--&&v(e[i],t[i],r););return-1===i}if(!n||"object"===A(e)){for(n in i=0,e){if(b.call(e,n)&&++i&&!b.call(t,n))return!1;if(!(n in t)||!v(e[n],t[n],r))return!1}return Object.keys(t).length===i}}return e!=e&&t!=t}var I=r(131);function S(e){var t,r,n;return new I.SearchResults(e,[{query:null!==(t=e.query)&&void 0!==t?t:"",page:null!==(r=e.page)&&void 0!==r?r:0,hitsPerPage:null!==(n=e.hitsPerPage)&&void 0!==n?n:20,hits:[],nbHits:0,nbPages:0,params:"",exhaustiveNbHits:!0,exhaustiveFacetsCount:!0,processingTimeMS:0,index:e.index}],{__isArtificial:!0})}function w(e){return w="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},w(e)}function R(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function j(e){for(var t=1;te.length)&&(t=e.length);for(var r=0,n=new Array(t);re.length)&&(t=e.length);for(var r=0,n=new Array(t);r=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}function L(e){var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=Z(),i=x(),a=H(),c=B(t),s=B(r),o=(0,y.useRef)(!0),u=(0,y.useRef)(null),l=(0,y.useMemo)((function(){return X(X({},e((function(e,t){if(t)o.current=!0;else if(o.current){e.instantSearchInstance,e.widgetParams;var r=V(e,G);v(r,u.current,(function(e,t){return(null==e?void 0:e.constructor)===Function&&(null==t?void 0:t.constructor)===Function}))||(p(r),u.current=r)}}),(function(){o.current=!1}))(c)),s)}),[e,c,s]),f=(0,y.useState)((function(){if(l.getWidgetRenderState){var e,t=a.getHelper(),r=a.getWidgetUiState({})[a.getIndexId()];t.state=(null===(e=l.getWidgetSearchParameters)||void 0===e?void 0:e.call(l,t.state,{uiState:r}))||t.state;var n=O(a),c=n.results,s=n.scopedResults,o=l.getWidgetRenderState({helper:t,parent:a,instantSearchInstance:i,results:c,scopedResults:s,state:t.state,renderState:i.renderState,templatesConfig:i.templatesConfig,createURL:a.createURL,searchMetadata:{isSearchStalled:"stalled"===i.status},status:i.status,error:i.error});return o.widgetParams,V(o,F)}return{}})),h=W(f,2),d=h[0],p=h[1];return z({widget:l,parentIndex:a,props:c,shouldSsr:Boolean(n)}),d}function Y(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);re.length)&&(t=e.length);for(var r=0,n=new Array(t);ree()({path:"newfold-ai/v1/search",method:"POST",data:{user_prompt:e,identifier:t,extra:r}})};var re,ne;function ie(){return ie=Object.assign?Object.assign.bind():function(e){for(var t=1;t{let{searchTitle:r,onGo:n}=t;return(0,e.createElement)(e.Fragment,null,(0,e.createElement)("div",{className:"algoliaResult",onClick:n},(0,e.createElement)("p",null,r),(0,e.createElement)("div",{className:"svg"},(0,e.createElement)(se,null))))},ue=window.wp.i18n,le=()=>"true"===localStorage.getItem("helpVisible"),fe=t=>{let{postId:r}=t;const[n,i]=(0,e.useState)(""),a=(0,e.useRef)(null),c=(0,e.useRef)(null);return(0,e.useEffect)((()=>{i(""),c.current.className="feedback-button no",a.current.className="feedback-button yes"}),[r]),(0,e.useEffect)((()=>{(async()=>{"helpful"!==n&&"notHelpful"!==n||((e,t)=>{ee()({path:"nfd-help/v1/feedback",method:"POST",data:{post_id:e,status:t}})})(r,n)})(),"helpful"===n&&(a.current.className="feedback-button yes selected-yes",c.current.className="feedback-button no"),"notHelpful"===n&&(c.current.className="feedback-button no selected-no",a.current.className="feedback-button yes")}),[n]),(0,e.createElement)("div",{className:"feedback-container"},(0,e.createElement)("div",null,(0,e.createElement)("p",null,(0,e.createElement)("b",null,(0,ue.__)("Did this result help you ?","wp-module-help-center")))),(0,e.createElement)("div",{class:"icon"},(0,e.createElement)("button",{ref:a,onClick:()=>{i("helpful")},class:"feedback-button yes"},"helpful"===n&&(0,e.createElement)(e.Fragment,null,"🥳")," Yes"),(0,e.createElement)("button",{onClick:()=>{i("notHelpful")},ref:c,class:"feedback-button no"},"notHelpful"===n&&(0,e.createElement)(e.Fragment,null,"😭")," No")))};var he,de;function pe(){return pe=Object.assign?Object.assign.bind():function(e){for(var t=1;t(0,e.createElement)("div",null,(0,e.createElement)("p",null,(0,ue.__)("Result based on your search:","wp-module-help-center")),(0,e.createElement)("h4",null,(0,ue.__)("Sorry, we don't have any content for that yet.","wp-module-help-center")),(0,e.createElement)("hr",null),(0,e.createElement)(me,null),(0,e.createElement)("p",null,(0,ue.__)("This tool is being built and doesn't always have a match.","wp-module-help-center")),(0,e.createElement)("p",null,(0,ue.__)("In the meantime, try searching our","wp-module-help-center")," ",(0,e.createElement)("a",{href:"https://www.bluehost.com/help"},(0,ue.__)("Resource center.","wp-module-help-center"))),(0,e.createElement)("hr",null)),ye=t=>{let{content:r,noResult:n,postId:i}=t;return n?(0,e.createElement)(ge,null):r&&r.length>0?(0,e.createElement)(e.Fragment,null,(0,e.createElement)("h4",null,(0,ue.__)("Follow these steps:","wp-module-help-center")),(0,e.createElement)("p",{dangerouslySetInnerHTML:{__html:r}}),r&&r.length>0&&(0,e.createElement)(fe,{postId:i})):(0,e.createElement)(e.Fragment,null)};var Ae,be,ve,Ie,Se,we;function Re(){return Re=Object.assign?Object.assign.bind():function(e){for(var t=1;t(0,e.createElement)(e.Fragment,null,(0,e.createElement)(je,null)," ",(0,e.createElement)(je,null)," ",(0,e.createElement)(je,null)),Oe=()=>{const[t,r]=(0,e.useState)(!1),[n,i]=(0,e.useState)(!1),[c,s]=(0,e.useState)(""),[o,u]=(0,e.useState)(""),[l,f]=(0,e.useState)(),{query:h,refine:d,clear:p}=L(g,undefined,undefined);const{results:m}=function(){var e=(arguments.length>0&&void 0!==arguments[0]?arguments[0]:{}).catchError,t=x(),r=_(),n=r.uiState,i=r.setUiState,a=r.indexUiState,c=r.setIndexUiState,s=q(),o=s.results,u=s.scopedResults,l=(0,y.useCallback)((function(){for(var e=arguments.length,r=new Array(e),n=0;n{const n=e.replace(/\n/g,"

");u(n),f(t),((e,t)=>{localStorage.setItem("helpResultContent",e),localStorage.setItem("helpPostId",t)})(n,t),(e=>{localStorage.setItem("searchInput",e)})(r)};(0,e.useEffect)((()=>{const{content:e,postId:t}={content:localStorage.getItem("helpResultContent"),postId:localStorage.getItem("helpPostId")};e&&u(e),t&&f(t);const r=localStorage.getItem("searchInput");r&&(s(r),d(r))}),[]);const b=(0,e.useMemo)((()=>(0,a.debounce)((function(e){e&&0===e.length&&p(),d(e)}),300)),[]);return(0,e.useEffect)((()=>{b.cancel()}),[]),t?(0,e.createElement)(e.Fragment,null,(0,e.createElement)(Pe,null)):(0,e.createElement)(e.Fragment,null,(0,e.createElement)("div",{className:"search-container"},(0,e.createElement)("button",{onClick:()=>{document.getElementById("search-input-box").focus()}},(0,e.createElement)(ae,null)),(0,e.createElement)("input",{type:"text",id:"search-input-box",style:{flexGrow:2},value:c,maxLength:"144",placeholder:"Ask me anything...",onChange:e=>{s(e.target.value),A("",void 0,e.target.value),i(!1),b(e.target.value)},onKeyDown:async e=>{"Enter"===e.key&&await(async()=>{r(!0);try{const e=m.hits;if(e.length>0&&e[0]._rankingInfo.proximityDistance/e[0]._rankingInfo.words>=.75)return void A(e[0].content,e[0].post_id,c);const t=await te.getSearchResult(h,"helpcenter");A(t.result,t.post_id,c)}catch(e){console.log(e),i(!0)}finally{r(!1)}})()}})),(0,e.createElement)("div",{className:"attribute"},(0,e.createElement)("p",null,(0,e.createElement)("span",null,c?c.length:0,"/144"))),(0,e.createElement)(ye,{content:o,noResult:n,postId:l}),m.hits.length>0&&(0,e.createElement)("p",null,(0,e.createElement)("b",null,o.length>0?"Other Resources":"Search Suggestions")),m.hits.map((t=>(0,e.createElement)(e.Fragment,null,(0,e.createElement)(oe,{searchTitle:t.post_title,onGo:()=>{s(t.post_title),A(t.content,t.post_id,t.post_title)}})))))};var Ee=r(955),Te=r.n(Ee),He=r(331);function ke(e){return ke="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},ke(e)}function xe(){return function(e){if("object"===("undefined"==typeof document?"undefined":ke(document))&&"string"==typeof document.cookie)for(var t="".concat("_ALGOLIA","="),r=document.cookie.split(";"),n=0;n1&&void 0!==arguments[1]?arguments[1]:{fallback:function(){}},r=t.fallback;return"undefined"==typeof window?r():e({window})}function Ze(e){if(e.transporter){var t=e.transporter,r=t.headers,n=t.queryParameters,i="x-algolia-application-id",a="x-algolia-api-key";return[r[i]||n[i],r[a]||n[a]]}return[e.applicationID,e.apiKey]}function De(e,t){for(var r,n=0;ne.length)&&(t=e.length);for(var r=0,n=new Array(t);r=3||2===r&&n>=6||1===r&&n>=10}function Ve(e,t,r){var n=t.getHelper();return{uiState:r,helper:n,parent:t,instantSearchInstance:e,state:n.state,renderState:e.renderState,templatesConfig:e.templatesConfig,createURL:t.createURL,scopedResults:[],searchMetadata:{isSearchStalled:"stalled"===e.status},status:e.status,error:e.error}}function Le(e,t){var r=t.getResults();return{helper:t.getHelper(),parent:t,instantSearchInstance:e,results:r,scopedResults:t.getScopedResults(),state:r._state,renderState:e.renderState,templatesConfig:e.templatesConfig,createURL:t.createURL,searchMetadata:{isSearchStalled:"stalled"===e.status},status:e.status,error:e.error}}function Ye(e,t,r){var n=Ve(t,t.mainIndex,t._initialUiState);e.forEach((function(e){var i={};if(e.getWidgetRenderState){var a=e.getWidgetRenderState(n);a&&a.widgetParams&&(i=a.widgetParams)}var c=Object.keys(i).filter((function(e){return void 0!==i[e]}));r.widgets.push({type:e.$$type,widgetType:e.$$widgetType,params:c}),"ais.index"===e.$$type&&Ye(e.getWidgets(),t,r)}))}var qe=r(368);function Ke(e){return Ke="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Ke(e)}function _e(e,t){for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:{},t=e.createURL,r=void 0===t?function(e){var t=e.qsModule,r=e.routeState,n=e.location,i=n.protocol,a=n.hostname,c=n.port,s=void 0===c?"":c,o=n.pathname,u=n.hash,l=t.stringify(r),f=""===s?"":":".concat(s);return l?"".concat(i,"//").concat(a).concat(f).concat(o,"?").concat(l).concat(u):"".concat(i,"//").concat(a).concat(f).concat(o).concat(u)}:t,n=e.parseURL,i=void 0===n?function(e){var t=e.qsModule,r=e.location;return t.parse(r.search.slice(1),{arrayLimit:99})}:n,a=e.writeDelay,c=void 0===a?400:a,s=e.windowTitle,o=e.getLocation,u=void 0===o?function(){return Me((function(e){return e.window.location}),{fallback:function(){throw new Error("You need to provide `getLocation` to the `history` router in environments where `window` does not exist.")}})}:o,l=e.start,f=e.dispose,h=e.push;return new rt({createURL:r,parseURL:i,writeDelay:c,windowTitle:s,getLocation:u,start:l,dispose:f,push:h})}function it(e){return it="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},it(e)}var at=["configure"];function ct(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function st(e){for(var t=1;t=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}(e,at)}function lt(){return{$$type:"ais.simple",stateToRoute:function(e){return Object.keys(e).reduce((function(t,r){return st(st({},t),{},ot({},r,ut(e[r])))}),{})},routeToState:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return Object.keys(e).reduce((function(t,r){return st(st({},t),{},ot({},r,ut(e[r])))}),{})}}}function ft(e){return e!==Object(e)}function ht(e,t){if(e===t)return!0;if(ft(e)||ft(t)||"function"==typeof e||"function"==typeof t)return e===t;if(Object.keys(e).length!==Object.keys(t).length)return!1;for(var r=0,n=Object.keys(e);r=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}(t,bt);return e.setQueryParameters(r)},Rt=function(e,t){return t.facets.reduce((function(e,t){return e.addFacet(t)}),e)},jt=function(e,t){return t.disjunctiveFacets.reduce((function(e,t){return e.addDisjunctiveFacet(t)}),e)},Pt=function(e,t){return e.setQueryParameters({hierarchicalFacets:t.hierarchicalFacets.reduce((function(e,t){var r=function(e,r){if(!Array.isArray(e))return-1;for(var n=0;n0?e.setQueryParameters({ruleContexts:r}):e},Zt=function(){for(var e=arguments.length,t=new Array(e),r=0;re.length)&&(t=e.length);for(var r=0,n=new Array(t);r2&&void 0!==arguments[2]?arguments[2]:{};return e.reduce((function(e,r){return yt(r)?e:r.getWidgetUiState||r.getWidgetState?r.getWidgetUiState?r.getWidgetUiState(e,t):r.getWidgetState(e,t):e}),r)}function Xt(e,t){var r=t.initialSearchParameters,n=function(e,t){if(null==e)return{};var r,n,i=function(e,t){if(null==e)return{};var r,n,i={},a=Object.keys(e);for(n=0;n=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}(t,Bt);return e.filter((function(e){return!yt(e)})).reduce((function(e,t){return t.getWidgetSearchParameters?t.getWidgetSearchParameters(e,n):e}),r)}function Jt(e){var t=e.filter(yt);0!==t.length&&t.forEach((function(e){var t=e.getHelper();Qt(t,{state:t.state.resetPage(),isPageReset:!0}),Jt(e.getWidgets())}))}function Vt(e){return e.filter(yt).reduce((function(e,t){return e.concat.apply(e,[{indexId:t.getIndexId(),results:t.getResults(),helper:t.getHelper()}].concat(Gt(Vt(t.getWidgets()))))}),[])}const Lt=function(e){if(void 0===e||void 0===e.indexName)throw new Error(Wt("The `indexName` option is required."));var t=e.indexName,r=e.indexId,n=void 0===r?t:r,i=[],a={},c=null,s=null,o=null,u=null,l=null;return{$$type:"ais.index",$$widgetType:"ais.index",getIndexName:function(){return t},getIndexId:function(){return n},getHelper:function(){return o},getResults:function(){var e;return null!==(e=u)&&void 0!==e&&e.lastResults?(u.lastResults._state=o.state,u.lastResults):null},getPreviousState:function(){return l},getScopedResults:function(){var e=this.getParent();return Vt(e?e.getWidgets():[this])},getParent:function(){return s},createURL:function(e){return c._createURL(Ut({},n,Ct(i,{searchParameters:e,helper:o})))},getWidgets:function(){return i},addWidgets:function(e){var t=this;if(!Array.isArray(e))throw new Error(Wt("The `addWidgets` method expects an array of widgets."));if(e.some((function(e){return"function"!=typeof e.init&&"function"!=typeof e.render})))throw new Error(Wt("The widget definition expects a `render` and/or an `init` method."));return i=i.concat(e),c&&Boolean(e.length)&&(Qt(o,{state:Xt(i,{uiState:a,initialSearchParameters:o.state}),_uiState:a}),e.forEach((function(e){e.getRenderState&&Yt({renderState:e.getRenderState(c.renderState[t.getIndexId()]||{},Ve(c,t,c._initialUiState)),instantSearchInstance:c,parent:t})})),e.forEach((function(e){e.init&&e.init(Ve(c,t,c._initialUiState))})),c.scheduleSearch()),this},removeWidgets:function(e){var t=this;if(!Array.isArray(e))throw new Error(Wt("The `removeWidgets` method expects an array of widgets."));if(e.some((function(e){return"function"!=typeof e.dispose})))throw new Error(Wt("The widget definition expects a `dispose` method."));if(i=i.filter((function(t){return-1===e.indexOf(t)})),c&&Boolean(e.length)){var r=e.reduce((function(e,r){return r.dispose({helper:o,state:e,parent:t})||e}),o.state);a=Ct(i,{searchParameters:r,helper:o}),o.setState(Xt(i,{uiState:a,initialSearchParameters:r})),i.length&&c.scheduleSearch()}return this},init:function(e){var r,f=this,h=e.instantSearchInstance,d=e.parent,p=e.uiState;if(null===o){c=h,s=d,a=p[n]||{};var m=h.mainHelper,g=Xt(i,{uiState:a,initialSearchParameters:new I.SearchParameters({index:t})});(o=I({},g.index,g)).search=function(){return h.onStateChange?(h.onStateChange({uiState:h.mainIndex.getWidgetUiState({}),setUiState:function(e){return h.setUiState(e,!1)}}),m):m.search()},o.searchWithoutTriggeringOnStateChange=function(){return m.search()},o.searchForFacetValues=function(e,t,r,n){var i=o.state.setQueryParameters(n);return m.searchForFacetValues(e,t,r,i)},u=m.derive((function(){return Zt.apply(void 0,Gt(function(e){for(var t=e.getParent(),r=[e.getHelper().state];null!==t;)r=[t.getHelper().state].concat(r),t=t.getParent();return r}(f)))}));var y=null===(r=h._initialResults)||void 0===r?void 0:r[this.getIndexId()];if(y){var A=new I.SearchResults(new I.SearchParameters(y.state),y.results);u.lastResults=A,o.lastResults=A}o.on("change",(function(e){e.isPageReset&&Jt(i)})),u.on("search",(function(){h.scheduleStalledRender()})),u.on("result",(function(e){var t=e.results;h.scheduleRender(),o.lastResults=t,l=t._state})),i.forEach((function(e){e.getRenderState&&Yt({renderState:e.getRenderState(h.renderState[f.getIndexId()]||{},Ve(h,f,p)),instantSearchInstance:h,parent:f})})),i.forEach((function(e){e.init&&e.init(Ve(h,f,p))})),o.on("change",(function(e){var t=e.state,r=e._uiState;a=Ct(i,{searchParameters:t,helper:o},r||{}),h.onStateChange||h.onInternalStateChange()})),y&&h.scheduleRender()}},render:function(e){var t=this,r=e.instantSearchInstance;this.getResults()&&("error"!==r.status||r.mainHelper.hasPendingRequests()||o.setState(l),i.forEach((function(e){e.getRenderState&&Yt({renderState:e.getRenderState(r.renderState[t.getIndexId()]||{},Le(r,t)),instantSearchInstance:r,parent:t})})),i.forEach((function(e){e.render&&e.render(Le(r,t))})))},dispose:function(){var e,t,r=this;i.forEach((function(e){e.dispose&&e.dispose({helper:o,state:o.state,parent:r})})),c=null,s=null,null===(e=o)||void 0===e||e.removeAllListeners(),o=null,null===(t=u)||void 0===t||t.detach(),u=null},getWidgetUiState:function(e){return i.filter(yt).reduce((function(e,t){return t.getWidgetUiState(e)}),zt(zt({},e),{},Ut({},n,zt(zt({},e[n]),a))))},getWidgetState:function(e){return this.getWidgetUiState(e)},getWidgetSearchParameters:function(e,t){var r=t.uiState;return Xt(i,{uiState:r,initialSearchParameters:e})},refreshUiState:function(){a=Ct(i,{searchParameters:this.getHelper().state,helper:this.getHelper()},a)},setIndexUiState:function(e){var t="function"==typeof e?e(a):e;c.setUiState((function(e){return zt(zt({},e),{},Ut({},n,t))}))}}};function Yt(e){var t=e.renderState,r=e.instantSearchInstance,n=e.parent,i=n?n.getIndexId():r.mainIndex.getIndexId();r.renderState=zt(zt({},r.renderState),{},Ut({},i,zt(zt({},r.renderState[i]),t)))}var qt=function(e){return function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},r=t.descendantName,n=t.modifierName,i=r?"-".concat(r):"",a=n?"--".concat(n):"";return"".concat("ais","-").concat(e).concat(i).concat(a)}};function Kt(e,t){return(Array.isArray(t)?t:t.split(".")).reduce((function(e,t){return e&&e[t]}),e)}var _t="",$t="",er=qt("Highlight");function tr(e){var t=_t,r=$t;return e.map((function(e){return e.isHighlighted?t+e.value+r:e.value})).join("")}RegExp(/[&<>"']/g.source);var rr={"&":"&","<":"<",">":">",""":'"',"'":"'"},nr=/&(amp|quot|lt|gt|#39);/g,ir=RegExp(nr.source),ar=new RegExp(/\w/i);function cr(e,t){var r,n,i,a=e[t],c=(null===(r=e[t+1])||void 0===r?void 0:r.isHighlighted)||!0,s=(null===(n=e[t-1])||void 0===n?void 0:n.isHighlighted)||!0;return ar.test((i=a.value)&&ir.test(i)?i.replace(nr,(function(e){return rr[e]})):i)||s!==c?a.isHighlighted:s}function sr(e){return sr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},sr(e)}function or(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function ur(e){for(var t=1;t')).replace(new RegExp($t,"g"),""))}(br(br({},JSON.parse(e)),{},{hit:this})))}catch(e){throw new Error('\nThe highlight helper expects a JSON object of the format:\n{ "attribute": "name", "highlightedTagName": "mark" }')}},reverseHighlight:function(e,t){try{return t(function(e){var t=e.attribute,r=e.highlightedTagName,n=void 0===r?"mark":r,i=e.hit,a=e.cssClasses,c=void 0===a?{}:a,s=(Kt(i._highlightResult,t)||{}).value,o=void 0===s?"":s,u=dr({descendantName:"highlighted"})+(c.highlighted?" ".concat(c.highlighted):"");return tr(fr(hr(o))).replace(new RegExp(_t,"g"),"<".concat(n,' class="').concat(u,'">')).replace(new RegExp($t,"g"),""))}(br(br({},JSON.parse(e)),{},{hit:this})))}catch(e){throw new Error('\n The reverseHighlight helper expects a JSON object of the format:\n { "attribute": "name", "highlightedTagName": "mark" }')}},snippet:function(e,t){try{return t(function(e){var t=e.attribute,r=e.highlightedTagName,n=void 0===r?"mark":r,i=e.hit,a=e.cssClasses,c=void 0===a?{}:a,s=(Kt(i._snippetResult,t)||{}).value,o=void 0===s?"":s,u=pr({descendantName:"highlighted"})+(c.highlighted?" ".concat(c.highlighted):"");return o.replace(new RegExp(_t,"g"),"<".concat(n,' class="').concat(u,'">')).replace(new RegExp($t,"g"),""))}(br(br({},JSON.parse(e)),{},{hit:this})))}catch(e){throw new Error('\nThe snippet helper expects a JSON object of the format:\n{ "attribute": "name", "highlightedTagName": "mark" }')}},reverseSnippet:function(e,t){try{return t(function(e){var t=e.attribute,r=e.highlightedTagName,n=void 0===r?"mark":r,i=e.hit,a=e.cssClasses,c=void 0===a?{}:a,s=(Kt(i._snippetResult,t)||{}).value,o=void 0===s?"":s,u=mr({descendantName:"highlighted"})+(c.highlighted?" ".concat(c.highlighted):"");return tr(fr(hr(o))).replace(new RegExp(_t,"g"),"<".concat(n,' class="').concat(u,'">')).replace(new RegExp($t,"g"),""))}(br(br({},JSON.parse(e)),{},{hit:this})))}catch(e){throw new Error('\n The reverseSnippet helper expects a JSON object of the format:\n { "attribute": "name", "highlightedTagName": "mark" }')}},insights:function(e,t){try{var r=JSON.parse(e),n=r.method,i=r.payload;return t(function(e,t){return function(e){var t,r=e.method,n=e.payload;if("object"!==gr(n))throw new Error("The insights helper expects the payload to be an object.");try{t=function(e){return btoa(encodeURIComponent(JSON.stringify(e)))}(n)}catch(e){throw new Error("Could not JSON serialize the payload object.")}return'data-insights-method="'.concat(r,'" data-insights-payload="').concat(t,'"')}({method:e,payload:t})}(n,br({objectIDs:[this.objectID]},i)))}catch(e){throw new Error('\nThe insights helper expects a JSON object of the format:\n{ "method": "method-name", "payload": { "eventName": "name of the event" } }')}}}}var Sr=Promise.resolve();function wr(e){var t=null,r=!1,n=function(){for(var n=arguments.length,i=new Array(n),a=0;a0&&void 0!==arguments[0])||arguments[0];null!==(e=t.mainHelper)&&void 0!==e&&e.hasPendingRequests()||(clearTimeout(t._searchStalledTimer),t._searchStalledTimer=null,r&&(t.status="idle",t.error=void 0)),t.mainIndex.render({instantSearchInstance:kr(t)}),t.emit("render")}))),Mr(kr(t),"onInternalStateChange",wr((function(){var e=t.mainIndex.getWidgetUiState({});t.middleware.forEach((function(t){t.instance.onStateChange({uiState:e})}))}))),t.setMaxListeners(100);var r=e.indexName,n=void 0===r?null:r,i=e.numberLocale,s=e.initialUiState,u=void 0===s?{}:s,l=e.routing,f=void 0===l?null:l,h=e.insights,d=void 0!==h&&h,p=e.searchFunction,m=e.stalledSearchDelay,g=void 0===m?200:m,y=e.searchClient,A=void 0===y?null:y,b=e.insightsClient,v=void 0===b?null:b,I=e.onStateChange,S=void 0===I?null:I;if(null===n)throw new Error(Dr("The `indexName` option is required."));if(null===A)throw new Error(Dr("The `searchClient` option is required."));if("function"!=typeof A.search)throw new Error("The `searchClient` must implement a `search` method.\n\nSee: https://www.algolia.com/doc/guides/building-search-ui/going-further/backend-search/in-depth/backend-instantsearch/js/");if("function"==typeof A.addAlgoliaAgent&&A.addAlgoliaAgent("instantsearch.js (".concat("4.55.0",")")),v&&"function"!=typeof v)throw new Error(Dr("The `insightsClient` option should be a function."));if(t.client=A,t.insightsClient=v,t.indexName=n,t.helper=null,t.mainHelper=null,t.mainIndex=Lt({indexName:n}),t.onStateChange=S,t.started=!1,t.templatesConfig={helpers:Ir({numberLocale:i}),compileOptions:{}},t._stalledSearchDelay=g,t._searchStalledTimer=null,t._createURL=Br,t._initialUiState=u,t._initialResults=null,p&&(t._searchFunction=p),t.sendEventToInsights=o,f){var w="boolean"==typeof f?{}:f;w.$$internal=!0,t.use(function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.router,r=void 0===t?nt():t,n=e.stateMapping,i=void 0===n?lt():n,a=e.$$internal,c=void 0!==a&&a;return function(e){var t=e.instantSearchInstance;t._createURL=function(e){var n=Object.keys(e).reduce((function(t,r){return mt(mt({},t),{},gt({},r,e[r]))}),t.mainIndex.getWidgetUiState({})),a=i.stateToRoute(n);return r.createURL(a)};var n=void 0,a=t._initialUiState;return{$$type:"ais.router({router:".concat(r.$$type||"__unknown__",", stateMapping:").concat(i.$$type||"__unknown__","})"),$$internal:c,onStateChange:function(e){var t=e.uiState,a=i.stateToRoute(t);void 0!==n&&ht(n,a)||(r.write(a),n=a)},subscribe:function(){t._initialUiState=mt(mt({},a),i.routeToState(r.read())),r.onUpdate((function(e){t.setUiState(i.routeToState(e))}))},started:function(){var e;null===(e=r.start)||void 0===e||e.call(r)},unsubscribe:function(){r.dispose()}}}}(w))}if(d){var R="boolean"==typeof d?{}:d;R.$$internal=!0,t.use(function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.insightsClient,r=e.insightsInitParams,n=e.onEvent,i=e.$$internal,a=void 0!==i&&i,c=t;t||null===t||Me((function(e){var t=e.window,r=t.AlgoliaAnalyticsObject||"aa";"string"==typeof r&&(c=t[r]),c||(t.AlgoliaAnalyticsObject=r,t[r]||(t[r]=function(){t[r].queue||(t[r].queue=[]);for(var e=arguments.length,n=new Array(e),i=0;i-1}),{fallback:function(){return!1}})&&t.use(function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.$$internal,r=void 0!==t&&t;return function(e){var t=e.instantSearchInstance,n={widgets:[]},i=document.createElement("meta"),a=document.querySelector("head");return i.name="instantsearch:widgets",{$$type:"ais.metadata",$$internal:r,onStateChange:function(){},subscribe:function(){setTimeout((function(){var e=t.client;n.ua=e.transporter&&e.transporter.userAgent?e.transporter.userAgent.value:e._ua,Ye(t.mainIndex.getWidgets(),t,n),t.middleware.forEach((function(e){return n.widgets.push({middleware:!0,type:e.instance.$$type,internal:e.instance.$$internal})})),i.content=JSON.stringify(n),a.appendChild(i)}),0)},started:function(){},unsubscribe:function(){i.remove()}}}}({$$internal:!0})),t}return t=c,r=[{key:"_isSearchStalled",get:function(){return"stalled"===this.status}},{key:"use",value:function(){for(var e=this,t=arguments.length,r=new Array(t),n=0;n0&&this.scheduleSearch();this.helper=this.mainIndex.getHelper(),this.started=!0,this.middleware.forEach((function(e){e.instance.started()}))}},{key:"dispose",value:function(){var e;this.scheduleSearch.cancel(),this.scheduleRender.cancel(),clearTimeout(this._searchStalledTimer),this.removeWidgets(this.mainIndex.getWidgets()),this.mainIndex.dispose(),this.started=!1,this.removeAllListeners(),null===(e=this.mainHelper)||void 0===e||e.removeAllListeners(),this.mainHelper=null,this.helper=null,this.middleware.forEach((function(e){e.instance.unsubscribe()}))}},{key:"scheduleStalledRender",value:function(){var e=this;this._searchStalledTimer||(this._searchStalledTimer=setTimeout((function(){e.status="stalled",e.scheduleRender()}),this._stalledSearchDelay))}},{key:"setUiState",value:function(e){var t=this,r=!(arguments.length>1&&void 0!==arguments[1])||arguments[1];if(!this.mainHelper)throw new Error(Dr("The `start` method needs to be called before `setUiState`."));this.mainIndex.refreshUiState();var n="function"==typeof e?e(this.mainIndex.getWidgetUiState({})):e;this.onStateChange&&r?this.onStateChange({uiState:n,setUiState:function(e){Rr("function"==typeof e?e(n):e,t.mainIndex),t.scheduleSearch(),t.onInternalStateChange()}}):(Rr(n,this.mainIndex),this.scheduleSearch(),this.onInternalStateChange())}},{key:"getUiState",value:function(){return this.started&&this.mainIndex.refreshUiState(),this.mainIndex.getWidgetUiState({})}},{key:"createURL",value:function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};if(!this.started)throw new Error(Dr("The `start` method needs to be called before `createURL`."));return this._createURL(e)}},{key:"refresh",value:function(){if(!this.mainHelper)throw new Error(Dr("The `start` method needs to be called before `refresh`."));this.mainHelper.clearCache().search()}}],r&&Er(t.prototype,r),Object.defineProperty(t,"prototype",{writable:!1}),c}(He);var zr=r(688),Ur=(0,y.createContext)(null);function Gr(){return(0,y.useContext)(Ur)}const Fr="6.38.1";function Wr(e,t){(null==t||t>e.length)&&(t=e.length);for(var r=0,n=new Array(t);r=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}(e,Vr));return r.started?y.createElement(k.Provider,{value:r},y.createElement(T.Provider,{value:r.mainIndex},t)):null}var Yr=["children"];function qr(e){var t,r,n,i,a,c,s,o,u,l=e.children,f=(t=function(e,t){if(null==e)return{};var r,n,i=function(e,t){if(null==e)return{};var r,n,i={},a=Object.keys(e);for(n=0;n=0||(i[r]=e[r]);return i}(e,t);if(Object.getOwnPropertySymbols){var a=Object.getOwnPropertySymbols(e);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(e,r)&&(i[r]=e[r])}return i}(e,Yr),r=Z(),n=Gr(),i=null==n?void 0:n.initialResults,a=H(),c=B(t),s=(0,y.useMemo)((function(){return Lt(c)}),[c]),o=s.getHelper(),u=Qr(),N((function(){u()}),[o,u]),z({widget:s,parentIndex:a,props:c,shouldSsr:Boolean(r||i)}),s);return null===f.getHelper()?null:y.createElement(T.Provider,{value:f},l)}function Kr(e){return Kr="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},Kr(e)}function _r(e){if(!function(e){return"object"===Kr(e)&&null!==e}(e)||"[object Object]"!==function(e){return null===e?void 0===e?"[object Undefined]":"[object Null]":Object.prototype.toString.call(e)}(e))return!1;if(null===Object.getPrototypeOf(e))return!0;for(var t=e;null!==Object.getPrototypeOf(t);)t=Object.getPrototypeOf(t);return Object.getPrototypeOf(e)===t}function $r(e){return $r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},$r(e)}function en(e,t){var r=Object.keys(e);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(e);t&&(n=n.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),r.push.apply(r,n)}return r}function tn(e){for(var t=1;t0&&void 0!==arguments[0]?arguments[0]:o,t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:o;return function(r){if(!r||!_r(r.searchParameters))throw new Error(nn("The `searchParameters` option expects an object."));var n={};return{$$type:"ais.configure",init:function(t){var r=t.instantSearchInstance;e(tn(tn({},this.getWidgetRenderState(t)),{},{instantSearchInstance:r}),!0)},render:function(t){var r=t.instantSearchInstance;e(tn(tn({},this.getWidgetRenderState(t)),{},{instantSearchInstance:r}),!1)},dispose:function(e){var n=e.state;return t(),an(n,r)},getRenderState:function(e,t){var r,n=this.getWidgetRenderState(t);return tn(tn({},e),{},{configure:tn(tn({},n),{},{widgetParams:tn(tn({},n.widgetParams),{},{searchParameters:Zt(new I.SearchParameters(null===(r=e.configure)||void 0===r?void 0:r.widgetParams.searchParameters),new I.SearchParameters(n.widgetParams.searchParameters)).getQueryParams()})})})},getWidgetRenderState:function(e){var t=e.helper;return n.refine||(n.refine=function(e){return function(t){var n=an(e.state,r),i=Zt(n,new I.SearchParameters(t));r.searchParameters=t,e.setState(i).search()}}(t)),{refine:n.refine,widgetParams:r}},getWidgetSearchParameters:function(e,t){var n=t.uiState;return Zt(e,new I.SearchParameters(tn(tn({},n.configure),r.searchParameters)))},getWidgetUiState:function(e){return tn(tn({},e),{},{configure:tn(tn({},e.configure),r.searchParameters)})}}}};function sn(e){return function(e,t){L(cn,{searchParameters:e},{$$widgetType:"ais.configure"})}(e),null}const on=t=>{const r=Te()("AVE0JWZU92","eef54890add97ea2583ff1e417ff86ea");return(0,e.createElement)("div",{className:"nfd-help-center"},(0,e.createElement)(Lr,{searchClient:r,indexName:"nfd_help_searchable_posts"},(0,e.createElement)(qr,{indexName:"nfd_help_searchable_posts"},(0,e.createElement)(sn,{hitsPerPage:3,getRankingInfo:!0}),(0,e.createElement)(Oe,null))))};var un,ln;function fn(){return fn=Object.assign?Object.assign.bind():function(e){for(var t=1;t{let{onClose:r}=t;return(0,e.useEffect)((()=>{const e=le();An(e)}),[]),(0,e.createElement)("div",{className:"modal"},(0,e.createElement)("div",{className:"modal-header"},(0,e.createElement)("h3",{className:"heading"},(0,e.createElement)("span",{className:"icon"},(0,e.createElement)(mn,null)),(0,ue.__)("Help Center","wp-module-help-center")),(0,e.createElement)("button",{className:"close-button",onClick:r},(0,e.createElement)("div",{className:"icon-button"},(0,e.createElement)(dn,null)))),(0,e.createElement)(on,{closeHelp:r}))},yn=document.getElementById("wpcontent"),An=e=>{yn.classList.toggle("wpcontent-container",e),document.getElementById("nfd-help-center").classList.toggle("help-container",e),(e=>{localStorage.setItem("helpVisible",e?"true":"false")})(e)};window.newfoldEmbeddedHelp={},window.newfoldEmbeddedHelp.toggleNFDLaunchedEmbeddedHelp=()=>{const e=le();Object.is(e,void 0)?An(!0):An(!e)},window.newfoldEmbeddedHelp.toggleNFDUnlaunchedEmbeddedHelp=function(){let e=document.getElementById("nfd-help-center");yn.removeChild(e),newfoldEmbeddedHelp.renderEmbeddedHelp()},(0,i.registerPlugin)("nfd-help-panel",{render:()=>(0,e.createElement)(t.PluginSidebar,{name:"nfd-help-sidebar",title:"Help Center",icon:(0,e.createElement)(mn,null)},(0,e.createElement)(on,null))}),window.newfoldEmbeddedHelp.renderEmbeddedHelp=function(){let t=document.createElement("div");t.id="nfd-help-center",t.style.display="none",yn.appendChild(t);const r=document.getElementById("nfd-help-center");(0,e.render)((0,e.createElement)(gn,{onClose:()=>{An(!1)}}),r)},newfoldEmbeddedHelp.renderEmbeddedHelp()})()})(); \ No newline at end of file +/******/ (() => { // webpackBootstrap +/******/ var __webpack_modules__ = ({ + +/***/ "./node_modules/@algolia/events/events.js": +/*!************************************************!*\ + !*** ./node_modules/@algolia/events/events.js ***! + \************************************************/ +/***/ ((module) => { + +// Copyright Joyent, Inc. and other Node contributors. +// +// Permission is hereby granted, free of charge, to any person obtaining a +// copy of this software and associated documentation files (the +// "Software"), to deal in the Software without restriction, including +// without limitation the rights to use, copy, modify, merge, publish, +// distribute, sublicense, and/or sell copies of the Software, and to permit +// persons to whom the Software is furnished to do so, subject to the +// following conditions: +// +// The above copyright notice and this permission notice shall be included +// in all copies or substantial portions of the Software. +// +// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS +// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN +// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, +// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR +// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE +// USE OR OTHER DEALINGS IN THE SOFTWARE. + +function EventEmitter() { + this._events = this._events || {}; + this._maxListeners = this._maxListeners || undefined; +} +module.exports = EventEmitter; + +// Backwards-compat with node 0.10.x +// EventEmitter.EventEmitter = EventEmitter; + +EventEmitter.prototype._events = undefined; +EventEmitter.prototype._maxListeners = undefined; + +// By default EventEmitters will print a warning if more than 10 listeners are +// added to it. This is a useful default which helps finding memory leaks. +EventEmitter.defaultMaxListeners = 10; + +// Obviously not all Emitters should be limited to 10. This function allows +// that to be increased. Set to zero for unlimited. +EventEmitter.prototype.setMaxListeners = function(n) { + if (!isNumber(n) || n < 0 || isNaN(n)) + throw TypeError('n must be a positive number'); + this._maxListeners = n; + return this; +}; + +EventEmitter.prototype.emit = function(type) { + var er, handler, len, args, i, listeners; + + if (!this._events) + this._events = {}; + + // If there is no 'error' event listener then throw. + if (type === 'error') { + if (!this._events.error || + (isObject(this._events.error) && !this._events.error.length)) { + er = arguments[1]; + if (er instanceof Error) { + throw er; // Unhandled 'error' event + } else { + // At least give some kind of context to the user + var err = new Error('Uncaught, unspecified "error" event. (' + er + ')'); + err.context = er; + throw err; + } + } + } + + handler = this._events[type]; + + if (isUndefined(handler)) + return false; + + if (isFunction(handler)) { + switch (arguments.length) { + // fast cases + case 1: + handler.call(this); + break; + case 2: + handler.call(this, arguments[1]); + break; + case 3: + handler.call(this, arguments[1], arguments[2]); + break; + // slower + default: + args = Array.prototype.slice.call(arguments, 1); + handler.apply(this, args); + } + } else if (isObject(handler)) { + args = Array.prototype.slice.call(arguments, 1); + listeners = handler.slice(); + len = listeners.length; + for (i = 0; i < len; i++) + listeners[i].apply(this, args); + } + + return true; +}; + +EventEmitter.prototype.addListener = function(type, listener) { + var m; + + if (!isFunction(listener)) + throw TypeError('listener must be a function'); + + if (!this._events) + this._events = {}; + + // To avoid recursion in the case that type === "newListener"! Before + // adding it to the listeners, first emit "newListener". + if (this._events.newListener) + this.emit('newListener', type, + isFunction(listener.listener) ? + listener.listener : listener); + + if (!this._events[type]) + // Optimize the case of one listener. Don't need the extra array object. + this._events[type] = listener; + else if (isObject(this._events[type])) + // If we've already got an array, just append. + this._events[type].push(listener); + else + // Adding the second element, need to change to array. + this._events[type] = [this._events[type], listener]; + + // Check for listener leak + if (isObject(this._events[type]) && !this._events[type].warned) { + if (!isUndefined(this._maxListeners)) { + m = this._maxListeners; + } else { + m = EventEmitter.defaultMaxListeners; + } + + if (m && m > 0 && this._events[type].length > m) { + this._events[type].warned = true; + console.error('(node) warning: possible EventEmitter memory ' + + 'leak detected. %d listeners added. ' + + 'Use emitter.setMaxListeners() to increase limit.', + this._events[type].length); + if (typeof console.trace === 'function') { + // not supported in IE 10 + console.trace(); + } + } + } + + return this; +}; + +EventEmitter.prototype.on = EventEmitter.prototype.addListener; + +EventEmitter.prototype.once = function(type, listener) { + if (!isFunction(listener)) + throw TypeError('listener must be a function'); + + var fired = false; + + function g() { + this.removeListener(type, g); + + if (!fired) { + fired = true; + listener.apply(this, arguments); + } + } + + g.listener = listener; + this.on(type, g); + + return this; +}; + +// emits a 'removeListener' event iff the listener was removed +EventEmitter.prototype.removeListener = function(type, listener) { + var list, position, length, i; + + if (!isFunction(listener)) + throw TypeError('listener must be a function'); + + if (!this._events || !this._events[type]) + return this; + + list = this._events[type]; + length = list.length; + position = -1; + + if (list === listener || + (isFunction(list.listener) && list.listener === listener)) { + delete this._events[type]; + if (this._events.removeListener) + this.emit('removeListener', type, listener); + + } else if (isObject(list)) { + for (i = length; i-- > 0;) { + if (list[i] === listener || + (list[i].listener && list[i].listener === listener)) { + position = i; + break; + } + } + + if (position < 0) + return this; + + if (list.length === 1) { + list.length = 0; + delete this._events[type]; + } else { + list.splice(position, 1); + } + + if (this._events.removeListener) + this.emit('removeListener', type, listener); + } + + return this; +}; + +EventEmitter.prototype.removeAllListeners = function(type) { + var key, listeners; + + if (!this._events) + return this; + + // not listening for removeListener, no need to emit + if (!this._events.removeListener) { + if (arguments.length === 0) + this._events = {}; + else if (this._events[type]) + delete this._events[type]; + return this; + } + + // emit removeListener for all listeners on all events + if (arguments.length === 0) { + for (key in this._events) { + if (key === 'removeListener') continue; + this.removeAllListeners(key); + } + this.removeAllListeners('removeListener'); + this._events = {}; + return this; + } + + listeners = this._events[type]; + + if (isFunction(listeners)) { + this.removeListener(type, listeners); + } else if (listeners) { + // LIFO order + while (listeners.length) + this.removeListener(type, listeners[listeners.length - 1]); + } + delete this._events[type]; + + return this; +}; + +EventEmitter.prototype.listeners = function(type) { + var ret; + if (!this._events || !this._events[type]) + ret = []; + else if (isFunction(this._events[type])) + ret = [this._events[type]]; + else + ret = this._events[type].slice(); + return ret; +}; + +EventEmitter.prototype.listenerCount = function(type) { + if (this._events) { + var evlistener = this._events[type]; + + if (isFunction(evlistener)) + return 1; + else if (evlistener) + return evlistener.length; + } + return 0; +}; + +EventEmitter.listenerCount = function(emitter, type) { + return emitter.listenerCount(type); +}; + +function isFunction(arg) { + return typeof arg === 'function'; +} + +function isNumber(arg) { + return typeof arg === 'number'; +} + +function isObject(arg) { + return typeof arg === 'object' && arg !== null; +} + +function isUndefined(arg) { + return arg === void 0; +} + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/HiiveEvent.js": +/*!*******************************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/HiiveEvent.js ***! + \*******************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "HiiveEvent": () => (/* binding */ HiiveEvent) +/* harmony export */ }); +/** + * Defines the structure of a Hiive analytics event. + * + * @class HiiveEvent + */ +class HiiveEvent { + /** + * Constructor for the HiiveEvent class. + * + * @param {string} category The category of the event (This actual value will depend on the URL you are reporting to). + * @param {string} action The action that triggered the event (The actual value will depend on the URL you are reporting to). + * @param {Object} data Data related to the event. + */ + constructor( category, action, data ) { + this.category = category; + this.action = action; + this.data = data; + } +} + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/index.js": +/*!**************************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/index.js ***! + \**************************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "HiiveEvent": () => (/* reexport safe */ _HiiveEvent__WEBPACK_IMPORTED_MODULE_0__.HiiveEvent) +/* harmony export */ }); +/* harmony import */ var _HiiveEvent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./HiiveEvent */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/HiiveEvent.js"); +// Exports related to Hiive events. + + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/index.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/index.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "HiiveAnalytics": () => (/* binding */ HiiveAnalytics), +/* harmony export */ "HiiveEvent": () => (/* reexport safe */ _events__WEBPACK_IMPORTED_MODULE_1__.HiiveEvent) +/* harmony export */ }); +/* harmony import */ var _wordpress_data__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/data */ "@wordpress/data"); +/* harmony import */ var _wordpress_data__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_data__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./events */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/index.js"); +/* harmony import */ var _store__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../store */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/index.js"); +/* harmony import */ var _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @wordpress/api-fetch */ "@wordpress/api-fetch"); +/* harmony import */ var _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_3__); + + + + + +/** + * Determines whether Hiive analytics have been initialized or not. + * + * @return {boolean} whether Hiive analytics have been initialized or not. + */ +const initialized = () => { + if ( true === window?.nfdUIAnalytics?.hiive ) { + return true; + } + return false; +}; + +/** + * Validates that the parameter is an instance of HiiveEvent. + * + * @param {Object} event Any valid JS Object. + * @return {boolean} whether the param is a valid HiiveEvent instance or not. + */ +const validate = ( event ) => { + if ( ! ( event instanceof _events__WEBPACK_IMPORTED_MODULE_1__.HiiveEvent ) ) { + return false; + } + + return true; +}; + +/** + * Initializes the module to send out Hiive analytics events. + * + * @param {Object} param0 Data to initialize Hiive analytics. + * @param {Object} param0.settings Settings that define the behavior of HiiveAnalytics. + * @param {Object} param0.settings.debounce Settings related to the debounce. + * @param {number} param0.settings.debounce.time The interval that must pass once an event has been tracked after which a batch request gets placed automatically to the batch URL. + * @param {Object} param0.settings.queue Settings related to the Hiive events queue. + * @param {number} param0.settings.queue.threshold The limit that the number of events in the queue must cross after which a batch request gets placed automatically to the batch URL. + * @param {Object} param0.urls Contains URL's to report analytics. + * @param {string} param0.urls.single The URL that can handle a single event. + * @param {string} param0.urls.batch The URL that can handle an array of events. + * @return {boolean} Whether the module was initialized or not. + */ +const initialize = ( { + urls: { single, batch } = {}, + settings: { debounce: { time } = {}, queue: { threshold = 100 } = {} } = {}, +} ) => { + // If the module is already initialized then skip initialization. + if ( initialized() ) { + return true; + } + + // If no reporting URL's are defined then fail initialization. + if ( ! ( single || batch ) ) { + return false; + } + + // Update Redux store with all the required data. + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveUrls( { + single, + batch, + } ); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveDebounceTime( time ); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveEventsQueueThreshold( threshold ); + + // This helps us quickly determine whether Hiive analytics have been enabled. + window.nfdUIAnalytics = { + hiive: true, + }; + + return true; +}; + +/** + * Tracks the event by putting it in a queue. + * + * @param {HiiveEvent} event The event object to track. + * @return {boolean} whether the event has been successfully queued for tracking or not. + */ +const track = ( event ) => { + // Do not perform any activity if the module has not been initialized or the event is not valid. + if ( ! ( initialized() && validate( event ) ) ) { + return false; + } + + // Add the event to a queue of tracked events. + const events = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.select)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).getHiiveEventsQueue(); + events.push( event ); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveEventsQueue( events ); + + // If the number of events in the queue have crossed the threshold then dispatch all of them. + const threshold = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.select)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).getHiiveEventsQueueThreshold(); + if ( threshold && threshold < events.length ) { + dispatchEvents(); + } + + // Reset the debounce setTimeout instance. + resetDebounceInstance(); + + return true; +}; + +/** + * Reports the event to urls.single defined during initialization. + * + * @param {HiiveEvent} event The event object to send. + * @return {Promise} whether the event has been successfully sent or not. + */ +const send = async ( event ) => { + // Do not perform any activity if the module has not been initialized or the event is not valid. + if ( ! ( initialized() && validate( event ) ) ) { + return false; + } + + const url = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.select)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).getHiiveSingleUrl(); + if ( ! url ) { + return false; + } + + try { + await _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_3___default()( { + url, + method: 'POST', + data: event, + } ); + } catch ( error ) { + console.error( error ); + return false; + } +}; + +/** + * Reports all the queued events to urls.batch defined during initialization. + * + * @return {Promise} whether or not all the events were sent to the batchUrl successfully. + */ +const dispatchEvents = async () => { + if ( ! initialized() ) { + return false; + } + + const url = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.select)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).getHiiveBatchUrl(); + if ( ! url ) { + return false; + } + + // If there are no events to report then return. + const events = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.select)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).getHiiveEventsQueue(); + if ( 0 === events.length ) { + return true; + } + + // Rare case: Do this so that any other dispatchEvents calls do not dispatch redundant data. + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveEventsQueue( [] ); + + try { + await _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_3___default()( { + url, + method: 'POST', + data: events, + } ); + } catch ( error ) { + // [TODO] Figure out a better error handling method and clear the queue. + console.error( error ); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveEventsQueue( events ); + } + + return true; +}; + +/** + * Resets the debounce instance countdown. + * + * @return {boolean} whether the reset occurred successfully or not. + */ +const resetDebounceInstance = () => { + const debounce = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.select)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).getHiiveDebounce(); + + if ( ! debounce.time ) { + return false; + } + + clearInterval( debounce.instance ); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveDebounceInstance( + setTimeout( () => { + dispatchEvents(); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveDebounceInstance( undefined ); + }, debounce.time ) + ); + return true; +}; + +/** + * Disables the debounce. + * + * @return {boolean} whether the debounce has been successfully disabled or not. + */ +const disableDebounce = () => { + const debounce = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.select)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).getHiiveDebounce(); + if ( debounce.instance ) { + clearInterval( debounce.instance ); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveDebounceInstance( undefined ); + (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.dispatch)( _store__WEBPACK_IMPORTED_MODULE_2__.store ).updateHiiveDebounceTime( undefined ); + } + return true; +}; + +const HiiveAnalytics = { + initialize, + initialized, + validate, + track, + send, + dispatchEvents, + disableDebounce, +}; + + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/index.js": +/*!*************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/index.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "HiiveAnalytics": () => (/* reexport safe */ _hiive__WEBPACK_IMPORTED_MODULE_0__.HiiveAnalytics), +/* harmony export */ "HiiveEvent": () => (/* reexport safe */ _hiive__WEBPACK_IMPORTED_MODULE_0__.HiiveEvent) +/* harmony export */ }); +/* harmony import */ var _hiive__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./hiive */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/index.js"); +// Exports for the Hiive Platform. + + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/actions.js": +/*!*********************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/actions.js ***! + \*********************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "updateHiiveDebounceInstance": () => (/* binding */ updateHiiveDebounceInstance), +/* harmony export */ "updateHiiveDebounceTime": () => (/* binding */ updateHiiveDebounceTime), +/* harmony export */ "updateHiiveEventsQueue": () => (/* binding */ updateHiiveEventsQueue), +/* harmony export */ "updateHiiveEventsQueueThreshold": () => (/* binding */ updateHiiveEventsQueueThreshold), +/* harmony export */ "updateHiiveUrls": () => (/* binding */ updateHiiveUrls) +/* harmony export */ }); +/** + * Update the Hiive URLs. + * + * @param {Object} urls The Hiive URLs. + * @return {Object} Type of action to perform with data. + */ +function updateHiiveUrls( urls ) { + return { + type: 'UPDATE_HIIVE_URLS', + urls, + }; +} + +/** + * Update the Hiive events queue. + * + * @param {Array} events An array of events to be queued. + * @return {Object} Type of action to perform with data. + */ +function updateHiiveEventsQueue( events ) { + return { + type: 'UPDATE_HIIVE_EVENTS_QUEUE', + events, + }; +} + +/** + * + * @param {number} threshold The threshold for the queue. + * @return {Object} Type of action to perform with data. + */ +function updateHiiveEventsQueueThreshold( threshold ) { + return { + type: 'UPDATE_HIIVE_EVENTS_QUEUE_THRESHOLD', + threshold, + }; +} + +/** + * Update the Hiive events dispatch debounce time. + * + * @param {number} debounceTime The time to wait. + * @return {Object} Type of action to perform with data. + */ +function updateHiiveDebounceTime( debounceTime ) { + return { + type: 'UPDATE_HIIVE_DEBOUNCE_TIME', + debounceTime, + }; +} + +/** + * Updates the Hiive debounce instance. + * + * @param {Object} instance A setTimeout instance of the debounce. + * @return {Object} Type of action to perform with data. + */ +function updateHiiveDebounceInstance( instance ) { + return { + type: 'UPDATE_HIIVE_DEBOUNCE_INSTANCE', + instance, + }; +} + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/constants.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/constants.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "STORE_NAME": () => (/* binding */ STORE_NAME) +/* harmony export */ }); +/** + * The name for the Redux store of this package. + */ +const STORE_NAME = 'newfold/ui-analytics'; + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/index.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/index.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "nfdUIAnalyticsStoreConfig": () => (/* binding */ nfdUIAnalyticsStoreConfig), +/* harmony export */ "store": () => (/* binding */ store) +/* harmony export */ }); +/* harmony import */ var _reducer__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./reducer */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/reducer.js"); +/* harmony import */ var _actions__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./actions */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/actions.js"); +/* harmony import */ var _selectors__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./selectors */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/selectors.js"); +/* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./constants */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/constants.js"); +/* harmony import */ var _wordpress_data__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! @wordpress/data */ "@wordpress/data"); +/* harmony import */ var _wordpress_data__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_wordpress_data__WEBPACK_IMPORTED_MODULE_4__); + + + + + + + +/** + * The Redux store configuration. + */ +const nfdUIAnalyticsStoreConfig = { + reducer: _reducer__WEBPACK_IMPORTED_MODULE_0__["default"], + actions: _actions__WEBPACK_IMPORTED_MODULE_1__, + selectors: _selectors__WEBPACK_IMPORTED_MODULE_2__, +}; + +const store = (0,_wordpress_data__WEBPACK_IMPORTED_MODULE_4__.createReduxStore)( _constants__WEBPACK_IMPORTED_MODULE_3__.STORE_NAME, nfdUIAnalyticsStoreConfig ); +(0,_wordpress_data__WEBPACK_IMPORTED_MODULE_4__.register)( store ); + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/reducer.js": +/*!*********************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/reducer.js ***! + \*********************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__), +/* harmony export */ "hiive": () => (/* binding */ hiive) +/* harmony export */ }); +/* harmony import */ var _wordpress_data__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/data */ "@wordpress/data"); +/* harmony import */ var _wordpress_data__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_data__WEBPACK_IMPORTED_MODULE_0__); + + +/** + * A reducer for Hiive related actions. + * + * @param {Object} state The current state of the store. + * @param {Object} action The action to be performed to change the state. + * @return {Object} state The new state of the store after the action is performed. + */ +function hiive( + state = { + urls: { + single: undefined, + batch: undefined, + }, + queue: { + events: [], + threshold: 100, + }, + debounce: { + time: undefined, + instance: undefined, + }, + }, + action +) { + switch ( action.type ) { + case 'UPDATE_HIIVE_URLS': + return { + ...state, + urls: { + single: action.urls.single, + batch: action.urls.batch, + }, + }; + case 'UPDATE_HIIVE_EVENTS_QUEUE': + return { + ...state, + queue: { + events: action.events, + threshold: state.queue.threshold, + }, + }; + case 'UPDATE_HIIVE_EVENTS_QUEUE_THRESHOLD': { + return { + ...state, + queue: { + events: state.queue.events, + threshold: action.threshold, + }, + }; + } + case 'UPDATE_HIIVE_DEBOUNCE_TIME': + return { + ...state, + debounce: { + time: action.debounceTime, + instance: state.debounce.instance, + }, + }; + case 'UPDATE_HIIVE_DEBOUNCE_INSTANCE': + return { + ...state, + debounce: { + time: state.debounce.time, + instance: action.instance, + }, + }; + } + return state; +} + +/** + * Combines all the reducers in this file. + */ +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ((0,_wordpress_data__WEBPACK_IMPORTED_MODULE_0__.combineReducers)( { + hiive, +} )); + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/selectors.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/selectors.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "getHiiveBatchUrl": () => (/* binding */ getHiiveBatchUrl), +/* harmony export */ "getHiiveDebounce": () => (/* binding */ getHiiveDebounce), +/* harmony export */ "getHiiveEventsQueue": () => (/* binding */ getHiiveEventsQueue), +/* harmony export */ "getHiiveEventsQueueThreshold": () => (/* binding */ getHiiveEventsQueueThreshold), +/* harmony export */ "getHiiveSingleUrl": () => (/* binding */ getHiiveSingleUrl) +/* harmony export */ }); +/** + * Retrieves all the queued Hiive events. + * + * @param {Object} state The current state of the redux store. + * @return {Array} events An array of events that are queued. + */ +function getHiiveEventsQueue( state ) { + return state.hiive.queue.events; +} + +/** + * + * @param {*} state The current state of the redux store. + * @return {Array} threshold Threshold of the queue. + */ +function getHiiveEventsQueueThreshold( state ) { + return state.hiive.queue.threshold; +} + +/** + * Retrieves the default Hiive URL. + * + * @param {Object} state The current state of the redux store. + * @return {string} The default URL in the store. + */ +function getHiiveSingleUrl( state ) { + return state.hiive.urls.single; +} + +/** + * Retrieves the batch Hiive URL. + * + * @param {*} state The current state of the redux store. + * @return {string} The batch URL in the store. + */ +function getHiiveBatchUrl( state ) { + return state.hiive.urls.batch; +} + +/** + * Retrieves debounce data. + * + * @param {Object} state The current state of the redux store. + * @return {Object} The debounce data. + */ +function getHiiveDebounce( state ) { + return state.hiive.debounce; +} + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/wp-module-ai/index.js": +/*!**********************************************************!*\ + !*** ./node_modules/@newfold-labs/wp-module-ai/index.js ***! + \**********************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* reexport safe */ _lib_moduleAI__WEBPACK_IMPORTED_MODULE_0__["default"]) +/* harmony export */ }); +/* harmony import */ var _lib_moduleAI__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./lib/moduleAI */ "./node_modules/@newfold-labs/wp-module-ai/lib/moduleAI.js"); + + + + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/wp-module-ai/lib/core/AISearch.js": +/*!**********************************************************************!*\ + !*** ./node_modules/@newfold-labs/wp-module-ai/lib/core/AISearch.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/api-fetch */ "@wordpress/api-fetch"); +/* harmony import */ var _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_0__); + + +const base = "newfold-ai/v1"; + +const AISearch = { + getSearchResult: (userPrompt, identifier, extra) => + _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_0___default()({ + path: base + "/search", + method: "POST", + data: { + user_prompt: userPrompt, + identifier: identifier, + extra: extra, + }, + }), +}; + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (AISearch); + + +/***/ }), + +/***/ "./node_modules/@newfold-labs/wp-module-ai/lib/moduleAI.js": +/*!*****************************************************************!*\ + !*** ./node_modules/@newfold-labs/wp-module-ai/lib/moduleAI.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _core_AISearch__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./core/AISearch */ "./node_modules/@newfold-labs/wp-module-ai/lib/core/AISearch.js"); + + +const moduleAI = { + search: _core_AISearch__WEBPACK_IMPORTED_MODULE_0__["default"], +} + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (moduleAI); + + +/***/ }), + +/***/ "./src/icons/close.svg": +/*!*****************************!*\ + !*** ./src/icons/close.svg ***! + \*****************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ReactComponent": () => (/* binding */ SvgClose), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__); +var _g, _defs; +function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } + +var SvgClose = function SvgClose(props) { + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("svg", _extends({ + width: 24, + height: 24, + fill: "none", + xmlns: "http://www.w3.org/2000/svg" + }, props), _g || (_g = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("g", { + clipPath: "url(#close_svg__a)" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("g", { + clipPath: "url(#close_svg__b)" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("path", { + fillRule: "evenodd", + clipRule: "evenodd", + d: "m12 13.06 3.712 3.713 1.06-1.06L13.06 12l3.713-3.712-1.061-1.06-3.713 3.711-3.712-3.712-1.06 1.06L10.939 12l-3.712 3.712 1.06 1.061L12 13.061Z", + fill: "#1E1E1E" + })))), _defs || (_defs = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("defs", null, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("clipPath", { + id: "close_svg__a" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("rect", { + width: 24, + height: 24, + rx: 2, + fill: "#fff" + })), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("clipPath", { + id: "close_svg__b" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("rect", { + width: 24, + height: 24, + rx: 2, + fill: "#fff" + }))))); +}; + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwXzYwNF8zMDE3KSI+CjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMV82MDRfMzAxNykiPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTExLjk5OTUgMTMuMDYwN0wxNS43MTE4IDE2Ljc3M0wxNi43NzI1IDE1LjcxMjNMMTMuMDYwMiAxMkwxNi43NzI1IDguMjg3NzJMMTUuNzExOSA3LjIyNzA2TDExLjk5OTUgMTAuOTM5NEw4LjI4NzIyIDcuMjI3MDVMNy4yMjY1NiA4LjI4NzcxTDEwLjkzODkgMTJMNy4yMjY1NyAxNS43MTIzTDguMjg3MjMgMTYuNzczTDExLjk5OTUgMTMuMDYwN1oiIGZpbGw9IiMxRTFFMUUiLz4KPC9nPgo8L2c+CjxkZWZzPgo8Y2xpcFBhdGggaWQ9ImNsaXAwXzYwNF8zMDE3Ij4KPHJlY3Qgd2lkdGg9IjI0IiBoZWlnaHQ9IjI0IiByeD0iMiIgZmlsbD0id2hpdGUiLz4KPC9jbGlwUGF0aD4KPGNsaXBQYXRoIGlkPSJjbGlwMV82MDRfMzAxNyI+CjxyZWN0IHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgcng9IjIiIGZpbGw9IndoaXRlIi8+CjwvY2xpcFBhdGg+CjwvZGVmcz4KPC9zdmc+Cg=="); + +/***/ }), + +/***/ "./src/icons/go.svg": +/*!**************************!*\ + !*** ./src/icons/go.svg ***! + \**************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ReactComponent": () => (/* binding */ SvgGo), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__); +function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } + +var SvgGo = function SvgGo(props) { + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("svg", _extends({ + height: 12, + width: 12, + xmlns: "http://www.w3.org/2000/svg", + viewBox: "-13.63 -13.63 254.36 254.36", + xmlSpace: "preserve", + fill: "#1D1D1F", + stroke: "#394150" + }, props), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("path", { + style: { + fill: "#010002" + }, + d: "m152.835 39.285-5.902 5.898 64.18 64.19H0v8.35h211.124l-64.191 64.179 5.902 5.909 74.261-74.261z" + })); +}; + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjEycHgiIHdpZHRoPSIxMnB4IiB2ZXJzaW9uPSIxLjEiIGlkPSJDYXBhXzEiCiAgICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgICB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmlld0JveD0iLTEzLjYzIC0xMy42MyAyNTQuMzYgMjU0LjM2IgogICAgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgZmlsbD0iIzFEMUQxRiIgc3Ryb2tlPSIjMzk0MTUwIj48ZyBpZD0iU1ZHUmVwb19iZ0NhcnJpZXIiIHN0cm9rZS13aWR0aD0iMCI+PC9nPjxnIGlkPSJTVkdSZXBvX3RyYWNlckNhcnJpZXIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PC9nPjxnIGlkPSJTVkdSZXBvX2ljb25DYXJyaWVyIj4gPGc+IDxnPiA8cG9seWdvbiBzdHlsZT0iZmlsbDojMDEwMDAyOyIgcG9pbnRzPSIxNTIuODM1LDM5LjI4NSAxNDYuOTMzLDQ1LjE4MyAyMTEuMTEzLDEwOS4zNzMgMCwxMDkuMzczIDAsMTE3LjcyMyAyMTEuMTI0LDExNy43MjMgMTQ2LjkzMywxODEuOTAyIDE1Mi44MzUsMTg3LjgxMSAyMjcuMDk2LDExMy41NSAiPjwvcG9seWdvbj4gPC9nPiA8L2c+IDwvZz48L3N2Zz4="); + +/***/ }), + +/***/ "./src/icons/help.svg": +/*!****************************!*\ + !*** ./src/icons/help.svg ***! + \****************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ReactComponent": () => (/* binding */ SvgHelp), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__); +var _path; +function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } + +var SvgHelp = function SvgHelp(props) { + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("svg", _extends({ + width: 36, + height: 37, + fill: "none", + xmlns: "http://www.w3.org/2000/svg" + }, props), _path || (_path = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("path", { + fillRule: "evenodd", + clipRule: "evenodd", + d: "M18 .902c-9.941 0-18 8.059-18 18s8.059 18 18 18h15.366A2.634 2.634 0 0 0 36 34.268V18.902c0-9.941-8.059-18-18-18Zm-.913 17.877c-.336.588-.504 1.286-.504 2.092v.832h3.326v-.404c0-.587.101-1.075.303-1.461.218-.387.613-.849 1.184-1.386.723-.689 1.269-1.344 1.638-1.966.37-.621.555-1.369.555-2.243 0-.89-.236-1.696-.706-2.419-.454-.739-1.092-1.319-1.915-1.739-.823-.42-1.764-.63-2.823-.63-1.41 0-2.587.395-3.528 1.185-.924.773-1.545 1.697-1.864 2.772l2.898 1.21a3.278 3.278 0 0 1 .907-1.462c.437-.403.991-.605 1.663-.605.638 0 1.15.185 1.537.555.387.352.58.79.58 1.31 0 .437-.118.823-.353 1.16-.218.335-.58.73-1.084 1.184-.856.756-1.461 1.428-1.814 2.015Zm-.428 8.644c.436.42.957.63 1.562.63.605 0 1.117-.21 1.537-.63.42-.437.63-.957.63-1.562 0-.605-.21-1.117-.63-1.538-.42-.42-.932-.63-1.537-.63-.605 0-1.126.21-1.562.63-.42.42-.63.933-.63 1.538 0 .604.21 1.125.63 1.562Z", + fill: "#196BDE" + }))); +}; + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzYiIGhlaWdodD0iMzciIHZpZXdCb3g9IjAgMCAzNiAzNyIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIgogICAgICAgIGQ9Ik0xOCAwLjkwMTg1NUM4LjA1ODg4IDAuOTAxODU1IDAgOC45NjA3MyAwIDE4LjkwMTlDMCAyOC44NDMgOC4wNTg4OCAzNi45MDE5IDE4IDM2LjkwMTlIMzMuMzY1OUMzNC44MjA3IDM2LjkwMTkgMzYgMzUuNzIyNSAzNiAzNC4yNjc3VjE4LjkwMTlDMzYgOC45NjA3MyAyNy45NDExIDAuOTAxODU1IDE4IDAuOTAxODU1Wk0xNy4wODcgMTguNzc5NUMxNi43NTEgMTkuMzY3NSAxNi41ODMgMjAuMDY0NyAxNi41ODMgMjAuODcxMVYyMS43MDI3SDE5LjkwOTRWMjEuMjk5NUMxOS45MDk0IDIwLjcxMTUgMjAuMDEwMiAyMC4yMjQzIDIwLjIxMTggMTkuODM3OUMyMC40MzAyIDE5LjQ1MTUgMjAuODI1IDE4Ljk4OTUgMjEuMzk2MiAxOC40NTE5QzIyLjExODYgMTcuNzYzMSAyMi42NjQ2IDE3LjEwNzkgMjMuMDM0MiAxNi40ODYzQzIzLjQwMzggMTUuODY0NyAyMy41ODg2IDE1LjExNzEgMjMuNTg4NiAxNC4yNDM1QzIzLjU4ODYgMTMuMzUzMSAyMy4zNTM0IDEyLjU0NjcgMjIuODgzIDExLjgyNDNDMjIuNDI5NCAxMS4wODUxIDIxLjc5MSAxMC41MDU1IDIwLjk2NzggMTAuMDg1NUMyMC4xNDQ2IDkuNjY1NDggMTkuMjAzOCA5LjQ1NTQ4IDE4LjE0NTQgOS40NTU0OEMxNi43MzQyIDkuNDU1NDggMTUuNTU4MiA5Ljg1MDI4IDE0LjYxNzQgMTAuNjM5OUMxMy42OTM0IDExLjQxMjcgMTMuMDcxOCAxMi4zMzY3IDEyLjc1MjYgMTMuNDExOUwxNS42NTA2IDE0LjYyMTVDMTUuODM1NCAxNC4wMzM1IDE2LjEzNzggMTMuNTQ2MyAxNi41NTc4IDEzLjE1OTlDMTYuOTk0NiAxMi43NTY3IDE3LjU0OSAxMi41NTUxIDE4LjIyMSAxMi41NTUxQzE4Ljg1OTQgMTIuNTU1MSAxOS4zNzE4IDEyLjczOTkgMTkuNzU4MiAxMy4xMDk1QzIwLjE0NDYgMTMuNDYyMyAyMC4zMzc4IDEzLjg5OTEgMjAuMzM3OCAxNC40MTk5QzIwLjMzNzggMTQuODU2NyAyMC4yMjAyIDE1LjI0MzEgMTkuOTg1IDE1LjU3OTFDMTkuNzY2NiAxNS45MTUxIDE5LjQwNTQgMTYuMzA5OSAxOC45MDE0IDE2Ljc2MzVDMTguMDQ0NiAxNy41MTk1IDE3LjQzOTggMTguMTkxNSAxNy4wODcgMTguNzc5NVpNMTYuNjU4NiAyNy40MjMxQzE3LjA5NTQgMjcuODQzMSAxNy42MTYyIDI4LjA1MzEgMTguMjIxIDI4LjA1MzFDMTguODI1OCAyOC4wNTMxIDE5LjMzODIgMjcuODQzMSAxOS43NTgyIDI3LjQyMzFDMjAuMTc4MiAyNi45ODYzIDIwLjM4ODIgMjYuNDY1NSAyMC4zODgyIDI1Ljg2MDdDMjAuMzg4MiAyNS4yNTU5IDIwLjE3ODIgMjQuNzQzNSAxOS43NTgyIDI0LjMyMzVDMTkuMzM4MiAyMy45MDM1IDE4LjgyNTggMjMuNjkzNSAxOC4yMjEgMjMuNjkzNUMxNy42MTYyIDIzLjY5MzUgMTcuMDk1NCAyMy45MDM1IDE2LjY1ODYgMjQuMzIzNUMxNi4yMzg2IDI0Ljc0MzUgMTYuMDI4NiAyNS4yNTU5IDE2LjAyODYgMjUuODYwN0MxNi4wMjg2IDI2LjQ2NTUgMTYuMjM4NiAyNi45ODYzIDE2LjY1ODYgMjcuNDIzMVoiCiAgICAgICAgZmlsbD0iIzE5NkJERSIgLz4KPC9zdmc+"); + +/***/ }), + +/***/ "./src/icons/loader.svg": +/*!******************************!*\ + !*** ./src/icons/loader.svg ***! + \******************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ReactComponent": () => (/* binding */ SvgLoader), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__); +var _rect, _rect2, _rect3, _rect4, _path, _defs; +function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } + +var SvgLoader = function SvgLoader(props) { + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("svg", _extends({ + width: 248, + height: 72, + fill: "none", + xmlns: "http://www.w3.org/2000/svg" + }, props), _rect || (_rect = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("rect", { + width: 89, + height: 14, + rx: 7, + fill: "url(#loader_svg__a)" + })), _rect2 || (_rect2 = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("rect", { + y: 22, + width: 233, + height: 10, + rx: 5, + fill: "url(#loader_svg__b)" + })), _rect3 || (_rect3 = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("rect", { + y: 38, + width: 248, + height: 10, + rx: 5, + fill: "url(#loader_svg__c)" + })), _rect4 || (_rect4 = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("rect", { + y: 54, + width: 140, + height: 10, + rx: 5, + fill: "url(#loader_svg__d)" + })), _path || (_path = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("path", { + stroke: "#EEE", + d: "M0 71.5h248" + })), _defs || (_defs = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("defs", null, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("linearGradient", { + id: "loader_svg__a", + x1: 89, + y1: 7, + x2: 0, + y2: 7, + gradientUnits: "userSpaceOnUse" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + stopColor: "#D9D9D9" + }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + offset: 1, + stopColor: "#D9D9D9", + stopOpacity: 0.3 + })), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("linearGradient", { + id: "loader_svg__b", + x1: 0, + y1: 27, + x2: 233, + y2: 27, + gradientUnits: "userSpaceOnUse" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + stopColor: "#D9D9D9" + }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + offset: 1, + stopColor: "#D9D9D9", + stopOpacity: 0.3 + })), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("linearGradient", { + id: "loader_svg__c", + x1: 0, + y1: 43, + x2: 266.243, + y2: 43, + gradientUnits: "userSpaceOnUse" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + stopColor: "#D9D9D9" + }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + offset: 0.516, + stopColor: "#D9D9D9", + stopOpacity: 0.2 + }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + offset: 1, + stopColor: "#D9D9D9", + stopOpacity: 0.8 + })), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("linearGradient", { + id: "loader_svg__d", + x1: 138.754, + y1: 59, + x2: 1.495, + y2: 59, + gradientUnits: "userSpaceOnUse" + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + stopColor: "#D9D9D9" + }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("stop", { + offset: 1, + stopColor: "#D9D9D9", + stopOpacity: 0.3 + }))))); +}; + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQ4IiBoZWlnaHQ9IjcyIiB2aWV3Qm94PSIwIDAgMjQ4IDcyIiBmaWxsPSJub25lIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgo8cmVjdCB3aWR0aD0iODkiIGhlaWdodD0iMTQiIHJ4PSI3IiBmaWxsPSJ1cmwoI3BhaW50MF9saW5lYXJfNjA0XzMwNDMpIi8+CjxyZWN0IHk9IjIyIiB3aWR0aD0iMjMzIiBoZWlnaHQ9IjEwIiByeD0iNSIgZmlsbD0idXJsKCNwYWludDFfbGluZWFyXzYwNF8zMDQzKSIvPgo8cmVjdCB5PSIzOCIgd2lkdGg9IjI0OCIgaGVpZ2h0PSIxMCIgcng9IjUiIGZpbGw9InVybCgjcGFpbnQyX2xpbmVhcl82MDRfMzA0MykiLz4KPHJlY3QgeT0iNTQiIHdpZHRoPSIxNDAiIGhlaWdodD0iMTAiIHJ4PSI1IiBmaWxsPSJ1cmwoI3BhaW50M19saW5lYXJfNjA0XzMwNDMpIi8+CjxsaW5lIHkxPSI3MS41IiB4Mj0iMjQ4IiB5Mj0iNzEuNSIgc3Ryb2tlPSIjRUVFRUVFIi8+CjxkZWZzPgo8bGluZWFyR3JhZGllbnQgaWQ9InBhaW50MF9saW5lYXJfNjA0XzMwNDMiIHgxPSI4OSIgeTE9IjcuMDAwMDEiIHgyPSIyLjQ2OTQ5ZS0wNyIgeTI9IjcuMDAwMDEiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agc3RvcC1jb2xvcj0iI0Q5RDlEOSIvPgo8c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiNEOUQ5RDkiIHN0b3Atb3BhY2l0eT0iMC4zIi8+CjwvbGluZWFyR3JhZGllbnQ+CjxsaW5lYXJHcmFkaWVudCBpZD0icGFpbnQxX2xpbmVhcl82MDRfMzA0MyIgeDE9IjEuNDM3NjJlLTA2IiB5MT0iMjYuOTk5OSIgeDI9IjIzMyIgeTI9IjI2Ljk5OTkiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agc3RvcC1jb2xvcj0iI0Q5RDlEOSIvPgo8c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiNEOUQ5RDkiIHN0b3Atb3BhY2l0eT0iMC4zIi8+CjwvbGluZWFyR3JhZGllbnQ+CjxsaW5lYXJHcmFkaWVudCBpZD0icGFpbnQyX2xpbmVhcl82MDRfMzA0MyIgeDE9Ii0xLjU3NTU4ZS0wNiIgeTE9IjQyLjk5OTkiIHgyPSIyNjYuMjQzIiB5Mj0iNDIuOTk5OSIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiPgo8c3RvcCBzdG9wLWNvbG9yPSIjRDlEOUQ5Ii8+CjxzdG9wIG9mZnNldD0iMC41MTU2MjUiIHN0b3AtY29sb3I9IiNEOUQ5RDkiIHN0b3Atb3BhY2l0eT0iMC4yIi8+CjxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iI0Q5RDlEOSIgc3RvcC1vcGFjaXR5PSIwLjgiLz4KPC9saW5lYXJHcmFkaWVudD4KPGxpbmVhckdyYWRpZW50IGlkPSJwYWludDNfbGluZWFyXzYwNF8zMDQzIiB4MT0iMTM4Ljc1NCIgeTE9IjU5IiB4Mj0iMS40OTQ2NiIgeTI9IjU5IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+CjxzdG9wIHN0b3AtY29sb3I9IiNEOUQ5RDkiLz4KPHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjRDlEOUQ5IiBzdG9wLW9wYWNpdHk9IjAuMyIvPgo8L2xpbmVhckdyYWRpZW50Pgo8L2RlZnM+Cjwvc3ZnPg=="); + +/***/ }), + +/***/ "./src/icons/no-result.svg": +/*!*********************************!*\ + !*** ./src/icons/no-result.svg ***! + \*********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ReactComponent": () => (/* binding */ SvgNoResult), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__); +var _path, _defs; +function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } + +var SvgNoResult = function SvgNoResult(props) { + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("svg", _extends({ + width: 302, + height: 186, + fill: "none", + xmlns: "http://www.w3.org/2000/svg", + xmlnsXlink: "http://www.w3.org/1999/xlink" + }, props), _path || (_path = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("path", { + fill: "url(#no-result_svg__a)", + d: "M0 0h302v186H0z" + })), _defs || (_defs = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("defs", null, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("pattern", { + id: "no-result_svg__a", + patternContentUnits: "objectBoundingBox", + width: 1, + height: 1 + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("use", { + xlinkHref: "#no-result_svg__b", + transform: "matrix(.0009 0 0 .00145 0 0)" + })), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("image", { + id: "no-result_svg__b", + width: 1121, + height: 690, + xlinkHref: "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABGEAAAKyCAYAAAB16sOJAAAACXBIWXMAAAsTAAALEwEAmpwYAABFUGlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNy4yLWMwMDAgNzkuMWI2NWE3OWI0LCAyMDIyLzA2LzEzLTIyOjAxOjAxICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczpkYz0iaHR0cDovL3B1cmwub3JnL2RjL2VsZW1lbnRzLzEuMS8iIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczpzdEV2dD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlRXZlbnQjIiB4bWxuczppbGx1c3RyYXRvcj0iaHR0cDovL25zLmFkb2JlLmNvbS9pbGx1c3RyYXRvci8xLjAvIiB4bWxuczp4bXBUUGc9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC90L3BnLyIgeG1sbnM6c3REaW09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9EaW1lbnNpb25zIyIgeG1sbnM6c3RGbnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9Gb250IyIgeG1sbnM6eG1wRz0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL2cvIiB4bWxuczpwZGY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vcGRmLzEuMy8iIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHhtcDpNZXRhZGF0YURhdGU9IjIwMjItMTEtMTRUMTY6MTY6MTItMDc6MDAiIHhtcDpNb2RpZnlEYXRlPSIyMDIyLTExLTE0VDE2OjE2OjEyLTA3OjAwIiB4bXA6Q3JlYXRlRGF0ZT0iMjAyMS0wMi0yMlQxMzoxMDowMi0wNzowMCIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBJbGx1c3RyYXRvciAyNS4yIChNYWNpbnRvc2gpIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOmNiMDdhMjNiLWJhNjgtNGQzMi1hN2RmLTMwYjRkYTk3YTE2MyIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo1NjViZDYxOC1kMzU3LTRjMDMtODI0MS1jMDA2YjI0OWM1YzciIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0idXVpZDo1RDIwODkyNDkzQkZEQjExOTE0QTg1OTBEMzE1MDhDOCIgeG1wTU06UmVuZGl0aW9uQ2xhc3M9InByb29mOnBkZiIgaWxsdXN0cmF0b3I6U3RhcnR1cFByb2ZpbGU9IlByaW50IiBpbGx1c3RyYXRvcjpDcmVhdG9yU3ViVG9vbD0iQUlSb2JpbiIgaWxsdXN0cmF0b3I6VHlwZT0iRG9jdW1lbnQiIHhtcFRQZzpIYXNWaXNpYmxlT3ZlcnByaW50PSJGYWxzZSIgeG1wVFBnOkhhc1Zpc2libGVUcmFuc3BhcmVuY3k9IlRydWUiIHhtcFRQZzpOUGFnZXM9IjEiIHBkZjpQcm9kdWNlcj0iQWRvYmUgUERGIGxpYnJhcnkgMTUuMDAiIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiPiA8ZGM6dGl0bGU+IDxyZGY6QWx0PiA8cmRmOmxpIHhtbDpsYW5nPSJ4LWRlZmF1bHQiPn5haS1hMzliYTc1MC04NzBjLTQ3NTgtYWZjNC02NzM5ZmJlNWNjMjJfPC9yZGY6bGk+IDwvcmRmOkFsdD4gPC9kYzp0aXRsZT4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InV1aWQ6NWVmYTMxODktY2NmNS1mMzRhLWI5ZGUtMjU5YmY4ODYxNDUzIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjU2NWJkNjE4LWQzNTctNGMwMy04MjQxLWMwMDZiMjQ5YzVjNyIgc3RSZWY6b3JpZ2luYWxEb2N1bWVudElEPSJ1dWlkOjVEMjA4OTI0OTNCRkRCMTE5MTRBODU5MEQzMTUwOEM4IiBzdFJlZjpyZW5kaXRpb25DbGFzcz0icHJvb2Y6cGRmIi8+IDx4bXBNTTpIaXN0b3J5PiA8cmRmOlNlcT4gPHJkZjpsaSBzdEV2dDphY3Rpb249InNhdmVkIiBzdEV2dDppbnN0YW5jZUlEPSJ4bXAuaWlkOjA1YjRlZDM3LThkMzItNGM0Ni05N2YwLTdiNjFlMzZhZmQ1MyIgc3RFdnQ6d2hlbj0iMjAxOC0xMC0zMFQxNjoyMzoyMi0wNjowMCIgc3RFdnQ6c29mdHdhcmVBZ2VudD0iQWRvYmUgSWxsdXN0cmF0b3IgQ0MgMjIuMSAoTWFjaW50b3NoKSIgc3RFdnQ6Y2hhbmdlZD0iLyIvPiA8cmRmOmxpIHN0RXZ0OmFjdGlvbj0ic2F2ZWQiIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6NTY1YmQ2MTgtZDM1Ny00YzAzLTgyNDEtYzAwNmIyNDljNWM3IiBzdEV2dDp3aGVuPSIyMDIwLTA5LTE0VDE2OjIxOjQyLTA2OjAwIiBzdEV2dDpzb2Z0d2FyZUFnZW50PSJBZG9iZSBJbGx1c3RyYXRvciAyNC4zIChNYWNpbnRvc2gpIiBzdEV2dDpjaGFuZ2VkPSIvIi8+IDxyZGY6bGkgc3RFdnQ6YWN0aW9uPSJjb252ZXJ0ZWQiIHN0RXZ0OnBhcmFtZXRlcnM9ImZyb20gYXBwbGljYXRpb24vcGRmIHRvIGFwcGxpY2F0aW9uL3ZuZC5hZG9iZS5waG90b3Nob3AiLz4gPHJkZjpsaSBzdEV2dDphY3Rpb249ImRlcml2ZWQiIHN0RXZ0OnBhcmFtZXRlcnM9ImNvbnZlcnRlZCBmcm9tIGFwcGxpY2F0aW9uL3ZuZC5hZG9iZS5waG90b3Nob3AgdG8gaW1hZ2UvcG5nIi8+IDxyZGY6bGkgc3RFdnQ6YWN0aW9uPSJzYXZlZCIgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDpjNzg0MDY0NC1iZTAwLTQ0NGItYTdmZC1iYjUxMmQ4NTBlMTAiIHN0RXZ0OndoZW49IjIwMjItMTEtMTRUMTY6MTI6MjEtMDc6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCAyMy41IChNYWNpbnRvc2gpIiBzdEV2dDpjaGFuZ2VkPSIvIi8+IDxyZGY6bGkgc3RFdnQ6YWN0aW9uPSJzYXZlZCIgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDpjYjA3YTIzYi1iYTY4LTRkMzItYTdkZi0zMGI0ZGE5N2ExNjMiIHN0RXZ0OndoZW49IjIwMjItMTEtMTRUMTY6MTY6MTItMDc6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCAyMy41IChNYWNpbnRvc2gpIiBzdEV2dDpjaGFuZ2VkPSIvIi8+IDwvcmRmOlNlcT4gPC94bXBNTTpIaXN0b3J5PiA8eG1wVFBnOk1heFBhZ2VTaXplIHN0RGltOnc9IjEyMjQuMDAwMDAwIiBzdERpbTpoPSI4OTcuNDg2NTY0IiBzdERpbTp1bml0PSJQb2ludHMiLz4gPHhtcFRQZzpGb250cz4gPHJkZjpCYWc+IDxyZGY6bGkgc3RGbnQ6Zm9udE5hbWU9Ik15cmlhZFByby1SZWd1bGFyIiBzdEZudDpmb250RmFtaWx5PSJNeXJpYWQgUHJvIiBzdEZudDpmb250RmFjZT0iUmVndWxhciIgc3RGbnQ6Zm9udFR5cGU9Ik9wZW4gVHlwZSIgc3RGbnQ6dmVyc2lvblN0cmluZz0iVmVyc2lvbiAyLjExNTtQUyAyLjAwMDtob3Rjb252IDEuMC44MTttYWtlb3RmLmxpYjIuNS42MzQwNiIgc3RGbnQ6Y29tcG9zaXRlPSJGYWxzZSIgc3RGbnQ6Zm9udEZpbGVOYW1lPSIuNjg1MS5vdGYiLz4gPHJkZjpsaSBzdEZudDpmb250TmFtZT0iT3BlblNhbnMtQm9sZCIgc3RGbnQ6Zm9udEZhbWlseT0iT3BlbiBTYW5zIiBzdEZudDpmb250RmFjZT0iQm9sZCIgc3RGbnQ6Zm9udFR5cGU9Ik9wZW4gVHlwZSIgc3RGbnQ6dmVyc2lvblN0cmluZz0iVmVyc2lvbiAxLjEwIiBzdEZudDpjb21wb3NpdGU9IkZhbHNlIiBzdEZudDpmb250RmlsZU5hbWU9Ik9wZW5TYW5zLUJvbGQudHRmIi8+IDwvcmRmOkJhZz4gPC94bXBUUGc6Rm9udHM+IDx4bXBUUGc6UGxhdGVOYW1lcz4gPHJkZjpTZXE+IDxyZGY6bGk+Q3lhbjwvcmRmOmxpPiA8cmRmOmxpPk1hZ2VudGE8L3JkZjpsaT4gPHJkZjpsaT5ZZWxsb3c8L3JkZjpsaT4gPHJkZjpsaT5CbGFjazwvcmRmOmxpPiA8L3JkZjpTZXE+IDwveG1wVFBnOlBsYXRlTmFtZXM+IDx4bXBUUGc6U3dhdGNoR3JvdXBzPiA8cmRmOlNlcT4gPHJkZjpsaT4gPHJkZjpEZXNjcmlwdGlvbiB4bXBHOmdyb3VwTmFtZT0iRGVmYXVsdCBTd2F0Y2ggR3JvdXAiIHhtcEc6Z3JvdXBUeXBlPSIwIj4gPHhtcEc6Q29sb3JhbnRzPiA8cmRmOlNlcT4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IldoaXRlIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjU1IiB4bXBHOmdyZWVuPSIyNTUiIHhtcEc6Ymx1ZT0iMjU1Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJCbGFjayIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjM1IiB4bXBHOmdyZWVuPSIzMSIgeG1wRzpibHVlPSIzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQ01ZSyBSZWQiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIyMzYiIHhtcEc6Z3JlZW49IjI4IiB4bXBHOmJsdWU9IjM2Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDTVlLIFllbGxvdyIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI1NSIgeG1wRzpncmVlbj0iMjQxIiB4bXBHOmJsdWU9IjAiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgR3JlZW4iIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSIxNjUiIHhtcEc6Ymx1ZT0iODEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgQ3lhbiIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjAiIHhtcEc6Z3JlZW49IjE3MyIgeG1wRzpibHVlPSIyMzgiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgQmx1ZSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjQ2IiB4bXBHOmdyZWVuPSI0OSIgeG1wRzpibHVlPSIxNDUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgTWFnZW50YSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIzNSIgeG1wRzpncmVlbj0iMCIgeG1wRzpibHVlPSIxMzkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTUgTT0xMDAgWT05MCBLPTEwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMTkwIiB4bXBHOmdyZWVuPSIzMCIgeG1wRzpibHVlPSI0NSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09OTAgWT04NSBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIyMzgiIHhtcEc6Z3JlZW49IjY0IiB4bXBHOmJsdWU9IjU0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT04MCBZPTk1IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI0MCIgeG1wRzpncmVlbj0iOTAiIHhtcEc6Ymx1ZT0iNDAiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MCBNPTUwIFk9MTAwIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI0NiIgeG1wRzpncmVlbj0iMTQ2IiB4bXBHOmJsdWU9IjMwIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT0zNSBZPTg1IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI1MCIgeG1wRzpncmVlbj0iMTc1IiB4bXBHOmJsdWU9IjY0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTUgTT0wIFk9OTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjQ5IiB4bXBHOmdyZWVuPSIyMzYiIHhtcEc6Ymx1ZT0iNDkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MjAgTT0wIFk9MTAwIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIxNCIgeG1wRzpncmVlbj0iMjIyIiB4bXBHOmJsdWU9IjM1Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTUwIE09MCBZPTEwMCBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxMzkiIHhtcEc6Z3JlZW49IjE5NyIgeG1wRzpibHVlPSI2MyIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz03NSBNPTAgWT0xMDAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iNTUiIHhtcEc6Z3JlZW49IjE3OSIgeG1wRzpibHVlPSI3NCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz04NSBNPTEwIFk9MTAwIEs9MTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSIxNDciIHhtcEc6Ymx1ZT0iNjkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9OTAgTT0zMCBZPTk1IEs9MzAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSIxMDQiIHhtcEc6Ymx1ZT0iNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NzUgTT0wIFk9NzUgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iNDEiIHhtcEc6Z3JlZW49IjE4MCIgeG1wRzpibHVlPSIxMTUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9ODAgTT0xMCBZPTQ1IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjAiIHhtcEc6Z3JlZW49IjE2NiIgeG1wRzpibHVlPSIxNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NzAgTT0xNSBZPTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMzgiIHhtcEc6Z3JlZW49IjE2OSIgeG1wRzpibHVlPSIyMjQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9ODUgTT01MCBZPTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjciIHhtcEc6Z3JlZW49IjExNyIgeG1wRzpibHVlPSIxODciLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTAwIE09OTUgWT01IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjQzIiB4bXBHOmdyZWVuPSI1NiIgeG1wRzpibHVlPSIxNDMiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTAwIE09MTAwIFk9MjUgSz0yNSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjM4IiB4bXBHOmdyZWVuPSIzNCIgeG1wRzpibHVlPSI5NyIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz03NSBNPTEwMCBZPTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMTAxIiB4bXBHOmdyZWVuPSI0NSIgeG1wRzpibHVlPSIxNDQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NTAgTT0xMDAgWT0wIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE0NCIgeG1wRzpncmVlbj0iMzkiIHhtcEc6Ymx1ZT0iMTQyIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTM1IE09MTAwIFk9MzUgSz0xMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE1OCIgeG1wRzpncmVlbj0iMzEiIHhtcEc6Ymx1ZT0iOTkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTAgTT0xMDAgWT01MCBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIyMTciIHhtcEc6Z3JlZW49IjI4IiB4bXBHOmJsdWU9IjkyIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT05NSBZPTIwIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIzNiIgeG1wRzpncmVlbj0iNDEiIHhtcEc6Ymx1ZT0iMTIzIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTI1IE09MjUgWT00MCBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxOTMiIHhtcEc6Z3JlZW49IjE4MCIgeG1wRzpibHVlPSIxNTQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NDAgTT00NSBZPTUwIEs9NSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE1NCIgeG1wRzpncmVlbj0iMTMyIiB4bXBHOmJsdWU9IjEyMSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz01MCBNPTUwIFk9NjAgSz0yNSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjExMyIgeG1wRzpncmVlbj0iMTAxIiB4bXBHOmJsdWU9Ijg4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTU1IE09NjAgWT02NSBLPTQwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iOTAiIHhtcEc6Z3JlZW49Ijc0IiB4bXBHOmJsdWU9IjY2Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTI1IE09NDAgWT02NSBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxOTUiIHhtcEc6Z3JlZW49IjE1MyIgeG1wRzpibHVlPSIxMDciLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MzAgTT01MCBZPTc1IEs9MTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxNjgiIHhtcEc6Z3JlZW49IjEyNCIgeG1wRzpibHVlPSI3OSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0zNSBNPTYwIFk9ODAgSz0yNSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjEzOCIgeG1wRzpncmVlbj0iOTMiIHhtcEc6Ymx1ZT0iNTkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NDAgTT02NSBZPTkwIEs9MzUiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxMTciIHhtcEc6Z3JlZW49Ijc2IiB4bXBHOmJsdWU9IjQwIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTQwIE09NzAgWT0xMDAgSz01MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9Ijk2IiB4bXBHOmdyZWVuPSI1NiIgeG1wRzpibHVlPSIxOSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz01MCBNPTcwIFk9ODAgSz03MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjU5IiB4bXBHOmdyZWVuPSIzNSIgeG1wRzpibHVlPSIyMCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz03MyBNPTQwIFk9MCBLPTAiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjcwIiB4bXBHOmdyZWVuPSIxMzQiIHhtcEc6Ymx1ZT0iMTk4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTYwIEc9ODEgQj0xMzMiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjYwIiB4bXBHOmdyZWVuPSI4MSIgeG1wRzpibHVlPSIxMzMiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTI2IEc9MTY3IEI9MjIzIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIxMjYiIHhtcEc6Z3JlZW49IjE2NSIgeG1wRzpibHVlPSIyMTUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTY1IEc9MjAzIEI9MjM5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIxNjYiIHhtcEc6Z3JlZW49IjIwMiIgeG1wRzpibHVlPSIyMzUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjA5IEc9MjI1IEI9MjQyIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyMDgiIHhtcEc6Z3JlZW49IjIyNSIgeG1wRzpibHVlPSIyNDEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjQ1IEc9MjQ3IEI9MjQ5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDQiIHhtcEc6Z3JlZW49IjI0NiIgeG1wRzpibHVlPSIyNDgiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjQ3IEc9MTY2IEI9MTA2IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDciIHhtcEc6Z3JlZW49IjE2NiIgeG1wRzpibHVlPSIxMDYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjUgRz0yOCBCPTYwIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNCIgeG1wRzpncmVlbj0iMjciIHhtcEc6Ymx1ZT0iNTkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9NzQgRz0xMDEgQj0xNjMiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9Ijc0IiB4bXBHOmdyZWVuPSIxMDEiIHhtcEc6Ymx1ZT0iMTYzIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTkzIEc9MTI1IEI9MTkwIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI5MyIgeG1wRzpncmVlbj0iMTI1IiB4bXBHOmJsdWU9IjE5MCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNTUgRz0yMDUgQj0zMyIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjU1IiB4bXBHOmdyZWVuPSIyMDUiIHhtcEc6Ymx1ZT0iMzIiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjA5IEc9MjExIEI9MjEyIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyMDkiIHhtcEc6Z3JlZW49IjIxMSIgeG1wRzpibHVlPSIyMTEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9Ikdsb2JhbCBDb2xvciIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjUxIiB4bXBHOmdyZWVuPSIyMDgiIHhtcEc6Ymx1ZT0iMjQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MCBHPTc2IEI9MTE3IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSI3NiIgeG1wRzpibHVlPSIxMTciLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTA0IEc9MjA0IEI9MjI5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIxMDUiIHhtcEc6Z3JlZW49IjIwMyIgeG1wRzpibHVlPSIyMjgiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjUyIEc9MTc4IEI9MzEiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjI1MSIgeG1wRzpncmVlbj0iMTc4IiB4bXBHOmJsdWU9IjI4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJQQU5UT05FIDI4MiBDIiB4bXBHOnR5cGU9IlNQT1QiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJMQUIiIHhtcEc6TD0iMTAuOTgwMzkyIiB4bXBHOkE9IjIiIHhtcEc6Qj0iLTI2Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJibHVzaCBjb3B5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDIiIHhtcEc6Z3JlZW49IjE1NiIgeG1wRzpibHVlPSIxNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTA1IEc9MjA5IEI9NTIiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjEwNSIgeG1wRzpncmVlbj0iMjA5IiB4bXBHOmJsdWU9IjUyIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTUgRz0xNjAgQj02OSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNSIgeG1wRzpncmVlbj0iMTYwIiB4bXBHOmJsdWU9IjY4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTU1IEc9MTg4IEI9MTU1IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI1NCIgeG1wRzpncmVlbj0iMTg4IiB4bXBHOmJsdWU9IjE1NCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj00MSBHPTQxIEI9MTA1IGNvcHkiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjQwIiB4bXBHOmdyZWVuPSI0MCIgeG1wRzpibHVlPSIxMDUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9NSBHPTE5NyBCPTIxOSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNSIgeG1wRzpncmVlbj0iMTk2IiB4bXBHOmJsdWU9IjIxOSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNTUgRz03MyBCPTk5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNTUiIHhtcEc6Z3JlZW49IjczIiB4bXBHOmJsdWU9Ijk4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTI1NSBHPTIwMyBCPTEzOCIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjU1IiB4bXBHOmdyZWVuPSIyMDIiIHhtcEc6Ymx1ZT0iMTM3Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTYxIEc9MTA2IEI9MjA0IDQiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjYxIiB4bXBHOmdyZWVuPSIxMDUiIHhtcEc6Ymx1ZT0iMjA0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJza2luIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDQiIHhtcEc6Z3JlZW49IjIwNyIgeG1wRzpibHVlPSIxOTEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9NDEgRz00MSBCPTEwNSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNDAiIHhtcEc6Z3JlZW49IjQwIiB4bXBHOmJsdWU9IjEwNSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yMTQgRz0xODQgQj0xNDEiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjIxNCIgeG1wRzpncmVlbj0iMTg0IiB4bXBHOmJsdWU9IjE0MCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNDAgRz0xOTUgQj0xNjgiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjIzOSIgeG1wRzpncmVlbj0iMTk0IiB4bXBHOmJsdWU9IjE2NyIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj02MSBHPTEwNiBCPTIwNCIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNjEiIHhtcEc6Z3JlZW49IjEwNSIgeG1wRzpibHVlPSIyMDQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9ImJsdXNoIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDIiIHhtcEc6Z3JlZW49IjE1NiIgeG1wRzpibHVlPSIxNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MyBHPTIyNCBCPTE5NyIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMyIgeG1wRzpncmVlbj0iMjIzIiB4bXBHOmJsdWU9IjE5NiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj01IEc9MTkzIEI9MjE0IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI0IiB4bXBHOmdyZWVuPSIxOTIiIHhtcEc6Ymx1ZT0iMjE0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTcwIEc9MTcyIEI9MTk1IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI3MCIgeG1wRzpncmVlbj0iMTcyIiB4bXBHOmJsdWU9IjE5NSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yMyBHPTIzIEI9NTEiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjIyIiB4bXBHOmdyZWVuPSIyMiIgeG1wRzpibHVlPSI1MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj02MSBHPTEwNiBCPTIwNCAyIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI3MSIgeG1wRzpncmVlbj0iMTA1IiB4bXBHOmJsdWU9IjE3OCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj02MSBHPTEwNiBCPTIwNCAzIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI3MSIgeG1wRzpncmVlbj0iMTA1IiB4bXBHOmJsdWU9IjE3OCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj00MSBHPTQxIEI9MTA1IGNvcHkgMiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNDEiIHhtcEc6Z3JlZW49IjQyIiB4bXBHOmJsdWU9IjEwNCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNTAgRz0xNzYgQj0yOSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjUwIiB4bXBHOmdyZWVuPSIxNzYiIHhtcEc6Ymx1ZT0iMjkiLz4gPC9yZGY6U2VxPiA8L3htcEc6Q29sb3JhbnRzPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6bGk+IDxyZGY6bGk+IDxyZGY6RGVzY3JpcHRpb24geG1wRzpncm91cE5hbWU9IkdyYXlzIiB4bXBHOmdyb3VwVHlwZT0iMSI+IDx4bXBHOkNvbG9yYW50cz4gPHJkZjpTZXE+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT0wIFk9MCBLPTEwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjM1IiB4bXBHOmdyZWVuPSIzMSIgeG1wRzpibHVlPSIzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz05MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjY0IiB4bXBHOmdyZWVuPSI2NCIgeG1wRzpibHVlPSI2NSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz04MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9Ijg4IiB4bXBHOmdyZWVuPSI4OSIgeG1wRzpibHVlPSI5MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz03MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjEwOSIgeG1wRzpncmVlbj0iMTEwIiB4bXBHOmJsdWU9IjExMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz02MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjEyOCIgeG1wRzpncmVlbj0iMTI5IiB4bXBHOmJsdWU9IjEzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz01MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE0NiIgeG1wRzpncmVlbj0iMTQ4IiB4bXBHOmJsdWU9IjE1MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz00MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE2NiIgeG1wRzpncmVlbj0iMTY4IiB4bXBHOmJsdWU9IjE3MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz0zMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE4NyIgeG1wRzpncmVlbj0iMTg5IiB4bXBHOmJsdWU9IjE5MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz0yMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIwOCIgeG1wRzpncmVlbj0iMjEwIiB4bXBHOmJsdWU9IjIxMSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz0xMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIzMCIgeG1wRzpncmVlbj0iMjMxIiB4bXBHOmJsdWU9IjIzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz01IiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjQxIiB4bXBHOmdyZWVuPSIyNDEiIHhtcEc6Ymx1ZT0iMjQyIi8+IDwvcmRmOlNlcT4gPC94bXBHOkNvbG9yYW50cz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOmxpPiA8cmRmOmxpPiA8cmRmOkRlc2NyaXB0aW9uIHhtcEc6Z3JvdXBOYW1lPSJCcmlnaHRzIiB4bXBHOmdyb3VwVHlwZT0iMSI+IDx4bXBHOkNvbG9yYW50cz4gPHJkZjpTZXE+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT0xMDAgWT0xMDAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjM2IiB4bXBHOmdyZWVuPSIyOCIgeG1wRzpibHVlPSIzNiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09NzUgWT0xMDAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjQx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" + })))); +}; + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAyIiBoZWlnaHQ9IjE4NiIgdmlld0JveD0iMCAwIDMwMiAxODYiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPgo8cmVjdCB3aWR0aD0iMzAyIiBoZWlnaHQ9IjE4NiIgZmlsbD0idXJsKCNwYXR0ZXJuMCkiLz4KPGRlZnM+CjxwYXR0ZXJuIGlkPSJwYXR0ZXJuMCIgcGF0dGVybkNvbnRlbnRVbml0cz0ib2JqZWN0Qm91bmRpbmdCb3giIHdpZHRoPSIxIiBoZWlnaHQ9IjEiPgo8dXNlIHhsaW5rOmhyZWY9IiNpbWFnZTBfMzEzXzIwNDgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0wLjAwMDMwMjMzMikgc2NhbGUoMC4wMDA4OTI2IDAuMDAxNDQ5MjgpIi8+CjwvcGF0dGVybj4KPGltYWdlIGlkPSJpbWFnZTBfMzEzXzIwNDgiIHdpZHRoPSIxMTIxIiBoZWlnaHQ9IjY5MCIgeGxpbms6aHJlZj0iZGF0YTppbWFnZS9wbmc7YmFzZTY0LGlWQk9SdzBLR2dvQUFBQU5TVWhFVWdBQUJHRUFBQUt5Q0FZQUFBQjE2c09KQUFBQUNYQklXWE1BQUFzVEFBQUxFd0VBbXB3WUFBQkZVR2xVV0hSWVRVdzZZMjl0TG1Ga2IySmxMbmh0Y0FBQUFBQUFQRDk0Y0dGamEyVjBJR0psWjJsdVBTTHZ1NzhpSUdsa1BTSlhOVTB3VFhCRFpXaHBTSHB5WlZONlRsUmplbXRqT1dRaVB6NGdQSGc2ZUcxd2JXVjBZU0I0Yld4dWN6cDRQU0poWkc5aVpUcHVjenB0WlhSaEx5SWdlRHA0YlhCMGF6MGlRV1J2WW1VZ1dFMVFJRU52Y21VZ055NHlMV013TURBZ056a3VNV0kyTldFM09XSTBMQ0F5TURJeUx6QTJMekV6TFRJeU9qQXhPakF4SUNBZ0lDQWdJQ0FpUGlBOGNtUm1PbEpFUmlCNGJXeHVjenB5WkdZOUltaDBkSEE2THk5M2QzY3Vkek11YjNKbkx6RTVPVGt2TURJdk1qSXRjbVJtTFhONWJuUmhlQzF1Y3lNaVBpQThjbVJtT2tSbGMyTnlhWEIwYVc5dUlISmtaanBoWW05MWREMGlJaUI0Yld4dWN6cGtZejBpYUhSMGNEb3ZMM0IxY213dWIzSm5MMlJqTDJWc1pXMWxiblJ6THpFdU1TOGlJSGh0Ykc1ek9uaHRjRDBpYUhSMGNEb3ZMMjV6TG1Ga2IySmxMbU52YlM5NFlYQXZNUzR3THlJZ2VHMXNibk02ZUcxd1RVMDlJbWgwZEhBNkx5OXVjeTVoWkc5aVpTNWpiMjB2ZUdGd0x6RXVNQzl0YlM4aUlIaHRiRzV6T25OMFVtVm1QU0pvZEhSd09pOHZibk11WVdSdlltVXVZMjl0TDNoaGNDOHhMakF2YzFSNWNHVXZVbVZ6YjNWeVkyVlNaV1lqSWlCNGJXeHVjenB6ZEVWMmREMGlhSFIwY0RvdkwyNXpMbUZrYjJKbExtTnZiUzk0WVhBdk1TNHdMM05VZVhCbEwxSmxjMjkxY21ObFJYWmxiblFqSWlCNGJXeHVjenBwYkd4MWMzUnlZWFJ2Y2owaWFIUjBjRG92TDI1ekxtRmtiMkpsTG1OdmJTOXBiR3gxYzNSeVlYUnZjaTh4TGpBdklpQjRiV3h1Y3pwNGJYQlVVR2M5SW1oMGRIQTZMeTl1Y3k1aFpHOWlaUzVqYjIwdmVHRndMekV1TUM5MEwzQm5MeUlnZUcxc2JuTTZjM1JFYVcwOUltaDBkSEE2THk5dWN5NWhaRzlpWlM1amIyMHZlR0Z3THpFdU1DOXpWSGx3WlM5RWFXMWxibk5wYjI1ekl5SWdlRzFzYm5NNmMzUkdiblE5SW1oMGRIQTZMeTl1Y3k1aFpHOWlaUzVqYjIwdmVHRndMekV1TUM5elZIbHdaUzlHYjI1MEl5SWdlRzFzYm5NNmVHMXdSejBpYUhSMGNEb3ZMMjV6TG1Ga2IySmxMbU52YlM5NFlYQXZNUzR3TDJjdklpQjRiV3h1Y3pwd1pHWTlJbWgwZEhBNkx5OXVjeTVoWkc5aVpTNWpiMjB2Y0dSbUx6RXVNeThpSUhodGJHNXpPbkJvYjNSdmMyaHZjRDBpYUhSMGNEb3ZMMjV6TG1Ga2IySmxMbU52YlM5d2FHOTBiM05vYjNBdk1TNHdMeUlnWkdNNlptOXliV0YwUFNKcGJXRm5aUzl3Ym1jaUlIaHRjRHBOWlhSaFpHRjBZVVJoZEdVOUlqSXdNakl0TVRFdE1UUlVNVFk2TVRZNk1USXRNRGM2TURBaUlIaHRjRHBOYjJScFpubEVZWFJsUFNJeU1ESXlMVEV4TFRFMFZERTJPakUyT2pFeUxUQTNPakF3SWlCNGJYQTZRM0psWVhSbFJHRjBaVDBpTWpBeU1TMHdNaTB5TWxReE16b3hNRG93TWkwd056b3dNQ0lnZUcxd09rTnlaV0YwYjNKVWIyOXNQU0pCWkc5aVpTQkpiR3gxYzNSeVlYUnZjaUF5TlM0eUlDaE5ZV05wYm5SdmMyZ3BJaUI0YlhCTlRUcEpibk4wWVc1alpVbEVQU0o0YlhBdWFXbGtPbU5pTURkaE1qTmlMV0poTmpndE5HUXpNaTFoTjJSbUxUTXdZalJrWVRrM1lURTJNeUlnZUcxd1RVMDZSRzlqZFcxbGJuUkpSRDBpZUcxd0xtUnBaRG8xTmpWaVpEWXhPQzFrTXpVM0xUUmpNRE10T0RJME1TMWpNREEyWWpJME9XTTFZemNpSUhodGNFMU5Pazl5YVdkcGJtRnNSRzlqZFcxbGJuUkpSRDBpZFhWcFpEbzFSREl3T0RreU5Ea3pRa1pFUWpFeE9URTBRVGcxT1RCRU16RTFNRGhET0NJZ2VHMXdUVTA2VW1WdVpHbDBhVzl1UTJ4aGMzTTlJbkJ5YjI5bU9uQmtaaUlnYVd4c2RYTjBjbUYwYjNJNlUzUmhjblIxY0ZCeWIyWnBiR1U5SWxCeWFXNTBJaUJwYkd4MWMzUnlZWFJ2Y2pwRGNtVmhkRzl5VTNWaVZHOXZiRDBpUVVsU2IySnBiaUlnYVd4c2RYTjBjbUYwYjNJNlZIbHdaVDBpUkc5amRXMWxiblFpSUhodGNGUlFaenBJWVhOV2FYTnBZbXhsVDNabGNuQnlhVzUwUFNKR1lXeHpaU0lnZUcxd1ZGQm5Pa2hoYzFacGMybGliR1ZVY21GdWMzQmhjbVZ1WTNrOUlsUnlkV1VpSUhodGNGUlFaenBPVUdGblpYTTlJakVpSUhCa1pqcFFjbTlrZFdObGNqMGlRV1J2WW1VZ1VFUkdJR3hwWW5KaGNua2dNVFV1TURBaUlIQm9iM1J2YzJodmNEcERiMnh2Y2sxdlpHVTlJak1pUGlBOFpHTTZkR2wwYkdVK0lEeHlaR1k2UVd4MFBpQThjbVJtT214cElIaHRiRHBzWVc1blBTSjRMV1JsWm1GMWJIUWlQbjVoYVMxaE16bGlZVGMxTUMwNE56QmpMVFEzTlRndFlXWmpOQzAyTnpNNVptSmxOV05qTWpKZlBDOXlaR1k2YkdrK0lEd3ZjbVJtT2tGc2RENGdQQzlrWXpwMGFYUnNaVDRnUEhodGNFMU5Pa1JsY21sMlpXUkdjbTl0SUhOMFVtVm1PbWx1YzNSaGJtTmxTVVE5SW5WMWFXUTZOV1ZtWVRNeE9Ea3RZMk5tTlMxbU16UmhMV0k1WkdVdE1qVTVZbVk0T0RZeE5EVXpJaUJ6ZEZKbFpqcGtiMk4xYldWdWRFbEVQU0o0YlhBdVpHbGtPalUyTldKa05qRTRMV1F6TlRjdE5HTXdNeTA0TWpReExXTXdNRFppTWpRNVl6VmpOeUlnYzNSU1pXWTZiM0pwWjJsdVlXeEViMk4xYldWdWRFbEVQU0oxZFdsa09qVkVNakE0T1RJME9UTkNSa1JDTVRFNU1UUkJPRFU1TUVRek1UVXdPRU00SWlCemRGSmxaanB5Wlc1a2FYUnBiMjVEYkdGemN6MGljSEp2YjJZNmNHUm1JaTgrSUR4NGJYQk5UVHBJYVhOMGIzSjVQaUE4Y21SbU9sTmxjVDRnUEhKa1pqcHNhU0J6ZEVWMmREcGhZM1JwYjI0OUluTmhkbVZrSWlCemRFVjJkRHBwYm5OMFlXNWpaVWxFUFNKNGJYQXVhV2xrT2pBMVlqUmxaRE0zTFRoa016SXROR00wTmkwNU4yWXdMVGRpTmpGbE16WmhabVExTXlJZ2MzUkZkblE2ZDJobGJqMGlNakF4T0MweE1DMHpNRlF4TmpveU16b3lNaTB3Tmpvd01DSWdjM1JGZG5RNmMyOW1kSGRoY21WQloyVnVkRDBpUVdSdlltVWdTV3hzZFhOMGNtRjBiM0lnUTBNZ01qSXVNU0FvVFdGamFXNTBiM05vS1NJZ2MzUkZkblE2WTJoaGJtZGxaRDBpTHlJdlBpQThjbVJtT214cElITjBSWFowT21GamRHbHZiajBpYzJGMlpXUWlJSE4wUlhaME9tbHVjM1JoYm1ObFNVUTlJbmh0Y0M1cGFXUTZOVFkxWW1RMk1UZ3RaRE0xTnkwMFl6QXpMVGd5TkRFdFl6QXdObUl5TkRsak5XTTNJaUJ6ZEVWMmREcDNhR1Z1UFNJeU1ESXdMVEE1TFRFMFZERTJPakl4T2pReUxUQTJPakF3SWlCemRFVjJkRHB6YjJaMGQyRnlaVUZuWlc1MFBTSkJaRzlpWlNCSmJHeDFjM1J5WVhSdmNpQXlOQzR6SUNoTllXTnBiblJ2YzJncElpQnpkRVYyZERwamFHRnVaMlZrUFNJdklpOCtJRHh5WkdZNmJHa2djM1JGZG5RNllXTjBhVzl1UFNKamIyNTJaWEowWldRaUlITjBSWFowT25CaGNtRnRaWFJsY25NOUltWnliMjBnWVhCd2JHbGpZWFJwYjI0dmNHUm1JSFJ2SUdGd2NHeHBZMkYwYVc5dUwzWnVaQzVoWkc5aVpTNXdhRzkwYjNOb2IzQWlMejRnUEhKa1pqcHNhU0J6ZEVWMmREcGhZM1JwYjI0OUltUmxjbWwyWldRaUlITjBSWFowT25CaGNtRnRaWFJsY25NOUltTnZiblpsY25SbFpDQm1jbTl0SUdGd2NHeHBZMkYwYVc5dUwzWnVaQzVoWkc5aVpTNXdhRzkwYjNOb2IzQWdkRzhnYVcxaFoyVXZjRzVuSWk4K0lEeHlaR1k2YkdrZ2MzUkZkblE2WVdOMGFXOXVQU0p6WVhabFpDSWdjM1JGZG5RNmFXNXpkR0Z1WTJWSlJEMGllRzF3TG1scFpEcGpOemcwTURZME5DMWlaVEF3TFRRME5HSXRZVGRtWkMxaVlqVXhNbVE0TlRCbE1UQWlJSE4wUlhaME9uZG9aVzQ5SWpJd01qSXRNVEV0TVRSVU1UWTZNVEk2TWpFdE1EYzZNREFpSUhOMFJYWjBPbk52Wm5SM1lYSmxRV2RsYm5ROUlrRmtiMkpsSUZCb2IzUnZjMmh2Y0NBeU15NDFJQ2hOWVdOcGJuUnZjMmdwSWlCemRFVjJkRHBqYUdGdVoyVmtQU0l2SWk4K0lEeHlaR1k2YkdrZ2MzUkZkblE2WVdOMGFXOXVQU0p6WVhabFpDSWdjM1JGZG5RNmFXNXpkR0Z1WTJWSlJEMGllRzF3TG1scFpEcGpZakEzWVRJellpMWlZVFk0TFRSa016SXRZVGRrWmkwek1HSTBaR0U1TjJFeE5qTWlJSE4wUlhaME9uZG9aVzQ5SWpJd01qSXRNVEV0TVRSVU1UWTZNVFk2TVRJdE1EYzZNREFpSUhOMFJYWjBPbk52Wm5SM1lYSmxRV2RsYm5ROUlrRmtiMkpsSUZCb2IzUnZjMmh2Y0NBeU15NDFJQ2hOWVdOcGJuUnZjMmdwSWlCemRFVjJkRHBqYUdGdVoyVmtQU0l2SWk4K0lEd3ZjbVJtT2xObGNUNGdQQzk0YlhCTlRUcElhWE4wYjNKNVBpQThlRzF3VkZCbk9rMWhlRkJoWjJWVGFYcGxJSE4wUkdsdE9uYzlJakV5TWpRdU1EQXdNREF3SWlCemRFUnBiVHBvUFNJNE9UY3VORGcyTlRZMElpQnpkRVJwYlRwMWJtbDBQU0pRYjJsdWRITWlMejRnUEhodGNGUlFaenBHYjI1MGN6NGdQSEprWmpwQ1lXYytJRHh5WkdZNmJHa2djM1JHYm5RNlptOXVkRTVoYldVOUlrMTVjbWxoWkZCeWJ5MVNaV2QxYkdGeUlpQnpkRVp1ZERwbWIyNTBSbUZ0YVd4NVBTSk5lWEpwWVdRZ1VISnZJaUJ6ZEVadWREcG1iMjUwUm1GalpUMGlVbVZuZFd4aGNpSWdjM1JHYm5RNlptOXVkRlI1Y0dVOUlrOXdaVzRnVkhsd1pTSWdjM1JHYm5RNmRtVnljMmx2YmxOMGNtbHVaejBpVm1WeWMybHZiaUF5TGpFeE5UdFFVeUF5TGpBd01EdG9iM1JqYjI1MklERXVNQzQ0TVR0dFlXdGxiM1JtTG14cFlqSXVOUzQyTXpRd05pSWdjM1JHYm5RNlkyOXRjRzl6YVhSbFBTSkdZV3h6WlNJZ2MzUkdiblE2Wm05dWRFWnBiR1ZPWVcxbFBTSXVOamcxTVM1dmRHWWlMejRnUEhKa1pqcHNhU0J6ZEVadWREcG1iMjUwVG1GdFpUMGlUM0JsYmxOaGJuTXRRbTlzWkNJZ2MzUkdiblE2Wm05dWRFWmhiV2xzZVQwaVQzQmxiaUJUWVc1eklpQnpkRVp1ZERwbWIyNTBSbUZqWlQwaVFtOXNaQ0lnYzNSR2JuUTZabTl1ZEZSNWNHVTlJazl3Wlc0Z1ZIbHdaU0lnYzNSR2JuUTZkbVZ5YzJsdmJsTjBjbWx1WnowaVZtVnljMmx2YmlBeExqRXdJaUJ6ZEVadWREcGpiMjF3YjNOcGRHVTlJa1poYkhObElpQnpkRVp1ZERwbWIyNTBSbWxzWlU1aGJXVTlJazl3Wlc1VFlXNXpMVUp2YkdRdWRIUm1JaTgrSUR3dmNtUm1Pa0poWno0Z1BDOTRiWEJVVUdjNlJtOXVkSE0rSUR4NGJYQlVVR2M2VUd4aGRHVk9ZVzFsY3o0Z1BISmtaanBUWlhFK0lEeHlaR1k2YkdrK1EzbGhiand2Y21SbU9teHBQaUE4Y21SbU9teHBQazFoWjJWdWRHRThMM0prWmpwc2FUNGdQSEprWmpwc2FUNVpaV3hzYjNjOEwzSmtaanBzYVQ0Z1BISmtaanBzYVQ1Q2JHRmphend2Y21SbU9teHBQaUE4TDNKa1pqcFRaWEUrSUR3dmVHMXdWRkJuT2xCc1lYUmxUbUZ0WlhNK0lEeDRiWEJVVUdjNlUzZGhkR05vUjNKdmRYQnpQaUE4Y21SbU9sTmxjVDRnUEhKa1pqcHNhVDRnUEhKa1pqcEVaWE5qY21sd2RHbHZiaUI0YlhCSE9tZHliM1Z3VG1GdFpUMGlSR1ZtWVhWc2RDQlRkMkYwWTJnZ1IzSnZkWEFpSUhodGNFYzZaM0p2ZFhCVWVYQmxQU0l3SWo0Z1BIaHRjRWM2UTI5c2IzSmhiblJ6UGlBOGNtUm1PbE5sY1Q0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxkb2FYUmxJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTWpVMUlpQjRiWEJIT21keVpXVnVQU0l5TlRVaUlIaHRjRWM2WW14MVpUMGlNalUxSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKQ2JHRmpheUlnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpNMUlpQjRiWEJIT21keVpXVnVQU0l6TVNJZ2VHMXdSenBpYkhWbFBTSXpNaUl2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUTAxWlN5QlNaV1FpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeU16WWlJSGh0Y0VjNlozSmxaVzQ5SWpJNElpQjRiWEJIT21Kc2RXVTlJak0ySWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFRWbExJRmxsYkd4dmR5SWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakkxTlNJZ2VHMXdSenBuY21WbGJqMGlNalF4SWlCNGJYQkhPbUpzZFdVOUlqQWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa05OV1VzZ1IzSmxaVzRpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJd0lpQjRiWEJIT21keVpXVnVQU0l4TmpVaUlIaHRjRWM2WW14MVpUMGlPREVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtOTldVc2dRM2xoYmlJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqQWlJSGh0Y0VjNlozSmxaVzQ5SWpFM015SWdlRzF3UnpwaWJIVmxQU0l5TXpnaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTk5XVXNnUW14MVpTSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJalEySWlCNGJYQkhPbWR5WldWdVBTSTBPU0lnZUcxd1J6cGliSFZsUFNJeE5EVWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa05OV1VzZ1RXRm5aVzUwWVNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqSXpOU0lnZUcxd1J6cG5jbVZsYmowaU1DSWdlRzF3UnpwaWJIVmxQU0l4TXpraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNVFVnVFQweE1EQWdXVDA1TUNCTFBURXdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTVRrd0lpQjRiWEJIT21keVpXVnVQU0l6TUNJZ2VHMXdSenBpYkhWbFBTSTBOU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowd0lFMDlPVEFnV1QwNE5TQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeU16Z2lJSGh0Y0VjNlozSmxaVzQ5SWpZMElpQjRiWEJIT21Kc2RXVTlJalUwSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUQWdUVDA0TUNCWlBUazFJRXM5TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqSTBNQ0lnZUcxd1J6cG5jbVZsYmowaU9UQWlJSGh0Y0VjNllteDFaVDBpTkRBaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNQ0JOUFRVd0lGazlNVEF3SUVzOU1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakkwTmlJZ2VHMXdSenBuY21WbGJqMGlNVFEySWlCNGJYQkhPbUpzZFdVOUlqTXdJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRBZ1RUMHpOU0JaUFRnMUlFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpJMU1DSWdlRzF3UnpwbmNtVmxiajBpTVRjMUlpQjRiWEJIT21Kc2RXVTlJalkwSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUVWdUVDB3SUZrOU9UQWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU1qUTVJaUI0YlhCSE9tZHlaV1Z1UFNJeU16WWlJSGh0Y0VjNllteDFaVDBpTkRraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNakFnVFQwd0lGazlNVEF3SUVzOU1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakl4TkNJZ2VHMXdSenBuY21WbGJqMGlNakl5SWlCNGJYQkhPbUpzZFdVOUlqTTFJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRVd0lFMDlNQ0JaUFRFd01DQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeE16a2lJSGh0Y0VjNlozSmxaVzQ5SWpFNU55SWdlRzF3UnpwaWJIVmxQU0kyTXlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MDNOU0JOUFRBZ1dUMHhNREFnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlOVFVpSUhodGNFYzZaM0psWlc0OUlqRTNPU0lnZUcxd1J6cGliSFZsUFNJM05DSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejA0TlNCTlBURXdJRms5TVRBd0lFczlNVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJd0lpQjRiWEJIT21keVpXVnVQU0l4TkRjaUlIaHRjRWM2WW14MVpUMGlOamtpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU9UQWdUVDB6TUNCWlBUazFJRXM5TXpBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2Y21Wa1BTSXdJaUI0YlhCSE9tZHlaV1Z1UFNJeE1EUWlJSGh0Y0VjNllteDFaVDBpTlRZaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlOelVnVFQwd0lGazlOelVnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlOREVpSUhodGNFYzZaM0psWlc0OUlqRTRNQ0lnZUcxd1J6cGliSFZsUFNJeE1UVWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa005T0RBZ1RUMHhNQ0JaUFRRMUlFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpBaUlIaHRjRWM2WjNKbFpXNDlJakUyTmlJZ2VHMXdSenBpYkhWbFBTSXhOVFlpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU56QWdUVDB4TlNCWlBUQWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU16Z2lJSGh0Y0VjNlozSmxaVzQ5SWpFMk9TSWdlRzF3UnpwaWJIVmxQU0l5TWpRaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlPRFVnVFQwMU1DQlpQVEFnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlNamNpSUhodGNFYzZaM0psWlc0OUlqRXhOeUlnZUcxd1J6cGliSFZsUFNJeE9EY2lMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa005TVRBd0lFMDlPVFVnV1QwMUlFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpReklpQjRiWEJIT21keVpXVnVQU0kxTmlJZ2VHMXdSenBpYkhWbFBTSXhORE1pTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU1UQXdJRTA5TVRBd0lGazlNalVnU3oweU5TSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJak00SWlCNGJYQkhPbWR5WldWdVBTSXpOQ0lnZUcxd1J6cGliSFZsUFNJNU55SXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejAzTlNCTlBURXdNQ0JaUFRBZ1N6MHdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTVRBeElpQjRiWEJIT21keVpXVnVQU0kwTlNJZ2VHMXdSenBpYkhWbFBTSXhORFFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU5UQWdUVDB4TURBZ1dUMHdJRXM5TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRTBOQ0lnZUcxd1J6cG5jbVZsYmowaU16a2lJSGh0Y0VjNllteDFaVDBpTVRReUlpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSkRQVE0xSUUwOU1UQXdJRms5TXpVZ1N6MHhNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpFMU9DSWdlRzF3UnpwbmNtVmxiajBpTXpFaUlIaHRjRWM2WW14MVpUMGlPVGtpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU1UQWdUVDB4TURBZ1dUMDFNQ0JMUFRBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2Y21Wa1BTSXlNVGNpSUhodGNFYzZaM0psWlc0OUlqSTRJaUI0YlhCSE9tSnNkV1U5SWpreUlpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSkRQVEFnVFQwNU5TQlpQVEl3SUVzOU1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakl6TmlJZ2VHMXdSenBuY21WbGJqMGlOREVpSUhodGNFYzZZbXgxWlQwaU1USXpJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRJMUlFMDlNalVnV1QwME1DQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeE9UTWlJSGh0Y0VjNlozSmxaVzQ5SWpFNE1DSWdlRzF3UnpwaWJIVmxQU0l4TlRRaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlOREFnVFQwME5TQlpQVFV3SUVzOU5TSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakUxTkNJZ2VHMXdSenBuY21WbGJqMGlNVE15SWlCNGJYQkhPbUpzZFdVOUlqRXlNU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowMU1DQk5QVFV3SUZrOU5qQWdTejB5TlNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRXhNeUlnZUcxd1J6cG5jbVZsYmowaU1UQXhJaUI0YlhCSE9tSnNkV1U5SWpnNElpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSkRQVFUxSUUwOU5qQWdXVDAyTlNCTFBUUXdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpT1RBaUlIaHRjRWM2WjNKbFpXNDlJamMwSWlCNGJYQkhPbUpzZFdVOUlqWTJJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRJMUlFMDlOREFnV1QwMk5TQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeE9UVWlJSGh0Y0VjNlozSmxaVzQ5SWpFMU15SWdlRzF3UnpwaWJIVmxQU0l4TURjaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNekFnVFQwMU1DQlpQVGMxSUVzOU1UQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmNtVmtQU0l4TmpnaUlIaHRjRWM2WjNKbFpXNDlJakV5TkNJZ2VHMXdSenBpYkhWbFBTSTNPU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowek5TQk5QVFl3SUZrOU9EQWdTejB5TlNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRXpPQ0lnZUcxd1J6cG5jbVZsYmowaU9UTWlJSGh0Y0VjNllteDFaVDBpTlRraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlOREFnVFQwMk5TQlpQVGt3SUVzOU16VWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmNtVmtQU0l4TVRjaUlIaHRjRWM2WjNKbFpXNDlJamMySWlCNGJYQkhPbUpzZFdVOUlqUXdJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRRd0lFMDlOekFnV1QweE1EQWdTejAxTUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqazJJaUI0YlhCSE9tZHlaV1Z1UFNJMU5pSWdlRzF3UnpwaWJIVmxQU0l4T1NJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MDFNQ0JOUFRjd0lGazlPREFnU3owM01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJalU1SWlCNGJYQkhPbWR5WldWdVBTSXpOU0lnZUcxd1J6cGliSFZsUFNJeU1DSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejAzTXlCTlBUUXdJRms5TUNCTFBUQWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cDBhVzUwUFNJeE1EQXVNREF3TURBd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenB5WldROUlqY3dJaUI0YlhCSE9tZHlaV1Z1UFNJeE16UWlJSGh0Y0VjNllteDFaVDBpTVRrNElpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSlNQVFl3SUVjOU9ERWdRajB4TXpNaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpZd0lpQjRiWEJIT21keVpXVnVQU0k0TVNJZ2VHMXdSenBpYkhWbFBTSXhNek1pTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1USTJJRWM5TVRZM0lFSTlNakl6SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l4TWpZaUlIaHRjRWM2WjNKbFpXNDlJakUyTlNJZ2VHMXdSenBpYkhWbFBTSXlNVFVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1UWTFJRWM5TWpBeklFSTlNak01SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l4TmpZaUlIaHRjRWM2WjNKbFpXNDlJakl3TWlJZ2VHMXdSenBpYkhWbFBTSXlNelVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qQTVJRWM5TWpJMUlFSTlNalF5SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TURnaUlIaHRjRWM2WjNKbFpXNDlJakl5TlNJZ2VHMXdSenBpYkhWbFBTSXlOREVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qUTFJRWM5TWpRM0lFSTlNalE1SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TkRRaUlIaHRjRWM2WjNKbFpXNDlJakkwTmlJZ2VHMXdSenBpYkhWbFBTSXlORGdpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qUTNJRWM5TVRZMklFSTlNVEEySWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TkRjaUlIaHRjRWM2WjNKbFpXNDlJakUyTmlJZ2VHMXdSenBpYkhWbFBTSXhNRFlpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qVWdSejB5T0NCQ1BUWXdJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlOQ0lnZUcxd1J6cG5jbVZsYmowaU1qY2lJSGh0Y0VjNllteDFaVDBpTlRraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlsSTlOelFnUnoweE1ERWdRajB4TmpNaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpjMElpQjRiWEJIT21keVpXVnVQU0l4TURFaUlIaHRjRWM2WW14MVpUMGlNVFl6SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUa3pJRWM5TVRJMUlFSTlNVGt3SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0k1TXlJZ2VHMXdSenBuY21WbGJqMGlNVEkxSWlCNGJYQkhPbUpzZFdVOUlqRTVNQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWoweU5UVWdSejB5TURVZ1FqMHpNeUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPblJwYm5ROUlqRXdNQzR3TURBd01EQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25KbFpEMGlNalUxSWlCNGJYQkhPbWR5WldWdVBTSXlNRFVpSUhodGNFYzZZbXgxWlQwaU16SWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJbEk5TWpBNUlFYzlNakV4SUVJOU1qRXlJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlNRGtpSUhodGNFYzZaM0psWlc0OUlqSXhNU0lnZUcxd1J6cGliSFZsUFNJeU1URWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa2RzYjJKaGJDQkRiMnh2Y2lJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTWpVeElpQjRiWEJIT21keVpXVnVQU0l5TURnaUlIaHRjRWM2WW14MVpUMGlNalFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1DQkhQVGMySUVJOU1URTNJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXdJaUI0YlhCSE9tZHlaV1Z1UFNJM05pSWdlRzF3UnpwaWJIVmxQU0l4TVRjaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlsSTlNVEEwSUVjOU1qQTBJRUk5TWpJNUlpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmRHbHVkRDBpTVRBd0xqQXdNREF3TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZjbVZrUFNJeE1EVWlJSGh0Y0VjNlozSmxaVzQ5SWpJd015SWdlRzF3UnpwaWJIVmxQU0l5TWpnaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlsSTlNalV5SUVjOU1UYzRJRUk5TXpFaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJMU1TSWdlRzF3UnpwbmNtVmxiajBpTVRjNElpQjRiWEJIT21Kc2RXVTlJakk0SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKUVFVNVVUMDVGSURJNE1pQkRJaUI0YlhCSE9uUjVjR1U5SWxOUVQxUWlJSGh0Y0VjNmRHbHVkRDBpTVRBd0xqQXdNREF3TUNJZ2VHMXdSenB0YjJSbFBTSk1RVUlpSUhodGNFYzZURDBpTVRBdU9UZ3dNemt5SWlCNGJYQkhPa0U5SWpJaUlIaHRjRWM2UWowaUxUSTJJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0ppYkhWemFDQmpiM0I1SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TkRJaUlIaHRjRWM2WjNKbFpXNDlJakUxTmlJZ2VHMXdSenBpYkhWbFBTSXhOVFlpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1UQTFJRWM5TWpBNUlFSTlOVElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenAwYVc1MFBTSXhNREF1TURBd01EQXdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpweVpXUTlJakV3TlNJZ2VHMXdSenBuY21WbGJqMGlNakE1SWlCNGJYQkhPbUpzZFdVOUlqVXlJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pTUFRVZ1J6MHhOakFnUWowMk9TSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU5TSWdlRzF3UnpwbmNtVmxiajBpTVRZd0lpQjRiWEJIT21Kc2RXVTlJalk0SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUVTFJRWM5TVRnNElFSTlNVFUxSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kxTkNJZ2VHMXdSenBuY21WbGJqMGlNVGc0SWlCNGJYQkhPbUpzZFdVOUlqRTFOQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowME1TQkhQVFF4SUVJOU1UQTFJR052Y0hraUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpRd0lpQjRiWEJIT21keVpXVnVQU0kwTUNJZ2VHMXdSenBpYkhWbFBTSXhNRFVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU5TQkhQVEU1TnlCQ1BUSXhPU0lnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPblJwYm5ROUlqRXdNQzR3TURBd01EQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25KbFpEMGlOU0lnZUcxd1J6cG5jbVZsYmowaU1UazJJaUI0YlhCSE9tSnNkV1U5SWpJeE9TSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlVajB5TlRVZ1J6MDNNeUJDUFRrNUlpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmRHbHVkRDBpTVRBd0xqQXdNREF3TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZjbVZrUFNJeU5UVWlJSGh0Y0VjNlozSmxaVzQ5SWpjeklpQjRiWEJIT21Kc2RXVTlJams0SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUSTFOU0JIUFRJd015QkNQVEV6T0NJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTWpVMUlpQjRiWEJIT21keVpXVnVQU0l5TURJaUlIaHRjRWM2WW14MVpUMGlNVE0zSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUWXhJRWM5TVRBMklFSTlNakEwSURRaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpZeElpQjRiWEJIT21keVpXVnVQU0l4TURVaUlIaHRjRWM2WW14MVpUMGlNakEwSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKemEybHVJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlORFFpSUhodGNFYzZaM0psWlc0OUlqSXdOeUlnZUcxd1J6cGliSFZsUFNJeE9URWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJbEk5TkRFZ1J6MDBNU0JDUFRFd05TSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU5EQWlJSGh0Y0VjNlozSmxaVzQ5SWpRd0lpQjRiWEJIT21Kc2RXVTlJakV3TlNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMHlNVFFnUnoweE9EUWdRajB4TkRFaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJeE5DSWdlRzF3UnpwbmNtVmxiajBpTVRnMElpQjRiWEJIT21Kc2RXVTlJakUwTUNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMHlOREFnUnoweE9UVWdRajB4TmpnaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJek9TSWdlRzF3UnpwbmNtVmxiajBpTVRrMElpQjRiWEJIT21Kc2RXVTlJakUyTnlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMDJNU0JIUFRFd05pQkNQVEl3TkNJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTmpFaUlIaHRjRWM2WjNKbFpXNDlJakV3TlNJZ2VHMXdSenBpYkhWbFBTSXlNRFFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SW1Kc2RYTm9JaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlORElpSUhodGNFYzZaM0psWlc0OUlqRTFOaUlnZUcxd1J6cGliSFZsUFNJeE5UWWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJbEk5TXlCSFBUSXlOQ0JDUFRFNU55SWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU15SWdlRzF3UnpwbmNtVmxiajBpTWpJeklpQjRiWEJIT21Kc2RXVTlJakU1TmlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMDFJRWM5TVRreklFSTlNakUwSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kwSWlCNGJYQkhPbWR5WldWdVBTSXhPVElpSUhodGNFYzZZbXgxWlQwaU1qRTBJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pTUFRjd0lFYzlNVGN5SUVJOU1UazFJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSTNNQ0lnZUcxd1J6cG5jbVZsYmowaU1UY3lJaUI0YlhCSE9tSnNkV1U5SWpFNU5TSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlVajB5TXlCSFBUSXpJRUk5TlRFaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJeUlpQjRiWEJIT21keVpXVnVQU0l5TWlJZ2VHMXdSenBpYkhWbFBTSTFNU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowMk1TQkhQVEV3TmlCQ1BUSXdOQ0F5SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kzTVNJZ2VHMXdSenBuY21WbGJqMGlNVEExSWlCNGJYQkhPbUpzZFdVOUlqRTNPQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowMk1TQkhQVEV3TmlCQ1BUSXdOQ0F6SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kzTVNJZ2VHMXdSenBuY21WbGJqMGlNVEExSWlCNGJYQkhPbUpzZFdVOUlqRTNPQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowME1TQkhQVFF4SUVJOU1UQTFJR052Y0hrZ01pSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU5ERWlJSGh0Y0VjNlozSmxaVzQ5SWpReUlpQjRiWEJIT21Kc2RXVTlJakV3TkNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMHlOVEFnUnoweE56WWdRajB5T1NJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTWpVd0lpQjRiWEJIT21keVpXVnVQU0l4TnpZaUlIaHRjRWM2WW14MVpUMGlNamtpTHo0Z1BDOXlaR1k2VTJWeFBpQThMM2h0Y0VjNlEyOXNiM0poYm5SelBpQThMM0prWmpwRVpYTmpjbWx3ZEdsdmJqNGdQQzl5WkdZNmJHaytJRHh5WkdZNmJHaytJRHh5WkdZNlJHVnpZM0pwY0hScGIyNGdlRzF3UnpwbmNtOTFjRTVoYldVOUlrZHlZWGx6SWlCNGJYQkhPbWR5YjNWd1ZIbHdaVDBpTVNJK0lEeDRiWEJIT2tOdmJHOXlZVzUwY3o0Z1BISmtaanBUWlhFK0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUQWdUVDB3SUZrOU1DQkxQVEV3TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqTTFJaUI0YlhCSE9tZHlaV1Z1UFNJek1TSWdlRzF3UnpwaWJIVmxQU0l6TWlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejA1TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqWTBJaUI0YlhCSE9tZHlaV1Z1UFNJMk5DSWdlRzF3UnpwaWJIVmxQU0kyTlNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejA0TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqZzRJaUI0YlhCSE9tZHlaV1Z1UFNJNE9TSWdlRzF3UnpwaWJIVmxQU0k1TVNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejAzTUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRXdPU0lnZUcxd1J6cG5jbVZsYmowaU1URXdJaUI0YlhCSE9tSnNkV1U5SWpFeE1pSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU1DQlpQVEFnU3owMk1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakV5T0NJZ2VHMXdSenBuY21WbGJqMGlNVEk1SWlCNGJYQkhPbUpzZFdVOUlqRXpNaUl2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowd0lFMDlNQ0JaUFRBZ1N6MDFNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpFME5pSWdlRzF3UnpwbmNtVmxiajBpTVRRNElpQjRiWEJIT21Kc2RXVTlJakUxTVNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejAwTUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRTJOaUlnZUcxd1J6cG5jbVZsYmowaU1UWTRJaUI0YlhCSE9tSnNkV1U5SWpFM01TSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU1DQlpQVEFnU3owek1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakU0TnlJZ2VHMXdSenBuY21WbGJqMGlNVGc1SWlCNGJYQkhPbUpzZFdVOUlqRTVNU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowd0lFMDlNQ0JaUFRBZ1N6MHlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpJd09DSWdlRzF3UnpwbmNtVmxiajBpTWpFd0lpQjRiWEJIT21Kc2RXVTlJakl4TVNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejB4TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqSXpNQ0lnZUcxd1J6cG5jbVZsYmowaU1qTXhJaUI0YlhCSE9tSnNkV1U5SWpJek1pSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU1DQlpQVEFnU3owMUlpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlNalF4SWlCNGJYQkhPbWR5WldWdVBTSXlOREVpSUhodGNFYzZZbXgxWlQwaU1qUXlJaTgrSUR3dmNtUm1PbE5sY1Q0Z1BDOTRiWEJIT2tOdmJHOXlZVzUwY3o0Z1BDOXlaR1k2UkdWelkzSnBjSFJwYjI0K0lEd3ZjbVJtT214cFBpQThjbVJtT214cFBpQThjbVJtT2tSbGMyTnlhWEIwYVc5dUlIaHRjRWM2WjNKdmRYQk9ZVzFsUFNKQ2NtbG5hSFJ6SWlCNGJYQkhPbWR5YjNWd1ZIbHdaVDBpTVNJK0lEeDRiWEJIT2tOdmJHOXlZVzUwY3o0Z1BISmtaanBUWlhFK0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUQWdUVDB4TURBZ1dUMHhNREFnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlNak0ySWlCNGJYQkhPbWR5WldWdVBTSXlPQ0lnZUcxd1J6cGliSFZsUFNJek5pSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU56VWdXVDB4TURBZ1N6MHdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTWpReElpQjRiWEJIT21keVpXVnVQU0l4TURFaUlIaHRjRWM2WW14MVpUMGlNelFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU1DQk5QVEV3SUZrOU9UVWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU1qVTFJaUI0YlhCSE9tZHlaV1Z1UFNJeU1qRWlJSGh0Y0VjNllteDFaVDBpTWpFaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlPRFVnVFQweE1DQlpQVEV3TUNCTFBUQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmNtVmtQU0l3SWlCNGJYQkhPbWR5WldWdVBTSXhOakVpSUhodGNFYzZZbXgxWlQwaU56VWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa005TVRBd0lFMDlPVEFnV1Qwd0lFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpNMElpQjRiWEJIT21keVpXVnVQU0kyTXlJZ2VHMXdSenBpYkhWbFBTSXhOVE1pTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU5qQWdUVDA1TUNCWlBUQWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU1USTNJaUI0YlhCSE9tZHlaV1Z1UFNJMk15SWdlRzF3UnpwaWJIVmxQU0l4TlRFaUx6NGdQQzl5WkdZNlUyVnhQaUE4TDNodGNFYzZRMjlzYjNKaGJuUnpQaUE4TDNKa1pqcEVaWE5qY21sd2RHbHZiajRnUEM5eVpHWTZiR2srSUR3dmNtUm1PbE5sY1Q0Z1BDOTRiWEJVVUdjNlUzZGhkR05vUjNKdmRYQnpQaUE4TDNKa1pqcEVaWE5qY21sd2RHbHZiajRnUEM5eVpHWTZVa1JHUGlBOEwzZzZlRzF3YldWMFlUNGdQRDk0Y0dGamEyVjBJR1Z1WkQwaWNpSS9QcmVTYWlRQUFPZjNTVVJCVkhqYTdOMTVmQnQ1WWZmeDcyZ2syWkx2SzNZYzU4NG0yZnZDQzNqWlpZRnR1TUpWZURpNmZUamJSNVJDb1MwRmFsb29GTEt3UUV0TGFURXRCUW90eDVhamtIS1lMTHZMN21ZUHNmZm12aDNaam84NDhXM0xPcDQvUnQ0NGlROUpIa2tqNmZQZWx6YUpMWTFtZnZNYnpjeFh2OE9JeCtNQ0FBQUFBQUJBWnJrb0FnQUFBQUFBZ013amhBRUFBQUFBQU1nQ1FoZ0FBQUFBQUlBc0lJUUJBQUFBQUFESUFrSVlBQUFBQUFDQUxDQ0VBUUFBQUFBQXlBSkNHQUFBQUFBQWdDd2doQUVBQUFBQUFNZ0NRaGdBQUFBQUFJQXNJSVFCQUFBQUFBRElBa0lZQUFBQUFBQ0FMQ0NFQVFBQUFBQUF5QUpDR0FBQUFBQUFnQ3dnaEFFQUFBQUFBTWdDUWhnQUFBQUFBSUFzSUlRQkFBQUFBQURJQWtJWUFBQUFBQUNBTERBb0FnQUFBS0R3QklLaGF5WDlqcVFySmRWTGlrZ2FrclJYMHFPUzd1dG9iWm1tcEFBZ2V3aGhBQUFBZ0FJU0NJWmVKZWtUa3E1ZDRxbGprbjRoNlJ1U2Z0N1IyaEtqOUFBZ3N3aGhBQUFBZ0FJUUNJWXFKZjJicFArVHhzc1BTL3FDcEgvdmFHMEpVNW9Ba0JtRU1BQUFBSUFEQllLaEd5Vk5kTFMyUEo3RWMxc2s3WkswWlpsdmUwVFNuM1cwdHZ5RVBRQUE5aU9FQVFBQUFCd2tFQXg1SlgxSDB1L08vcWlqdGVXcml6eS9SZEo5a3RiWnVCci9JK2tQTzFwYkJ0Z2pBR0FmWmtjQ0FBQUFuT1ZiT2hmQVNOSVhBc0ZRM1h4UERBUkR0YkxHZFZsbjh6cThSdExUZ1dEb0ZuWUhBTmlIRUFZQUFBQndpRUF3OUU1SmI3emd4K1dTZm4rZTU1WksrcW1reXpPME9vMlNkZ1dDb1hlelp3REFIb1F3QUFBQWdBTUVncUVHU1o5ZjROZmJMM2l1SVd0V283WU1yNVlwNlY4Q3dkREgyVU1Bc0h5RU1BQUFBSUF6L0xXa21nVitkM01nR1BMTitmZm5KYjBwaSt2Mk40Rmc2QlBzSWdCWUhrSVlBQUFBSU1jQ3dkQWFTWXQxKy9GS3VqTHgzRTlJK3JNY3JPYkhBc0hRZTlsYkFKQStRaGdBQUFBZzl6NGl5YlBFYzE0YUNJYnVsUFN4SEs3blB3U0NvWmV3dXdBZ1BVeFJEUUFBQU9SUUlCaHFrblJNVW1tZXJISy9wR3M3V2x0NjJIc0FrQnBhd2dBQUFBQzU5VWZLbndCR2tsWkkrcy9FNE1BQWdCUVF3Z0FBQUFBNUVnaUdybEZ1eG5kWnJsc2t2WXM5Q0FDcEliMEdBQUFBc2lnUURHMlU5RTVKYjVHMFBvODM1WXlrclIydExmM3NWUUJJanBzaUFBQUFBREl2RUF5MVNQcWNyS21sQytITDBCcEo3Wkkrd040RmdPVFFFZ1lBQUFESXNFQXc5RkpKZDBxcUtMQk5DMHU2cEtPMXBZdTlEQUJMWTB3WUFBQUFJSU1Dd2RBR1NUOVU0UVV3a3VTVjlFSDJNZ0FraHhBR0FBQUF5S3cva09RdjRPMTdleUFZS21jM0E4RFNDR0VBQUFDQXpHb3U4TzJya0RYSU1BQmdDWVF3QUFBQVFHWWRLWUp0ZkRPN0dRQ1dSZ2dEQUFBQVpOWi9Tb29YK0RiZUhBaUdhdG5WQUxBNFFoZ0FBQUFnZ3pwYVc0NUsrbGFCYjZaYjBpM3NiUUJZSENFTUFBQUFrSGwvSnFtM3dMZXhqZDBNQUlzamhBRUFBQUF5cktPMTViU2s3WkltQ25nenIyRlBBOERpQ0dFQUFBQ0FMT2hvYlhsTTBrY0tlQlBYc1pjQllIR0VNQUFBQUVEMnJDbmdiYXRuOXdMQTRnaGhBQUFBZ094NU5VVUFBTVdMRUFZQUFBRElna0F3dEZIUzVnTGV4R24yTWdBc3prMFJBQUFBQUZueG9nTGZ2a09aZm9QV1c3ZWJrdFpMdWt6U1ZrbnJYQzVYbzlzMEt5VVpzWGg4TUJLSjlFaTZWOUwvQm5mdGpGRHRBRGdKSVF3QUFBQ1FIYmNVK1BiOXpPNEZ0dDY2dlZIU2paS2U3L1Y0WGhTSlJLNk14ZU5lU2FxcHJwcHBhVjdwV2xGZmI1YVdsaWdlajJ0MGRFeTkvZjJSSThkT2ZNRGpkbmUzM3JyOUxjRmRPKytuNmdGd0NrSVlJRWNDd1pBaHlTUEpUQnlMcHF3dWdyTi96bkpKaXMzNWQweFNkTTZma2NTZk14MnRMWEZLRmdBQXg3cXBnTGR0U05MWGxydVExbHUzbHlUSzZhVmVyL2RWNFhCNGl5U3RYdFVjdmZhcXk4MHJ0bTdScHZYcnRIN3RhcFg1L1o2RjduRjYrL3AxeDVlK3N1ckJSMzU3VCt1dDIxOGUzTFh6VjFRL0FFNWdVQVJBNWlVQ0Y1K2tVa2tsaVQ4OUdYaXJHVm45c2FkbUh4MnRMVEgyQUFBQU9iOFdXQ2ZwV0RxdjlabUdKcU9PL3A2bFg5TExFMU53cDZ6MTF1M2xrbDdxY2J2ZkdJdkh0MGVqVVgvVGlvYklqYzl0ZFQvMyttdDAzVlZYcUxLaUl1WGx4dUp4dGYvdForSy9lZkNSc1Vna2NrbHcxODYrVkpjUi92SHErbUd6L3NZN3EvNjg0VW5mTGRXSmE2MkhPbHBiSHFaV0EwZ0hJUXh5ZVRGeTRjRFE4VUpxeVJFSWhyeVN5aVdWeVFwZGNuVzhUVXFha0RUZTBkb3lSYzBEQUNBbjF3WC9WOUovcFBvNmx5Rjk5dW9tSFJnSmEvZmdoUGFPT081VS9vQ2syenBhVzA2azhxSkU4UElhcjhkeld5UWF2VFVlajNzdTNid3A5dUtiMmx3dmVrR2JWcTlxdG1YbHhpY205THEzL21GMFpIVHNYeC91L01rZkxmYmM4STlYRzVJMlNMcEswcldTdHA1eXI5djAxYnJQYlJod3QxUmQ4UFJISlAxQlIydkwwOVJ1QUtrZ2hFRW1MelpNV2EwK1NpUjVaYlg4Y0NjZUM4M01GZGU1TGpZek90ZXlZN3FqdFNXY0I5dnNsVlFwcVVLWmFlbXlYQkZKbzVKR09scGJtTUVBQUlEc1hTUDh2YVFQcFBxNlRlVmVmWEJydzdQL1BoT082cmREazNyazlMaE9UdVp1ek5uSXhIamM3Zk8vWDRieHp4MnRMZEZVWHZ1OGw3N21VNUkrR0l2RnZOZGRmV1g4SlRmZDZIcmhqYzlUUTExdGVpc1RqeWcrK0tCRyt4N1JiMTFYNnlGZG9ZbW9vWVlTVTlmWCtIVHMzbC9weS8vNjlYQXNGbHNSM0xWeldKTENQMTVkSlN0c3VWTFMxWFArWHBhNDl1dzVYSEx0Mlgrcy8vSzE4WVZ2bWNZbHZicWp0ZVhYMUhBQXlTS0VnWjBYRjRZa2YrTGs1WmNWdk5ncEtxdFZ4N2lzVmgwUkIyMTNoYVJxV1MxZThzVzBwR0ZaZ1F4ZGxnQUF5T3oxd2oyU1hwanE2N1kzVjJoN2MrVzh2enNUanVySnMxTjY4c3lFRG81T0s1cUZTM3QvTkt3am5UdlYvL0J2RkoyZTJoemN0VE9sR1pGYWI5M3VkcnZkSTl1M3ZjUVhlTnR0cXF1dFNmSHE1YlRpSS9zVkg5bW4rUEJleFVjUFNQR1lCc3htZmE3MHc1b3d5aTU2U1pNN3FzbnZmbEJ2WFBmMEQ2OWFPZTZSRmJpc1hlUmQ5bzY3cWp6dEszOTJTV3pCN3cyZk5TYXB0YU8xWlQrMUhFQXlHSmdYZGx4VStHVzEvaWlYbGo1VExZT1plSS95eFB0T1NSckpWWWlRNkU1Vkl5dDhNZk53MTVWSVdpR3BQaEFNRFVzNjQ1UmdDd0NBQW5UTmZELzB1Z3k5cnFWU045VDY1WFlaZXVyc2xPNDhlVllqTTlhbHpkYktoYi9mcWZHYXVtVkZtVzVaVWFaSVBLN2o0ek02TkRxdG82TlRPam82cmZHNFBhRk1neXVtSyt2SzFGcGZyblZsWHIzMUc0ZlZPejAxdTAycFRrdTlNUktKK0Y3N2lwY3VIc0RFSW9xUEhrd0VMbnV0UDRmM1NkTUQ1ejNOS04rb0ljOXEvYTN2YjdSUVlISXFZcXI2ZGUxYU5mRHUzMVYwZktuMWUwYlNwZjljOS9jRHNlUXVhOHNsZlRjUURMVjJ0TGJNVU0wQkxJVVFCc3NKSUNvVElVU3V1dDJVSmg0TmdXQm9KQkVpaExPMDdUV0poNnNBZHVlellWSWdHRG9yd2hnQUFPeStkbGd2cWVxaUMzSEQwQWMyMTJ0RCtibkd3NjIxUHEwcjgrZ3ord1kwSFkxclhWbHlsMWx1dzlDbWNxODJsWHVsbGRZZ3R1T1JtSHFuSXVxYmltaG9PcUl6TTFHTnpNUTBHWTFwTWhyWFZDU211T0p5dTF3cU5RMzVUSmNxUEM3VmVFelZsN2kxeXVkV2k5OGpuM24rNWM2V1RSdDE0UEJSeVdwUmNtZUt4VkVuU1RYVjU0b2pQdFVuamV4VGZIamZ1ZEJsOUlnVVgveHl4S2krVXJIeGsvcjd5bi9VVW9ISldiTkJYNjI3UXg4Y2VLYzg4VVV2Rnh0Q25zMVBkbmt2dlM2RmJicGEwbnNrL1FPMUhjQ1NuOWNVQVZLOGlEQmt0ZnlvbFhOYWZ4aUpDNXVxUURBMEt1bDBKc0tZeExaWEpTNGV6QUxjdlliT2hURkRrb2FZOGhvQUFGdGNQdDhQWDcycThyd0E1dGtVb01TdE42MnUwcjBENDNJYjZiZG1LWE83emdVek5sclQ4dXlndVJ0U2ZlMXJyemhkTVJNMTVEdjZPVVVPbjFSOFpKOFVQcFA2U25ockZSL2Vxd2VxMzZvemhqV1dUUFBNRVVVTlV5V3hTZlY1MW1yYThKLzNraDdQUnYyODRsMTY5Y2kvTExUVS9aSzIvcmpxZmVtMGFQbUxRREQwWmI3SUFyQVVRaGlrRWtKVVNHcHdlTDJwa0ZTUmFORnhPdFdCNGhiWmRwK2tSdGsvem8wVEdiS0NwcXBBTURUUTBkb3lTdTBIQUdCWkxnb3JhcnltWHRKWXR1QUxicWp6YXpUaXpDSGJWcTFzV25DN0ZwS1llZWh2NGdxMUc1TFUvejB0NTV1ZVdPbEt4V016K20vZk81NzlXVnlHK3R6ckpFbmUrSlJXemh4VnIrZjhWZngxK1Z0MDAvZ1BWUk9kZDdicXNiaGN3d2RMcm10SnAxZ2t2VWJTRDZqdUFCYmpvZ2lRUkFEaENRUkRMWkpXS24rQ3UycEo2eExCMFhLMjNSVUloaG9sclZaeEJEQnp1U1d0REFSRHpZRmdpTUFXQUlEMHJidndCeTlzS0pPNVJDdVhxNnVkT2Q3L25CQm1Vd292KzZTa2p4azJYRXZHSlVYT0hOQVJZN09paGlkeFV4UFRLYy82WjU4VE5rclY2OW1nbFpGajU3MDJhbmgwZC9sYkZscDBTNTk3N2RGNEdyZEk4V2hNWTZHQjkxTFZBU1J6a3dVc0ZrSlV5aHE4TlI4RE96TVJJcFJMNmsrMVZVeGl3T0VtamhPVlMvSUhncUUrV3NVQUFKQ1dpMXFNWEZ2alcvSkZ0VjVuWG9JMHJuaDJ5dXo2MWx1M2U0SzdkczVJVXV0THRwZExxazg4YWhPUHV1ZXRIYTJYanJiYjlmNzlFeFZxOUkvcXliSnprMDNWUmJvMTRGNTkzdk5LWStNNjQxcHgwZXNmOGI5TXJ4MytSN2wwWGt1akdVbE54N3hYZEtXNlBtTTlnenI5MUJISlpkd1VDSVpjekRvSllER0VNRmdvZ0RCa2RiK3BMSUROcVpEa0N3UkRQUjJ0TFZOSmJ2L3N4UU1zTGxtQlZwbXNRSXVMQ3dBQWtyZHU3ajlxdktZYVM1ZStESGNaemxqNVl5ZE9hdStCZ3hvNmMxWm5SMFkxUERLcU9YMkpubWw5eWZaS1dWMlo1eDFGK0pybXNhZGs0eGQ2STlNZXJmQWJlc1QvaW1kLzVvOWQvRDFSVlhSUWZaN3paNktPeCtQcVBqcXFwM3pYNnhvRjUvNXFRRkp6bjJkdDBpMmZ3eU1UR256cXNDYjZueDNUeGh6ckhuaU9wRWVvOGdBV1FnaUQrUUlJajZSbVdWTVlGMUpkWHgwSWh2bzdXbHVHRjlsMlUxYTNLejgxWVY2Vmtrb1RnVmFZNGdBQUlDa05jLy9SNHZQa3hVb2ZQSEpVbi9uaVArdVpmUWNXZTlybXhYNXBTR052dkdid1Nqdlh5Nldvb25KcnlqZzNwazdjT0Qvam1XODhtTW4rTXhwNDZyRENJeE82NzhybjZSci9lU0hNc0tUbVFiT2xiS24zajgxRU5MVHZoSWFQZENzZVAzOWttNW5SeVRZUndnQlk0c1lVbUJ0Q2xNZ2FXS3dRNjRZaHFURVFESGs2V2xzR2kyemI3ZVNWdENZUURQVjJ0TGFNVXh3QUFDeXBadTQvNmt1Y2Y2bHgrT2h4L2VIN1A2ekpxYWxsTGFlbGV2cHdpVHQyalozclZ1cU9hTVoxL25nNTAwYnBuQXUrdUVaZDV4bzB6MHhNNmZSVFJ6VFdjKzd5NzlEb3lndS9jbHU2bFc5Y0dqbHhTcWYzSEZWMGV2NEpsS0l6TTFkUTNaRXZMZ3dSOCtLR3pqRHl2dHdabUJkelF3aS9yQUZvQ3oyRXFBMEVRMDBYYkh0WmtXeTduWjhkcXdMQlVEVkZBUURBb3RkWEpaTE9Hd0Ntek8zc200aG9OS3EvL052UExEdUFrYVRuckI2YnNYdjl5cjFSelZ3d1gwSjBUaytvbHBsREdqT3JGWS9HTkxUdnVMcCtGVHd2Z0pHa00xTVhqY25qbGFUUytOaThMWDJuaGtZVXV1Y3g5VDkyWU1FQXhycXJGZGRHQUJiRkRTZG1MeEQ4c2xxQkdFV3l5WldKY1c5T3lSb3pwb2xha0pZVmdXRElQVi9MSWdBQUlPbUNWakNTNUhVNSszdlFYZmZlcnhNbnUyMVoxdnJhS2R1N3QwOUhYU3BUNUx5ZlJZeHpJY3l3V2F1eDdnRU5QbjFVa1luNWc2U0pxWXYyUWFra2xjZk9ucGV3UktmRE92M01NWTJjT0pYY3loa0c5MWNBRnNXSEJJb3hnSmxWSWV0Ymp4SnF3YkxVQm9JaHM2TzFwWStpQUFCQTg5N2N6eFdPT2JzTHdLL3V1YysyWmEyc0RKZlp2WDZ4V0Z4elJ3YVdKSGZjeWs3OFowOW8zOU5uTlRsd2R2RmxYTHdMbWlTcFplWlFXSkxpc2JpR2ozUnJhUDl4eFdaU21tQnpoaW9QWURHRU1FVXUwVVMyV2NVWHdNd2lnTEZIVldKS3hsNktBZ0NBeFkxSG5EM0o0SUZEUjJ4YjF1U015L1pRWW13cXJ2cUt5Zk4rWm9Rbk5MajNjR0t3M0tXWEVZOWU5Q1NQcEltVk0wZk5pYjR6R256cXNNS2pFeW12bTh0dG5xQ0dBMWowYzRJaUtGNkJZTWd0cXdVTTlRQjJxQWdFUTQwVUF3QUFpK3ViaWpoNi9RWk9EOW0yck5GcDAvWVFabUk2Sm5kOFJtWThZZzJXZTd4WGovNzZsTTRlVGk2QWtTU1hPZStQand3T2FXUFBBMCtsRmNCSWtydlUrelExSE1DaW56OFVRWEZLaklmU0xGcER3VjVWZ1dDb25tSUFBR0Job1VsbjkxaHgyVGhtelpIQjBpbmIxOCt3V2hJMTlBVjE4cDdIMVAvWVFZWERxYlV1S2l1ZDkvbmhTOHVPVjd0Y1Jscjl4VXl2Ui83RzJwOVF3d0VzK2hsR0VSU3RGWnFuanpKZ2c5cEFNRlJGTVFBQUlFbTZxRW5GeUV4VTNRNE9ZbGJVMTltMnJIMzlmdHU3dkxkVVcyTzBkRDB6b09rem8rbGRySlJPenZmalRWN1hUSHhMYlg5YVRZRkthaXFHdnZiQ2pXZW84Z0FXUXdoVGhBTEJVSVVrYnBLUjBldTN4SURQQUFBVXUzbHZ5aDg1UGVuWUZiNTA4eWJibG5Wb3dMZkc3dldyOXNkMWV0eWw1MVU5bGZZeXJxcVlkOXliS2tsUHZYUEZENzNwTExPa3V2d1hWSGNBU3lHRUtUS0pjV0JXVUJMSU1FTlNjeUFZOGxBVUFJQmkxdEhhTWlOcC9NS2Yzejg0cnFtb00yZEpldEZOYmJZdEt4SXpWandXS3UrMmV4Mjd6eGg2WmQzdXRLOVNYbEoyNzBLL3JidWk0bGpGbXByeGtWUVc2ZmFWeE11YWF2K0NHZzlnS1lRd3hXZUZKSk5pUUpZK1g1b1Q0dzhCQUZETVRsLzRnL0ZJVEQ4SURjLzc1RnpQWVAyU20yL1V1dFV0dGkzdm54NW83ck43SGJjMkc2cjNEdXY2aHE2VVg5dlE0Tlk2TFRnRFZJdWt4LzltN1QrN1hXYnlZOE5VckY2eDg1c3Z1N3lIcWc0Z21ac2tGSWxBTUZRbXFaeVNRQmFWaUpaWEFBQWNuKytIOXcyTXEvUFUySGsvbTRuRjlaT2VrWnl1ckdtYSt0UmYvWVhLL1BiMExEN1E3N3QyN3lsL3I1M3I2SFZGWk5aY29VRHpqNVRxT01LdlgzbmZVays1Y21YSjZZSDNyUC9wcVdTVzUydW9IcXZhMVBKbXFqbUFaREF6VHBGSXRFWm9vQ1NRQTFXQllHaWlvN1ZsbEtJQUFCU3BvNUp1bnU4WFB3d042L0V6azdxeXVsVFQwYmlDUXhNeURVT3ZYVldaMHhYZXZIR0QvdTBmNzlBWHZ2eFYvZmJ4UmNkZTJTdHBRTktncENGWnJYNkdFbytCMlg5NzNiRkxKUDNBenZ1UCtQQWVyYWxwMEp2WFA2Ny9Pbkp0VXE5WnNjTFVhMHIvSjVsN3BMcFgxdDEvZGlSYTN2T3Q0eTlxamk4dzkzVkpkWG00ZXVPcW03NTIwNFlKcWptQVpOQk5vRWdrWnF0cHBDU1FJMUZKSnpwYVd5Sno2cVFwcTJ1Y0lhdFZucEY0eEJPUHFLU1lwR2hIYTB1Y0lnUUE1UEYxMkVjbGZTclo1NXVHb1M5ZDF5eVhRNjdVend3UGEyRFE2bEZWVlZtcHJsQzMvdmhEZnlWSko0TzdkaVk5OEc3NHg2di9yNlN2eTg2dThTVjFpa2VuMVg3a2ovWEVxWnBGbitvdWNjZi81b3J2ZmU5NmQzQlUwdXpndTI2ZDMxSzhVdWQ2QzdnbFRUMDVkc25sbis5K1I5WGdXWmR2OWtrdWo2bnk1b1k5NWF0WHZPSmJyN3l5aTFxT2ZMUlF1T2pvQU1QSS93aURsakRGY2VJM0pOVlNFc2doVTlLcVFEQVVrZVJKUEl3VTZuQkUwb3lrc0tScFNWT1NwZ2xuQUFCNTRwbFVuaHlOeDlVek9hTVd2elBHdDYrcHFsSk4xYm1KTlo5NGVzL3NYNCtuc2h6dmEwOStLL3pqMVFjbC9aV2tsMGp5TFh2bHBrL0xWZHFvVDEzeWRYM0s5ZnQ2cUdmK1h0Qm1pVWNsNWNhN24vK0dIMzQxMWJjSS8xaXJ2cldsL1FXL0NkKzgrYituM3VBKzQxNTUwdGRROWIvZitKMUxlNm5hQUZKRkNGTWNLaE0zdlVBdWxTUWU2WDVXdVMrNFdJc0hncUVwU1JPU3hqdGFXNllvWWdDQVF6MlM2Z3YyalV4bkxZU1ppc1lWamNmUG02M0pheHJ5R0laS3pZdS9NK25wZTNhYzNlT3B2cGYzdFNjZmx2UXFTUXIvZUhXVnJDOWxURWtWa3ZUbDNTczNQOUpWOVl1M3YrWDF4dSs4OEFWU0xDeEZaMC94Y2NWbjV2UnVqazVJTWF1UnJUYzZxVStzUHFGNzloN1I5MExYNi9oUWlXS3h1SHpsUGpYVmwyci9MNzg3MWZuRC8vaHFPdVhqZmUzSmJrbmZrLzVUMWdNQTBrY0lVOEFDd1pCUFVyM3MrSllCY0I0alViZDlrdW9Dd2RDTXBGRkpJeDJ0TFdHS0J3RGdGQjJ0TGIyQllDZ2thK2FkcER3d09LNWJtOHJUSGp0Z0poYlg2WEJVcDZjakdncEhOUlNPYW5RbXByTXpVWTFGWWhxWmlXb3lHdGRrTkxib2NseUdWTzUycWFIRXJjWlN0OWFYZVhXMC84enNyNDhzcDF5OHJ6MDVkM3FveEF4U0o0OC9kOXVydjNuSE4rNzl2ODkvOGUrYkZWVmxGNTM4Ri9PU0s2d21Odkc0Tk50cjRUUC84R1h0bXhwN2hwb0l3QWtJWVFwUUlCanl5QnFFbDVtUVVFdzhzcnJkMVFhQ29VbEpaeGtNR0FEZ0lQZExTbm9HblZOVEVmM3kxS2hlMWxTeDRITmljYWwvT3FLK3FkbkhqUHFubytxYmltaGtKbXJMU3NmaTBzaE1UQ016WVIwWkMydjM0SVIwNDNadGF0aWcwNDg5T0tCZE8yMHZxRmdzOXBIeGlZazNmZTNiMy9GOTROMS9rTll5NWc0YnNmZkFvV2c0SEg2UUtnakFDUWhoQ2toaTdKY2FTWFZpMEdVVU41OGtYeUFZcXBmMXpkb280OGNBQUhMczUwb2hoSkdrSDRkR2RHWTZxdWZYKzFYaWNta3dIRkh2WkVUZGt6UHFtWnhSNzJSRWtSd05yRm01K1RLVnJtamFvaTk4M1BabEIzZnQ3R3U5ZGZ2SHZ2dWpuOTd4dWxlKzNGaTdlbFhheTRwRUlqcDg3SVJMMGhOVVFRQk9RQWhUSUFMQlVJbWtKcVUvNWdaUWlEeUo0Nkl1RUF3TmRMUzJqRkVrQUlBYytabXMyZjlTK3FMczNvRngzVHN3N3NnTjhsYlZuTTNnNHYvUmJacnYvZnlYTzlaODZUT2ZUUHZMeGNQSFRpZ1NpUmlTZmtzVkJPQUVMb29nL3dXQ29ScEphMFFBQXl6RUk2azVFQXkxSkxyckFRQ1FWUjJ0TFlPU2RoZlVSaGxHeHJyOUJuZnRESWRuWmdJUFAvcTRjZGR2SGtoN09RY09INUhMNVpxUnRKZGFDTUFKQ0dIeVdDQVljZ1dDb1daWjQ3L1EvUWpGeGtoOGhwbnpQR1puVTdydzV4V1NOZ1NDSWFac0J3RGt3amNMYkh1R003bnc0SzZkdnpSTjg0ZGYrUEpYb3hNVGsya3RZOS9CUS9KNDNIdUN1M1pHcUg0QW5JRHVTSGtxOFczK0trbGVTZ01GeHBEVmNzV2o4d09WMlZERnBlV0hqbXNUMDF2M1NacVdGSm56bUVrOHdoMnRMVnl3QVFEczlEMUovNkRDbWJseU9OTnZFSTFHM3pkMDl1d3IvKzNiM3pILzVQKzlNK1hYUC9iVW5zajBkUGdlcWg0QXB5Q0V5VU9CWUtoVVZnQmpVaHJJYzZhc2JuUWxPaGU4Wkt1N1VLbWsxWklHSkUwdWNLekZKSVVUajZuRVk1cEJmZ0VBNmVob2JSa0pCRVBmbGZTT0F0bWtvU3k4UjFVc0Zpdlp0R0Y5eWkrY25nN3J4TW1RVzFLUTJnZkFLUWhoOGt3Z0dDcVQxQ3k2SHlFL2VXV0ZIeVdKUDNNZEpMb2tOU1l1SWtjVytIMXA0bEdaK0ZrOEVBeE55d3BrSmlSTmRyUzJSTm0xQUlBa2ZVN1Myd3ZrV3U1RUZ0N2o5eHZxNnlJdmU4a3RLZCszbEpSNDVmRjRvdUZ3dUp4cUI4QXBHQk1tandTQ29YSVJ3Q0MvbUpMS1pZMWJ0Q1pSZjJzbGxjbFpMYmxxWlUzdG5neERWaWhUbmRpZWpZRmdhRTBnR0dvSUJFTitkamtBWURFZHJTMzdKUDFQQVd4S1hGSlhwdCtrcE1UNzVoZmYxT1oyR2VsZC9qWTNOY1lrYmFUbUFYQUtXc0xraVVRTG1KVWlnRUYrZks3NFpZVXYrVFJtVVlXc1lIb3djV0daaXRuV01qV0JZQ2dxYVZ6U21LUnh1aTR0KzdQUExhdUwydHlCbG1jSFpKWXUvakloTnVmUG1LVG9uTWVNcEVoSGEwdU1rZ1dRWXg5VFBQNWFHWGw5V1hlMG83VmxPcE52MEhycjlvYnA2ZkNHNTE1M2JkckxXTnZTN09rS2RXK2l5Z0Z3MHMwU25IOFQ0aGN0WU9Cc3BxeldMZmtXdkZ5b0xIRlQzNi9VZzVpNVpWR1plTVFDd2RDWXBKR08xcFlKcXNtaW4zTmVuUnNmYVBidm5neTlWMVRueHZxWlRqeW1DTXdBWk10amYvbnU0VFcvKy91cWIzMUJQbS9HVTFsNGp4c2s2Zkt0bTlOZVFITlRrN3dlejFacUhRQ25JSVRKanhzVEFoZzRrU0ZyZG9meXhKK0ZVa2Q5c3JwUDlkdXdMSmNTZ1V3Z0dJcklHbmRtdUtPMVpZYlB0bENwckJaVFBtVi9mQ0F6OGI2K0M5WnBXdFlnelJPU0ptZ3hBeUNEWHQvYitSUFZYLzBjeVZ1YWxUZGM0L2RvcGMranZxbUloc0pSVFVaam1vbFoyYlBQZEtuR2E2clo1OWJXaWhKTngrSzY4K1NTRXg4OW5vWFZmazU5Ylcya3Byb3E3WHVXNXFaR1JhTFJGcW9jQUtjZ2hISDJUWW9wYXhZa3h1NkJrNWl5dXU1VXFIQm42UEpMcXBmVk5jbk96OXRhU2JXSjFqRm5pNmwxVENBWWN1bGNheW0vUSt2T2JFdWM2c1E2VDhucVZqYlcwZG9TNXRBSFlLUGZuUmtiMFphUmJoMm96ODV3SmMrcDlXdGJVM0xqMC9aTlJaSUpZZTdMOURxN1hLN0xONjVmdTZ6elJkT0tCa1Vpa2NyV1c3ZVhCWGZ0SEtmcUFjZzFRaGhuYTFiMnB1c0ZsdUtSVkpXNGtTNkdsbG5sc3NZUUdjN1Fzc3NEd1ZCWTBobFozWlVLcml0TUlCZ3lFdldsTWsvcnpleFlQL1dKVmpLamlYMFY0ZU1BUUxwYWI5M2VJS2xOa3Q1NDlXYjl6N2hIVDUyZHl2ajdUa1dUYjl4WFgyTEswS0w5Y3FjbFBaVHhHeFczKzRwMWExcVdkZTVvWE5Fdys5YzFrdlpSQXdIa0dpR01jMjllNm5WQlUza2dSN3l5V2dZVTQ4dy9OWklpc2diYXpWVFpOa3FxQ3dSRFE3SzZLdVY5R0pQb1Jsa2xLM3dwbE5aU3M2MWs2Z1BCMElTc2NHNk1jV1FBcE9IbGtseWIxcS9UcXBWTmVsc2twaDM3K25WNk9wclJOKzJaVEw0bnJHa1k4cGt1VFN3YzNOemYwZHFTOGVRb0VvbXNYNzJxZVZuTFdObTRZdmF2YTBVSUE4QUJDR0djZVFQamw5VnRBY2lsWWc1ZjVxcVhOWUJySnNkeGNVdGFJYXVyMGhsWlhaWHk3dVkrOGRsVkk2dlZTeUh6Sng2UnhQNGFadndZQUNsNHFTUTkvNGJySlVsbGJwZitjRU90dm5CZzhOa3hXakpoejhpMGhtZWlxdklrbDQxUEx0NXk1cjh6WFVpdHQyNnZpOFZpcFMwclZ5NXJPVldWRmZKNnZiRndPTHlHcWdmQUNRaGh6dDA4dUdTTnZlS1NubTJCR1pNVXkrYkZkV0k5bXRnanlQSG5RakhjU0NmTGtEVlFiNi9TbnpFcGxiSnZrRlFkQ0laT2Q3UzJqT1RKNTJlNXBEcFpMVVdLN1ZocGtOV1M2YXlrTXgydExWRU9HUUNMQkFzdXpZWXd6N251MlordksvUHFuZXRyOU5ValF4azcwY3pFNHZyR3NUTjY3eVYxTXBlWUduc29IRjFzUFNMS1FnZ2pxVVdTR2xmVUwzdEJLK3Jyb3FHZVhnYm5CZUNZQzhpaUVnaUczRG8zSzRabnpzTlk1RFZ4V2QrQ3p6NG1KVTFtYUZ5QUJoR09JVGRjT3RlRmhObTR6dWVWRlV3TlplbjlQSkthQXNGUWphUUJwdzdnR3dpR3ltUzFGQ3JoMkZHdHJQRHNyS1FoV3NZQVdNQlZrdXBLU3J5Nitvckx6dnZGdFRVK3ZYbHR0YjV6NG16RzNuemZ5TFQrOGVCcHZXTjlqYXE5QzdlSWVmajBvcWVkbjNlMHRneG1vYXlzRUtaaCtTRk00NG9HTTlUVDIwejFBK0FFUlhHem4yZ2lYeUdyK1hnNkE5MGFpWnN3YitMZjFZbmx6c2lheW5UVWpwdWt4SlN0VlZSTDVFQkZJbVJnSnE2RlZTYU85Nmtzdm1lSnBKWkFNRFFxSzR4eHhJQ3dnV0NvUkZaZzdLZGFuR2MyaktrS0JFT0RIYTB0d3hRSmdBdmNMRWxYWFhhcFBPNkxMOE5mMkdBMVFzMWtFSE5nZEZwLy9VeWZicXozNjdsMWZxMHI4NTczemN1VFo2ZjA4OTdSeFJieHBTeVYxZXJTa3BKb2VWblpzc2NXYTZpcmRYbTkzdlZVUHdCT1VMQWhUS0xGUzNYaXhpbFQyems3VzB4VklCaUtTQnFSTlpaRHVqZEtLNmlTeURLUGFNbVFpanBKUGNwOHQ2UUxWVWdxUzl6WW44M1Z4aWU2UzlZblBsdXhNRk5TWXlBWXFwYlUzOUhhTWttUkFNVXRFQXpWZGJTMm5GWWloTG4rNmlzWGZPNExHOHBrR3RKL0hqK2IwYTVKOS9TUDY1NytjZmxObHhwTDNTb3hEUTFPUnpVNHZlaGxiTENqdGVWWFdTcTJodHFhNnFoc0dPQjlSWDI5REVPcnFZa0FuS0RnUXBoRStGS243SGVwY012NkJyUW1FQXlOU0RxZFNoZ1RDSVlxWlUyRkNtU0RvVVNBS0xvZXBjS1QrR3pKUlFzSGw2UVZpYytLdm83V2x1a3NmN2FXeXdxSzZTNlp2QkpKcXdQQjBMQ3Nsa3gwVVFLS1RPS3o4MHVTM3Z6L0h1NzZrOGMvK3A0WFN0SjFpNFF3a3ZTQytqSlZ1azE5N2VpUXBtT1p6ZjBub2pFZEd3OG4rL1NQWnJING1tcXJxMjFwb2J1aXZsYXhhS3lSR2duQUNRcW02MEVnR0hJbHBuVmVuK01ieTltYjIvV0JZS2doOGMzeFV1dHV5QXFPZ0d6d1NtcVcxWnFCQUNaMTFjcnR0TXVsa3RZa3hvdkp4bWVyR1FpR21oTjFoZ0FtUFZXUzFpWEcwQUZRSkFMQjBDcEp1eVc5WFZLcDRYSjl0ZVdWYjZqM2VyMjZiUE9tSlY5L1ZYV3BQbnhwZ3hwS0hQUFIrOE1zdG9LUnkrVmEwYmlpM3BhTnI2dXQxVXdrVXRsNjYzWmEvZ0xJdVlJSVlSSVh0dXRrdFVSeHlrMmxJV3VNaldRdXZDdVUzbGcxUURvM2d5dXBiOHMrdHFzY3NBNE5nV0JvZFNBWXl0aStUSHgyclpWVXptNWZOcmVrVllGZ2FFVWllQWRRd0FMQlVJdWtleVdkMStSbHhRdHUxUlh2K2hPNVBNbDlkRGY3UFByb1pTdDBRMTNPaCtBYWtQVHViTDZoeCtOdXJxNnk1M1E3WjNEZmxkUk9BTG1XMXlGTUlCZ3lBc0hRQ2ttcjVOeHZhR2N2dkJzWGFSVlRTMVZFaHBteXBqNnZFYTFmN0ZDaDNMYUdtZVdUdERiUlJjbnV6OVlHaDMrMjVxdHFXUzJadkJRRlVKZ0N3VkNWcEY5STJqanZFOVpzMHBjT250WmtOTGtlaXFXbW9YZXVyOUVmYnF4VnBTY25sKzRSU1cvcWFHMFp5T3BOaXVHcXI2eXc1enVBbXVwbnc1d21haWlBWE12YkVDYng3ZThhNWM4QWtWV3l4Z2J3WExBZGZwMmJkUW5JMUkzNktqSG1rSjJjMEJwbTd1ZDRVeUxvWFhiQWxoaFhxMFZXWUlmTUtKRVZ4TkRDQ0Nnd2ljL1FIMG02ZkxIbkhSaWQxaGNPREdwNEpwcjBzcSt2OGVuamx6ZnF4U3ZLWlJwWit6NGxKdW50SGEwdGQyZTdMR1B4V0ZWNW1UMjlPT3RxbnoybE5WQkxBZVJhWG43RG1aaktlWldjOFUxME9oZmVQWE5teTZpbUdpS0RxcWxqR1ZNaDZXemlBdFVKcWlTVkJvS2gzbzdXbG5BNkN3Z0VRejVaVGJWcC9aSjVMa25OZ1dCb3FLTzFaWkRpQUZMK3ZESVN4NUZMVmpBKys1anZDOFo0NGhHYjgyZXNvN1VsRXlQZS9yMmtGeVh6eE5ERWpENjdiMEIvc3JsZVRhWEpmZXlXdVYxNjQ1b3EzYktpVEQvcUh0SGpaekk2K2RxMHBMZDJ0TFo4UHhmN09CcU5WVlNVMnhQQ2xKYVV5T3Z4eE1Jek03U0VBWkJ6ZVhlaG5SaWpvRm41MjZYQ2xOUVNDSVo2SlUxS1lxQkdaS3FlMWN0cUJZUE1NQkxINzZpRDFtazI2TzN0YUcwWlQvR3p0VkpTbytpdWxtMjFpYTVKdlJtNklRVHlYaUFZS3BIVm1yTkVWdXRocngzWHNJRmdLQ29wUE9jeEpXa3EzV014RUF5OVM5SjdVM25OVURpcXorMGYwQjl0cXRPbTh1UWJScThvZFN1d3NWYWhpUmwxOW8zcHQwTVRzbmtTcFFPU2ZyK2p0ZVczdWRydmtVakViMWNJSTBrMTFWWFJ2b0ZCV3NJQXlMbThDbUVTVGJkWEZzQk5naUVyU0JybmhnY1o0RW5jVE5PYUlmTXFOSDhJWStyY043U3ozOHJHNWp5aUdWd25sNnh4cUFZNldsdk9KUG5aV2lkbWFNdWxjbG5kVmJzN1dsdWlGQWVLWFNKMDhjOTVaT3BheVpUMVpjWGNMeXppZ1dCb1d0SkU0akdaVENnVENJWnVrUFRQNmF6RWVDU21MeDRZMU52VzE2aTFOclh2VGxyOEhyMXpmWTFldDZwU3V3Y250UHYwdUU1UEwrdGo1S3lrejBqNnh6bXR0ck91OWRidDFaSmtWM2NrU2FxdHFUSDZCZ1pYY0lRQnlMVzh1VWxMdElBcGhBQm1MbHJCd0c0K1NTdEV1SmN0M3NRTmdsdldON1NleEdPcDhvOUxta2s4cGhLUEdadlhyU0hSd3FKL3NSdUlRRERVSkttU1habHpzMU9QaHpwYVcyWW9qcUlQSVl6RVo4bnM1NG83RVJqTUJyeHpQMlBtaHJ1UnhDTXNLZHpSMmhMSm8yMzJ5UXEyeTNOOGZXb2tqc2RTV1JNbnhBTEIwSmlrTVVuajgzMmVCb0toR2tuZjB6TEcrSXZFNC9yYTBTRjFUMWJvMWMyVmNxVjRGcS94bW5wbGM0VmUwVnloa3hNemV2THNwSTZPaFhWOGZDYVpBWUFuSmYxYTBnOGxmYmVqdFdYQ0FWV2lXckkzaEttcnJYYTdESVB1U0FCeUxpOUNtTVFZTVBuY0JRbklobkpaclJrNFRySXJuVy9WREoxclVqOTdoUm1SMVRwdVBIRURaWWNxU1o3RU9GU3hlVzd5bWhJM1BYQUdqNndXTWFGMHgvVkJma29jajdPdFBueXl3aGM3QnRxT3lBcDVKeE1CUXRoaDIyMG1QcWVxRXZYZmlWeXlndXBLU2RGQU1EUXFhYmlqdFdWNnpyNzdwcVIxZHJ6WkwzcEgxVFUrbzNkdXFGRzVPL1g1TXd4SmEvd2VyZkZieFJtWGRDWWMxYWM3dnFrOVhkMHFiV3p1YkxybFpUK1hOQ3hyMnVuRGtnNDdNTENybG13T1lXcHE1UFo0bUtJYVFNNDVQb1JKakRLL2lodExZTW1MbFdxS0llOC9qMmR2UnFZU0Y4aDJOQVgzNjF4WGw4aWNtNFptMFJyUHFmVmdOb2lacGpnS1YrSTRMSmNWaEpabDZEckhuWGlQY2xtdDQyWmtkYUVjeldYOVNuUTNxa2xzZXo1ZDM1bXo1OXRBTURRcDZZeWtnS1JYMmZrbWUwZW05TGQ3K3ZXdURUWGFYRkd5ckdVWmtzcmlVVDM4aS85Vk9CeVdwSS8vejEvOHdVTjVVTlpWa21Uem1EQ1MxYW9lQUhKK3NlZjBDNVJtNWQ4c1NFQTIxU2N1c0ZFNFpwdkNUMHM2cmVXM2pDbVp2YkdYMWVKbWxheHdCczY5MFdzaGlDbE1nV0RJazdpUnI5TDhNL2xra2tkV0Y1dmFRREEwSld2OGo5RnNEUXFkYU5sY3A4SUlnSDJTbmlOci9CVGJEYzlFOWZjSEJuVnJVN2xlM1Z3cGp5djlyT3FSeDUrWURXQzZKVDJjSitWYkxVbmxaZmFkcWlvcktpUXIvQU9BbkhKNlM1ajZ4STBJZ1BrMWlOWU1oYXhFVmhBOUt1c2IxK1ZNaCsyUnRFWldvTU9zV2M0M0c4U2NwR3RTWVVpTTBWUW41M1FCTEpYVkpiRStFQXlka1hRMlUyRk1JbmhxVUdGOVllQ1hOUjExeHE2bDQ1SitkV3BNend4UDZiYTFOU25ObmpUWEF3OEhaLy82djhGZE8vTmxGcllxd3pEaVhxL1h0cFpTbGVYbGlrUWlkTUVGa0hNdXA2NVlZb0EyMG1wZ2ZvYXNzVWdJWUlwRGhhd20xTjVsTG1kMkpoRGtoOWtneGtOUjVLOUFNR1FHZ3FGR1dXT0dPUEVHMEMwcklGa2ZDSVlxYk41Mkl4QU0xU2UydmRCYWJINU0wdHBzdkZIdlpFU2YzeitnL3poK1JpTXpxYzk4OUdEd3NkbS83c3lqOHZXV2xwVFlPbHRjUlVXWllyRllTZXV0MjcwQ2dCeHlaQWlUNkliVXlPNEI1alVid05DZHBMaDRaQVV4ZEQwckxtNVpVNDdUTFRjUEJZS2hLa25ybFJqZklnL3Eyc3BBTUxRNjBXcG51ZHRlbHRqMldoWGV1SDdiSmIwdTIyKzZlM0JDZi8xMG4zYjJqR282bGx5RGxsQlByM3I3K2lWcjlxeTc4NmlNeTcxZWo2MnRkaXJMbnoxOTF2THBCQ0NYbk5vU3BsckwvOFlYS0ZRTm9qVkRzVEprZGRPc3BpaUtpbGRTYytJTEN1U0JRRERrRGdSRHEyVjlvZVRLczlYM1NWb2JDSVpxMDl4MlY2TGx6eXJseVN5Y0tWb3Q2Uk81ZXZQcFdGdzdlMGIwa1NkUDZYKzZSelF5czNndjFVZWZmSHIycjQ4RWQrMGN5NmQ2NlBYYWV5dFFXZmxzUXk5YTJnUElLY2VkSEFQQmtFdFduMmtBRjZzWExXQmdoVENHckhGaVVCeDhzc2J2NktVb25DMFFESlVuOXBVcmp6ZkRrRFZXakYvU3FXU25MMDRNdkx0U3pwMXUybzdyNWkvSUFTMFNKNk14L2J4M1ZMODhOYW9ycTByMTNEcS90bFNVcU95Q2FhMGZmK3FaMmIvZWsyZGxYVkxtOTl2YkVxYUNFQWFBYzA0bVRsT1Q1eGN1UUNhUERicWlZTlpzOXdhQ21PSlJFUWlHcGp0YVc0WW9DbWRLakg5U1NGMGQvSkxXQklLaG5vN1dscWtsdHIxRzFoY0ZoZHhpNi8yU3JuYlNDc1hpMHBObnAvVGsyU21ycjNLcFcydkx2THEwc2tUWFZ2djA5TDREczAvZG5XL251TklTcjYzZE1Ddk9kVWNpaEFHUVU0NEtZUkpOcmF2WkxjQkZLcFVmWXdvZ3l4ZXBzdnI1ajFBVVJhTStFQXhOZGJTMlRGQVVqcnQrS2RReG05eXlwcmcvMWRIYU1yckF0amNtemxPRnJFM1NIenA1QmVPUytxWWk2cHVLNkpIVEUvcHY4NnhHYXhxbDdoNUplaWpQeXR2cksvWForcVdzMzFjcWw4c1ZqOFZpaERBQWNzcHBMVTRxWmMwR0FXRE9kWU1ZUkE0THE1VTExU3lLeDhwQU1PU21HSndoMFkxNnRRcTdwYUtScUhjMUYyeTdtZGoyUWc5ZzZpVjlUbm5XeW1jOEd0ZUcyd0phODlyZk8zUGQ3Vi9KdDFhVFpYNWZxWkdCaFVaRVN4Z0FPZWJFRUFiQU9WNVpBL0VDaTJrUUFYWXhNV1cxdWtDT3pRa2hpaVVJYlFnRVEzV0piZmRJV2xNRTIyNUsrcUtzSUNZdjFULzM1aHBKUDBpTTJaTVhETU1vZDN2c3o1cExTMHNscVl4UEx3QzU1SmdRSnZHdEhqTytBT2RmK0RXcXNQdlh3NzY2VWs4eEZCWGY3TTB3Y25iZDRwTFVJcW1reURhOUxqSDcwUm9WN2dDOGMvMkZwTllDMkk3WFNQcFpZckJseC9PNDNmN3lNdnV6a3ZJeXY3amZBSkJyVG1vSlU4SHVBSjQxMjhlZTFnMUkrcVpjZkx0WGJPcnk2WnZ0UXBJWUI2VVlBNWhaVlVWeWZucU5wSGNVMFBhOFNOSlBBOEdRMStrckdvdkhLMDNUL3RzVVgybXBTNHl4QnlESG5CVENrRW9EYzI2dVpIVkZBbEpSSzJhWEt6YU5pVUFBMmJWU2pNVlU2SzZVOUxjRnVGMHZsdlFmVHYvY2NMbGNMbitwL2JjR3BTVWxMbGxqN1FGQTdqN2pITFF1aERDQXBVSk1SWTMwbUtKVlliRXBFUU4zWjFVZ0dHcmdNN3JnMVV2Nkp4VnVTNmMzU2JyRHlTdG9HSmtKU2lyS3l3enVPUURrbWlOQ21FU3pTTHBkQU54UVlma3F4VGhDeGFZMk1VZ3FNbis5VWlGbVZpbDBIa2xma3RSVTROdjV3VUF3OUI2bnJsdzhGdmQ2dmZZM0NDNHRLWkhYNCtFNkMwZ3dEQ1B2SG9YQUtTMWhTamdFQUpteVpybmhCaHJMclVkOFMxOWsxMUNTVmxBTW1aVUl1aG9waVlMM01VblhGY20yZmpFUURMM0FrUjlxTHNOVjRyVS9XeTRwS1pGb01Rb2d4NXdTd3ZBTkhtQ05BK09tR0dBRFFwamlVeFlJaGhpWU9iT2F4SmhMaGU0dGt0NVlSTnZya1hSbklCaHkzSlQzOFZnOEk1OW5mcDlQaHN2Z3N4SkFUaEhDQU02NWFXYWdPTmlsUkFSNnhhaUJJc2lNUURCVUxjYVJLSFRYU2Zxckl0enVKa2svY0dDWFJ0UG5zLytROC9sS0pXWVNCSkJqVGdsaHVGbEFNWFBMYWdVRDJJbFFyL2g0QThGUUpjVmdyMEF3NUpZMVVDc0tWNTJrTHhieDllanpKWDNTU1N0a3VBd3pFMU5VdTAxVDhWaWM3a2dBY3NyRmVnRHpuLzhURjJPbHNscXBWTW9hakxGTzFyZk5LMlNORGJCeW5rZGo0am4xc2diWnJVb3N3eWVyMWRlRjlaMXhZSkFKVEo5Ym5PcVpzdHIrTXVVNnBhQ1prcjRneHZ2NWNDQVl1dFVwS3hPSlJNc3lNUUJuYVVtSlpCZ2N6d0J5eWltSlB4K0d5QlZEa2pmeDhDUWUyWml0S3lvcElpa21CcVpHWmhEQ0ZPOTV2VkxTTUVXeGZJRmdxQ1JSbmloYzc1WFZFb1RySWVrL0FzSFExUjJ0TFFOT1dLSHlNdnQ3RGJrOWJoa0dYM3dCeVAzRm1sTSsrSUZzTUJNM3A2V3l3ZzlQanVxZkthWmxSMmE1RW5Vc1NsRVVuUm9Sd3RpRnJxS0Y3Ym1TM2sweFBHdWxwSCtWOU5wY3IwZzhIcy9ZR0RXR0RLNi9BT1Q4SXAzMVFLRXJUZHlVTkV0YUxhdjdUNFdzRmk4RWdPQXpIb1dHc1dGc0VBaUd2R0ttc1VKV0krbnpmRTVlNURXQllPanR1VjZKV0N6bXpkU3lJOUVvWTZZQnlDbW50SVNKc1N0Z001K3NnVW45b3NVSmlwY3BhWVppS0VwTmdXQ29RdExwanRhV0tZb2plWWt4ZGFvVE4ra29USWFrejhnYTN3MFgrMklnR05yVjBkb1N5dVZLK0RNeE8xSXBQWFVCNUo1VDBuOUNHTmpCbmJob1hpMXJnTDBLRWNDQXozZ1VyekpKYXdMQjBLckUyQ1pZUXFJRjBYcFpMU2FadWJGd3ZVblNMUlREZ3Fvay9YdXVCL2syWFJtWUhjbk5ZUTNBR1RldFRoQm5WMkFaL0xJR1R1VHJEZUI4ZExlRFpJVXhaWUZnYUVUU1lFZHJTNFFpT1Y4aXBHcmtQRklVV2lSOWhHSlkwdTlJZXFla3J4WGd0dkVGSFlDY2NzcTNwRndRSXAyYnkwcEpxMlExSitiQ0daai9PQUZtVlVwYUh3aUdhcG5HMmhJSWhveEFNRlF2YVMzbmthSzU3cjFEVnBkbExPM3ZBc0hRNm15L2FldXQyelBhY2k4U2lkQXlFRURPVDBaT3dKZ0ZTT1dtc2xMV04xbTFzbVkzQWdBay94bGFMMmx0SUJncTZzRXBFd1B2cmttY1MxQWNicE4wUGNXUXRFcEoveFlJaHVxekhOeG1MQ1R6bFpLL0FNZzlRaGprMDQzRDNQQ0ZwcVRBMHVqcWlZVjRKYlVFZ3FIR1FEQlVkR01ISmNaK1dTT0pPN0xpMFNUcFR5bUdsRzJUOUdaSjY3SWQzSmFVMkQ5Qmt0dGtUQmdBdWVlVVQ2SnhTVDNzRGl6QUwrdWIyNGlrMHhRSGtMUnBpZ0JMcUpMa0R3UkRwenBhV3lhTFlZTUR3VkNEbVBtb0dQMjFyUEdSa0xxUFNkb3R5Uk1JaHM3SUdsc3E0eUcveDBOalp3Q0Z5UkVoVEdLUXdERjJCeTY0VVBiS0d1L0ZMeXVBWWV3Z0FNakF2WTZrMVlGZ2FFaldsTllGMllJcTBaMmltUnZ4b25TTHBGc3BoclExU0hxL3BFL0xDakI5Z1dDb3Q2TzFKZTlhc29kbmFId1BJUGVZdmhTT3ZGQU9CRU8xc2daSzlGTWlBSkFWdGJLNktCVmNlLzFBTUdSS1dpMENtR0xrbHZTWEZNT3kvYjZreXhOL0w1VzBKb1Bka3pMVzVYdzZIR1pQQXNnNVFoZzQ3VUs1VkZZLy9Yb3hzd3NBWkp0UDFxQzlCUk5XSkVLbEZqSDdVYkc2VGRJNmlzR1dlNFpQenJsM01DV3RDZ1JEVlJsNHI0cE1ib2piN1o1Z2R3TEk5UWNxNEpRTDVWcFozMVF5VUNJQTVNN3N6VlhlajVzeXB3VU01NVhpVkNucHZSU0RiYTZROUtZNS96WWtOUWFDb1RxS0JnQ1NSd2dESjF3a2V3TEIwR3JSK2dVQW5LUWhFQXl0elBMVXRIYWVXMXl5V3NBd3VtZnhlcHVzSUFiMitUTlpBM3JQVlJjSWh1b3BHZ0JJRGlFTWNuMlJYQ1pyN0JjZnBRRUFqbE1oYTV3WU01OVdPaEVjclJJdFlJcFpqYVIzVUF5MnE1UVZ4RnlvMXU0Z3h1TzJmM2lxOGZFSnVWeXVTWFlqZ0Z3aWhFRXVMNUxyRWhmSjFFTUFjQzZmck5tVDhxbEZTYU1JOTR2ZE84UkF6Sm55UmttWHpmUHpXanU3TVphVzJwK2h4dUl4R1FhemJRTElMVzUra1hXQllNZ1ZDSVpXU2FJUE1RRGtCNitzMlZBYzM3SWtNYjRZWFZDS20wL1NXeWlHak40L2ZFenpkeUZ2Q0FSREZVNWQ4Y25KS1JreWFBa0RJT2Nmb2tBMkw0N2RZcHBRQU1oSHBxd1dNWTZkWlNnUURQbGtqUytHNHZaNkVjUmwycldTWHJQQTc1cWMramtSalVabEdBYnpWQVBJS1VJWVpQUGl1RVRXOU5QMDBRZUEvTDF1YUFrRVEzNEhubU5NU2Mzc0l1cW9yQUY1a1hsL0lhbDhucDhia3BxZE9KYlUxUFMwNHZINE9Mc09RSzVQVkVBMkxvNzlzbHJBdUNrTkFNajdhNGRWaVZZblR0SW9xN1VPaXR2elpIM2hnOHlybC9USEMvek9MV21sMDFaNFluSktjY1hIMkhVQWNva2JZbVJjSUJncVQ1eUltWDRhQVBLWEtXdHNHRS9pc1NJUURQVkxta2w4dnB1U1lvbEhYRkkwOGJ0dzRzK3BqdGFXakF5SUdRaUdLalgvTi9Jb1BxK25DTExxYlpLK0wrbllQTC96QjRLaDJvN1dsaUduck96NHhJVGlzZmd3dXcxQUxoSENJS01TZzdNMWlRQUdBUEtOSWFsVWtsOVdOMUx2UE05Wks2bFhWc2dpTGRIQ05oQU16VWlhbERRaGFheWp0U1ZtdzNuR2xOVEE3b0tzY1dDMlVReFpaVXI2cUtRL1dPRDNkWUZnYUx5anRXWGFDU3M3TVRHcDhNek1hWFliZ0Z3aWhFSEdKQUtZbFpRRUFPU1ZFa2tWc2daUVh5cEFkOGtLMm51bHBLWjluVzFGVXlrcEhnaUd4aVVOZDdTMkxHZU1oanJSRFFtV2Jaby9MRVJtM1NUcFprbS9tZWQzaHF5dWdsMU9XTkdSc2JHb0pGckNBTWdweG9SQlJnU0NvYkxFaFRrQUlELzRaUTFzdTFKVzE1NWtXekNhaVp1c1ZLOHBqTVQ3ckFvRVErc0N3VkJsSUJoS3FkVmtJQmp5U3FwbTF5SGhaUlJCenZ5bEZnNURTd1BCVUpVVFZuSjBkQ3dxYVlUZEJTQ1hDR0ZndThSZ2pjMmlDeElBNUlPU3hHZjJDcVhmaXNDVGVIMjZuL3RlV2NIOXVzUTRZc21xWS9jaG9VTFdvTHpJalEyU2Jsdms5L1dCWUNqbjl4M2pFeE9TTk1ydUFwQkxoREN3VldJYTZsVWlnQUVBcHpObHpXNnlVdlowNFNqVjhrTVJqNnlwYlZzQ3daQW5pZk5OQmJzUkNiY2s2Zzl5NTMxYXVHV2FLYWttMXlzNGRIYllsRFRBcmdLUVM0UXdzRTBnR0hMTENtQ29Wd0RnYkxNdEZ1MmVVYWhjMW5ndnkrV1gxU3Btc1M0TU5leEd6SEVqUlpCemxaTGV2OWd4bXhoSU95bXhXTXpXbFF2UHpDZ2NEcHVTK3RsVkFIS0ptMlhZSXRHUGY1VVk3QmtBbks1RzFoZ3VaZ2FYWDJMRGNneEpqWUZnYU9XRjNSZ1NvVCt0WUREWDh5a0NSM2lUcEVzV3VlOUlPandkbjVpMGRjV0doNThkQ29iWmtRRGtGQ0VNN0xMU3BvdHVBRURtenZtTmtqSTlRS1loYTN3WXUwS2VDa21yRThITHJDclI3UlhuckJPVEFUaUZLV3VRM29WVXBUb0F0MTJHemo0N0tSSWhESUNjWDVBQnl4SUlodXBrZjVOMkFJQzlOMFpOc3JvaFpldjk2bTFjWG9ta05ZbHhZQ1I3dWp5aGNOeEFFVGpLalpKZXZNaG5RMDVhc1owZGZqYUVvVHNTZ0p3aWhNR3lCSUlodjVpZEFnQ2NiRGFBOFdiNWZYMnlOeXh4eTJvUlV5c0dZTVg1cnFJSUhPY3ZGemxPbDJxTk41T0pGZW9mUEMyWHl6VVQzTFZ6bU4wRElKY1l2d05wU3pRTlgwbEpBSUJqelFZd3VRb3RhaVJOMm5oVDVaSzlMV3hRR0FoaG5HZU5wTGRMK3RkNWZ1ZEx6SDVteUpwVnJVUldTR3hLY3AvZDgzajEwVzkzMkw1Qy9RT0Q4bmpjdmV3YUFMbEdDSVBsV0tuTURld0lBRmllMlRGZ2N0bHF4SkRVSUttblFNclRTRHd1YkVrY2t4U2Y4eWV5eHlkcEU4WGdTSDhrNlVlU0J1ZjUzVG90TUs2VDRUSXowbEsvZi9DMERCa2hkZ3VBWENPRVFWb1M0OEQ0S0FrQWNLd0daYjhMMG55OHNyb2xqVGk4dkZ5SmRmVWtIdTQ1RDBQSkR3UThHOFpFWmJVQWlpVCtuSDNFcUpxMjJpUytFSEtxTWtsL2R1Q0pmWjkvNkZmM2Z6Z1dqVmJmOU1vWGZYalRsVnZPS2djRGEvZjI5Y2ZENGZBUmRndUFYQ09FUWNvU0F5UFdVaElBNEZnMWNsWlFibmUzSkR0NGRLNHJSSW5zYXpGa0pFSUJVL09IWURPU3BoT1BDVmxoRGRKSEt4Z0hPek13OUx2My8renVXeUl6a1RwSnV2L245MzV5MDVWYi9pUVg2M0txcno4U2k4ZTcyU3NBY28yQmVaR1N4TFNDaldKcVVBQndLcDh5UHcxMXFnemxQcnczRW1WVEw2bEYwaXBaQTh1WEs3dGR0anlKOTZ5VHRIck9lcFJTZGRPeWtTSndwcUgrMC9ySk4zNWd6QVl3a2pROU9mWFN1Mzd3aTJ0eXNUNjkvZjB1U2NmWk13QnlqUkFHcWFyaFFoRUFITXVVMVEzSmlYeVMvRGw0M3hKWndjdHFXVjhpbE10WkxZRTlzcWJzYlVxc1k1MmMwWTBzWDJ5Z0NKeG5lT2lzZnZyTkgycHFZdktpMzNVZFB2RUgyVjZmd2FFaFRVK0hUVW1IMkRzQWNvMFFCa2tMQkVOZU1SMDFBRGhaamNQUDdiWEtUa3RLbDZ4eGFGYkpHa1MrUEUrdWVVeFpnVXh6NGxFaFdwNHVaUzFGNEN3VFl4UDYyYmYvWjk0QVJwTENVOU8zN3Y3bGI1WnN3UlNOMnRkVHJ5djA3TmpnaERBQWNvNFFCcWxvNEdJUUFCeXJWRmJZNEdSdVdlRklwcGl5Z3A3VmlUODllYncvWjcvNFdDMnBtbXUyQlRWVEJNNFJuZzdyWjkvK3NVYk9EQy8yTk9QZ2svdmZ2OVN5SmllbmJGdXZrOTA5Y3JsY001S1lIUWxBem5GQ1IxSUN3VkNackZIdUFRRE9sQzhEcGxkbjRQcGpObnhwa1JYeUZOSVhCcTVFbVJIR1hLeFN1ZW5paG5sRVppTDYyYmYvUjZmN0JwZDg3dlRrMUV0Ly9sOC9hY3ZXdXAwNEdaSzN0TFRudXR1L1VzR2VBdUNFRXp1d3FNUmd2QTJVQkFBNGxrLzVNNDZJSWZ0YXd4aXlCaUV1eFBCbHZtMnRuck90c01iUmdRTk1qSTNycDkvOGdmcEN2VW0vcHZ2WXlmYUpzZkdzVEM5K3JDc1VqeHF1UTVLYUFzRVF4dytBbkNLRVFUS3F4Q0NCQU9CazFYbDRYbG51elpkZjFwZ3ZOU3F1cnJJdVdhMSttc1ZBK1NzNTlIT3Y5MFMzZnREeEhmVjM5NlgwdW1na2Vza3Z2dlBUVjEzMDRYRHBWU04ycitQK1E0ZWpocmQwWCtLZlRZa1czZ0NRc3hNNXNLQkVLNWhhU2dJQUhLc2s4Y2dueTJrTk16c0QxQW81YTVhamJQUEthZ2xTVjhUWGM5VWMvcmtUajhmMTIzc2UxaysvK1VOTmpFMmt0WXloL3RQdnl2UjZEbytNNnZUUUdiZTN1bmJmbkIrdlRFdzRBUUJaUndpRFpDNXczQlFEQURoV3ZvNXhVSm5HZFVpWnJOWXZmSXQ5L3Y1ZnBlSnNGY09NalRreU5qeXFuM3pqQjNyMDNvY1ZqOGZUWGs0MEV0MTgzNy84eTJ2bi9WMHNac3U2SGp4eTFQckEyYlIxM3dYM1FDc0R3UkQzUWdDeWpnOGVMQ2pSQ3FhR2tnQUF4ektVdndPVEdrcCtOaWVYcEhwWkxXQzRkcm1ZS2F0VlRMRjF6YXBtMTJmZnNmMUhkT2RYL2t1bnVucHNXZDV3VC9kbjkvenRuMy8zMkhlL2RzM2NuMDlNVHRxeS9BT0hqOHJ0ZGs4MHZmZ1ZGNjV3aVJqekVFQU9jQ0dEeFZTSlZqQUE0R1NsZVg0dVQ2Wkxra2ZXMkIvbDdPNmt6dHROV3Y1NE8vbWltbDJlUGZGNFhBLzk2bjUxZnU5L0ZaNmF0bTI1bnFaTmFscTU2dW96VHdhL3QrZjJEMy91ekZPL3JUSk5jOGF1NVI4NGRGaW10MlRmUXNkTUlCaGloaTBBV1VVSWc4WFFDZ1lBbk0yWDUrdnYxdUl0ZWZ5eUJxRDFzS3VUVnBJb3M1SWkyRlphTVdSSlpDYWlYM3pucDNweTkyTzJMdmQxejc5Q1QvM3pCM1huVjc3ZytsVDdYOGhuNkpYZFAveldMMkt4bUcwdHVuNzc1TlBSdUxja3VNaFRWaVJhZndOQVZoRENZRjZKVWVPNTZBVUFaeXVFY1VBcUYvbjVDaFZYOXhxN3pIWlBLdlN4YzFhd3F6TXZQQjNXenYvNGtib09IYmZ2QnNRd2RQdmJYcTRmL09YdnE4Sm41WVhiWG5TenZ2KzFmemF2dWVMU21uZzhia3RMN042K2ZwMGVPbU9XTmpUOWRwR25lY1cwN3dDeWlCQUdDNkVWREFBNG01RzRlY2gzcGJxNCsweTltSm5QanZyUlVPQTNsMDNzNXN5S3grUHEvUDcvcWkvVWE5c3k2eXZMMVBtM2Y2Q1B2T0VXR2NiNUdXdDFWYVgrL2xNZk4yNTYzZzBhSDU5WTluczkvdlFlR1lZUlgvR0NXeDlmNHFtMXRJWUJrQzJNOTRHTEpLYnNvMzhzQURoYklVMnZXaTVwZUU1d3dEbklQcld5UXE0ekJiWmRwYkxDT21UUWs3c2ZVL2ZSazdZdDcvcE5MZnBoKy8vVm1vYnFCWi9qY2J2MW1ZLy9wUTRjUHJMczkzdmk2VDN5bHBZZXJ0eDgyZGdTVC9YSW1tbHNoTDBPSU5NSVlUQWZtbVFDZ1BNVjB1Q3I1WW1ibnhYSy8zRnVuS2hLVnV2bjAvbStJZC83cDIvOXdkVGsxSllWcXhwN2I5NytZcFZWTWw1ekpoMTRmSzl0eTNySHRsYjl5N3RmcXhMUDByY2ZIcmRiVjJ6ZHN1ejNmT2pSeHlNeFQ4bURLVnovRXNJQXlEaENtRHlWYURMcFRseUVtNG1McXd1YlVjWVNmMFlUajBoSGEwc3N5Wk1RQUlCemVMYk16b0RrWmJkbVRFWGlPbUV3WHpmZ2w5LzczeHZPbmo3ekY1TFVkZWk0L3ZPTFg5ZjZyUnQxN2MydHFtOWlqRjY3UldZaU9udDYrUTJvM0c1VC8vS2UxK2tQZnFjMXErdC8vR1JJcC9yNjNaVmJycmczeVpmNEE4R1F1Nk8xSmNMZUI4QUZYQkZMaEMwbHNwcmRsaVF1VUwxSzh4dlFRREFVbHpRaktTeHBPdkhuVkVkcnkwemk5MzdxQlFEa2hVSWJQSjBBSnZQS0pjV1ZweTFpZW82SDNqSDMzL0Y0WEVmM0hkYlJmWWUxZnV0RzNYQnJtNnJybkR1azNkVEVwRXI5K2RQUWEyeDRkTm5MYUtxdjF2LysxVnQxM2NaVldWLy8reDU4UktacFRyZTg0ZzJQcFBDeUNoVmUxejBBRHNQTnRnTUZncUVTV1RNYStHVTF5N1p6b0xEWmdSeTlpWXV4MmZlTVNKcWtUZ0JBM21BUVNhU2pRbFpMMmJ5NjBUeXk1MkJWZUdyNmhRdjkvdGorSXpwKzRLZ3V2ZjRLWGYvQ0crUXZkOWJFVU1jUEhGVThIdGY2clJ2enBzekQwOVBMZXYwTHI3NUVQL3p3NzZtMklqZERQUDNtd1lkalpxbnYvdElWVGVFVVh1WVRJUXlBRE9PRzJ5RVN3VXVsckdERWs2TzZVTUdlQUlDOHdReUhTRmVWckc3S2VUUCt4ZE1QUFhHVGxtZ0ZISS9IdGZlM1QrdmdrL3QxeFExWDZmSWJybEo1Wlc0dWJhTFJxRTUxOWFycjBIR2RQSHhjWndhRzlPcTN2ejZ2S2tsa0pyMWVPWVpoNktOdmVvays4WHUzeW1Ya0ppc2VHUjNWVTN2MkdiN20xYnRTZkNsalVnSEl5bzAzY2lUUjFhaENVcldzN2tZQUFDUjlyME1SWUJscVpYVlBuc3lIbFIwZUduNUI4dUhCako1NDRGRTl1ZnN4TmExcDFwcEwxbW4xeGpXcWJheS9hRXBrdTBRaUVRMTA5K25VeVY2ZDZ1cFJ6L0hRUlNGR2xZTzdTdG1sdnFwYzMvMkx0K2dsVjIvSzZYcDAzbjJmSk1WWDNQaVN1MU44cWNtNE1BQXlqUkFtQndMQmtFdFc4Rktqd3ByZEFnQ1FQYlNFd1hLdGtOUWpLNHh4dFBCMCtQcFVYeE9QeDlWN29sdTlKN3IxOEs0SFZGSmFvcVkxemFwcmFsQkQ4d3BWMTllb3NxWktMcGNycFdXT2o0enB6TUNRemd3TWFhai90SWI2VCt2MHFRSEZZZ3ZQZmVEeGV1UXZMK3laMTMvbjJrdjByVDk3c3hxcmN6OWoxVTkrOGF1WXQ2ejh3ZHBybjV0TzF5SzNKRUlZQUJsRENKTkZpWll2MWJLK2ZTSjhBUUFzUjR3aXdESVpzb0tZWGlmWHA0TlA3YStKUmFOcmxydWM2YWxwblRoNFRDY09IanRYQUlZaFg1bGZaWlhsS3ZXVnlsUGlsZHZqVml3YWZiWWxTelFTMWNUWXVDYkdKalExTWFsNFBKN3llMWZXVmhkc0pmSjYzTHJqN1MvWG43enF4b3kxTkVyRnNSTW50Zi9RWVZmWm12VS80UDRJZ0JQeElaTWxnV0NvWEZLRENtODJDd0JBYnNRcEF0akFJNmxlVXI5VFYvRG9ua05iTW5ZUXhlT0pnR1U4bzl0UW5ZZGRrZUt4cFQ5aXJsNi9VdC82c3pmcnluVk5qbG52bloyNzVIYTdSOWUrL20yL1NuTVJmRkVLSUtNSVlUSXNFQXk1WlgzTFZFNXBBQURzdkVlaUNHQVR2NnpKQVJ3NVVPL0ltWkdOK1Y3QVZiVlZlYmZPaXdWVEhyZXBqNzM1SmZydzYyK1J4KzJjekdKNk9xd2YvNnd6YXBSVmZEL0ZXWkhtWXJ3dEFCbEZDSk5CZ1dDb1VsWUFRNzk5QUlEZDZJNEVPOVhJR3FUWGNlUER6SVRESy9POWNMM1JxYnhiNS9HUnNYbC8vcHpOYS9UMVAzbTlybGpiNUxoMS92bGRkMnRzZk54WWVldXJ2cjJNeFJEQ0FNZ29RcGdNU0F5ODJ5aW1mQVlBWkE0RFI4Sk9ocXh1MHowT1hMRzhyK3NyTnF6UHUzV2VHSjg0NzkrbGZwOSsvM1V2MGxmZmRMTWp4bjY1VURRYTFkZi82L3RSYjNuRnI1cGUvSXFlWlI0TEFKQXh0TkN3V1NBWThrcGFJd0lZQUVCbUVjTEFibDVaM1pJYzVZcm5YZk1kbDJsMjUzUEIxclUwNTkwNkc0a3N3akFNWFhIRDFYcnorOTZxdDd6b2VrY0dNSkwwODd2dTBhbitBYlBxeXVkOGFabUxvcXNuZ0l5aUpZeU5Bc0ZRbWFTVkl0d0NBR1RlaktScGlnRTI4MGs2TFFlRmZGYzk3OXJqM2hMdnk0Sy91dThqVTVOVHQ4WHk3REtyek9lUnQ4U2JkeFZoMVliVm1nblA2TXJuWGFPYWhscXJjcmlkV2ZiVDAyRjk1ZXZmam5yOFpUOXJlZFVibjdiaHN4VUFNb1lReGlhQllLaEtWaGNrQUFDeUlTeHJhbUhBYmxNZHJTMU9xMXNuVzIvZC90NklZZDUyeTJ0L1QvY2Y3bFB3VUNndkNyT3hPVDh2RDlkY3NrNXJMbGwzM3M5OHBqTkRtUC82NFk4MU9EUVVpOFZpNyt0b2JUbkpJUXpBeVdpeFlZTkFNRlFyQWhnQUFGQVlLZ0xCVUtrRDE2dk1IWS9xdGhzdjFTTi85ejZkK1BlLzFKZi82TFY2ZmR1VnFxOHNjMnhoYnJqMkNtcFVCb1Y2ZXZXMWIzMDNGb3ZGZGdSMzdUeEJpUUJ3T2xyQ0xGTWdHS3FYVkV0SkFBQ0FBdElneVdrdENqeVM1UGRaK2RDYWhtcTk1eFhQMTN0ZThYekY0M0h0Qy9VcmVEQ2tSdzZlMUtOSHV2WFVzVjVOaG5QYnM4UjBHVnE5YVYzQlZJcFkzRm5EcGNSaU1YM3k4LzhRazNSTTB1MGN0Z0R5QVNITU1oREFBQUNBQXVVTEJFUCtqdGFXQ2FldG1HbWFGLzNNTUF4ZHRycFJsNjF1MU50ZWN2MnpnY0h4dmpONjZuaXY5bmIxNlZEUGFSM3VIZFNobmtIMW5SM0x5cnBlZXRYbXZCd1BaaUhUVVdlRk1OLzR6cDE2NnBtOThWZzgvcWJncnAyTWtRVWdMeERDcENuUkJZa0FCZ0FBRktwNlNWMU9XNmx3a3ExYlhJYWhEVTIxMnRCVXE5Yys3L0x6ZmpjMkZWYlh3QmwxOVo5VjE4QlpuUndjVnQvWlVmVU9qYXJ2N0toT25SblYwTmlreHFmQ0thK2ZZUmhxcmlxVk1kd1hmZjcyVzgxQ3FoQVJCN1dFZWVEaG9EcSsrWi94ZUR6K3dlQ3VuWTl5dUFMSUY0UXdhVWdNd2x0UFNRQUFnQUpXR2dpR1NqdGFXNlljc2o3amtqUWREaTk3UWVXbDNtZGJ6aXdtRW8xcGFHeENZNU5oalV4TWFXSjZSdUZJVkxGNFhDTVRWckg0U3p6eXV0MnE5SmRvUlZXNW1tb3E5S2NmL1p2NG9icjZzTXMwZllWVUljWWpNVWVzeDk0RGg5VCtxVHVpcG1sKzU4RmYvUGlMSEtvQThna2hUSW9TMDFBekNDOEFBQ2dHTlhMT0xGd3praFNKUkxOM29XeTZ0S0txWEN1cVVudmRrM3YyeFJ0KzV6VytRcXNNNDlIY2h6QUhqeHpWK3o3eXNXZzBGcnM3RW9tOGkwTVVRTDVoZHFRVUJJSWhyNlNWbEFRQUFDZ1NGWUZneUNsZjJrMUswdFRVbEtNTDdGVC9nS2FtcGx5K2xhc0tyakxrdWlYTVE3OTlUSC80Z1E5SHA4UGgrOExoOEd1Q3UzYUdPVVFCNUJ0Q21DUUZnaUdYcEdiS0RBQUFGSmxLSjZ6RTdNQ3JrV2pVMFlWMTdJUTFqRTdwaXNMNzNxNXZaRHduN3h1TlJ2WFZiLzZuM3QvK04vR1pTT1RiNFhENHBjRmRPeWM0TkFIa0k3b2pKVytGSkMvRkFBQUFpa3lWcENGSFhMaTYzZVBESXlObFRpNnNZMTBoZVgyK0dYZFpoYWZRS3NMVFI3djBpVi8rdDk1NTI1dTB1ams3SWRQalR6K2pPLzd4SzlGalhTZWo4WGo4angvOHhZLy9qVU1TUUQ0amhFbENJQmlxbEVPK0JRSUFBTWd5ajFNRzZIV2I1cG16dzg0T1lmcjZCMVJTVlJPV1ZIQWhUT21LcHVGZmZmVTNrei83MWErYlhueFRXL3dOcjM2bGNkMVZWOGd3REZ2Zlp5WVMwZjBQUGFMdi9QQW5zU2VlM3VQeWVqejN4R0t4L3hmY3RmTW9oeU9BZkVjSXM0UkVQK2dWbEFRQUFDaGlGWkp5SHNJWWhuRjY2T3h3aTVNTHFuOXdVR1pWVGJ3UUs0SExXMUpldHZXcUZXZWVmdlNOOXozNHlJZnYrczBEVnpTdGFJaTg3Q1czdUcrNThmbmF1bm1UWEdrR01yRjRYSHYySGRCZHY3bGZPenQvSFIwWkhYVjVQWjU3SlgzeWdaLy82QjRPUVFDRmdoQm1hU3ZFT0RBQUFLQzRsVXNheVBWS1JDS1IzdUhoNGF1ZFhGRGR2WDBSVDMyTHIwRHJnYm4rOS82d3RyUDFFOStXOU8zV1c3ZGYzejh3K1BadjMvbWpOMy9qTzNmV2w1ZVZSYTY1OGpMenNpMmJqVFdybXJXbXBWbE5LMWFvdk13dnQvdmNiY2ZrMUpUNkJnYlYwOXVuSThlT2ErL0JRd28rL2xSa1pIVFU3ZlY0ZXNNek0xK1g5SzhQL1B4SHh6bjBBQlFhUXBoRkpLYWpMcWNrQUFCQWtmTUVncUdTanRhVzZWeXV4RXdrMG4xbWVDUW1CMzlCTm5oNktPN2RjRVVoWDJNM1N6b2xTY0ZkT3grVjlHanJyZHYvUk5JMVkrUGp2L05nOExHYkhubnN5ZXRuWm1hYTR2SDRzODFpVE5PTW02WVpDNGZENW5rVnkrMCtZeGpHNCtHWm1ic2wvZnlCbi8vb1VRNDNBSVdNRUdZQmdXRElrTlJBU1FBQUFFaVMvSkttYzd3T3AzcFA5VVhrNE1rU2hrZEh6WlZsQmYwZFh0T0ZQd2p1MmhtWDlIamljWWNrdGQ2NjNTdHBvNlJWa3NxajBXaFZOQm8xSkUxSUdwZlVJNmxyOXk5K2ZKcERDMEF4SVlSWldMV1lEUWtBQUdDV1g5S1pISy9EaWI3QjA0NjlmcDJlRG10bVpzYmxLUy9vK1J5U0dwTW51R3RuV05LK3hBTUFrTUJZSi9OSXRJS3BvU1FBQUFDZTVZUnhUazZFdzJIWDJlRVJSeGJRMlJGcnZkeEYxaElHQUpBOFFwajVWWXRXUWdBQUFPZGROd2FDb1Z5M0VqNHVTYjE5Zlk0c29LRXpWa01odDcrc2tPdEJNNGNDQUN6alpFb1JuSTlXTUFBQUFBc3F6Zkg3ZDBuU3FmNEJSeGJPOE1pb0pNbGRWbEhJZGFDRnd3QUEwa2NJYzdGeTBRb0dBQUJnUGlXNWZQUGdycDFUSHJmN2RIZXZNMXZDbkIwZWtlRnl4VTJmdjVEckFOMlJBR0FaQ0dFdVZrVVJBQUFBektzazF5dGd1RndIajNlZGRHVGhuRDV6UmlVK2Y3akE2OEJLRGdNQVNCOGh6QnlCWU1namErUi9BQUFBWEN6bk0wZUd3K0duVDV3TXhaeFlPR2ZPanNoVFhoRXA4RHBBdDMwQVdBWkNtUE5WVWdRQUFBQUxjaWZHejh1bEEwZFBuSFJrQ0hQNnpCbVpaUlh4QXE4RHZrQXdWTUtoQUFEcElZUTVYemxGQUFBQTRPanJ4NE9qWTJQdTBiRXh4eFZNNzZtK21GbFQ3eW1DT2xETFlRQUErWGtTZFl4RVZ5UlNmUUFBZ01XWk9YNy92WkowdkN2a3VJTHA3ajBWTGFscktJYnJTYm9rQVVDYUNHSE9LYU1JQUFBQUhILzllTnpsY29VUEh6dnVxRUtKUkNJYU9EM2s5bFlYUlNNUlprZ0NnRHc5aVRvSkEvSUNBQUE0L1BveHVHdG56T3Z4SER4eTdJU2pDdVZrZDY5aXNaaFIybGdVa3djMWNoZ0FRQjZlUkIzR1J4RUFBQUE0Ly9veFBEUHo2S0dqeHgwMUFPN3hrOWEwMmFYMVJaRlBOSE1ZQUVDZW5rU2RJQkFNZVpYNy9zMEFBQUQ1SU5lekl5a1dpejF4Nk9neFI4MlFkUFI0bDN5VlZWTXViMUVNTVVoTEdBQklFeUdNaFFGNUFRQUE4c2ZUWStQajVzRHBJY2VzMFBHVElaWFVOMGFLcFB4WFV3VUJJRDJFTUJaQ0dBQUFnT1FZRGxpSHB5WHBpSU1HNXoxeTdFVEV1M0oxc1l3eHVKYkRBQURTUXdoajhWSUVBQUFBU2NsNUNCUGN0YlBmNDNhZlBleVF3WGxqOGJoT2hMcGRwWTByaStYYW1oQUdBTkpFQ0dQeFVBUUFBQUJKY2NTQXVDN1Q5WXhUcHFudTZUMmxtWmtabDIvRnltS3BBeXNUWXlvQ0FGSTlmMUVFa2doaEFBQUFrdVdJRUdaNk92em93Y05ISFRFR3kreDAyYVZOcTRxbERoaGlYQmdBU0FzaERPVUFBQUNRajU0NmZqTGtpc1Z5UDBuUzRXUEg1YXVzbWpKTFNvdXAvTGRTQlFFZ2RVVWZQZ1NDSVlOcUFBQUFrTFM0UTliajZVZ2s0dXJxN3NuNWlodzVma0lsalN1alJWWVBObkVvQUVEcWFBSGlqQkgrQVFBQThrWE1JZXV4VDVLT25laksrWW9jT0h4MHBxUjVyYi9JNmdFaERBQ2tnUkNHRUFZQUFDQVZqbWdKRTl5MWM4enI5ZmJrZW9ha21VaEVvWjVldDY5cFZiRmRVOUlkQ1FEU1FBZ0RBQUNBVkRpbTIwMDBHbjNpeUxIak9RMkZqcDNvVWp3ZU4zekZNeWp2ck1zNEZBQWdkWVF3dElRQkFBQkloVk82SXlrYWpUNTU2TWl4bVZ5dXc2RWp4MlM0WFBIU2hxWmlxd2ZOZ1dDb21zTUJBRkpEQ09PY3dlVUFBQUR5Z1pNR29OM1QzWHZLTXhQSjNVelZoNDRkVjFsZHc2Umhtc1ZZRnk3bmNBQ0ExQkRDQUFBQUlGbVJqdFlXSjMyQnRTY1dqeHNudWtJNVc0R0RoNC9HdkN0WEYrczFOU0VNQUtTSUVJYVdNQUFBQU1rS08yeDk5aHFHRVR0eVBIZUQ4eDQ0ZkRUbWExbGJXcVQxNFJvT0NRQklEU0VNSVF3QUFFQ3lIQlhDQkhmdERIczhucTZqeDNNelRmWGcwSkJHeDhiYy9wVXR4Vm9mcnVPUUFJRFV1SXU5QUJKTmFnOVNGUUFBQVBKUE5CcDkvUEN4NDJ1Vmc4a1dEaDg5TGtueU5SVnRDSE5sSUJneU8xcGJvdFJFQUVnT0xXRUFBQUNRdDZMUjZOT0hqeDNQeWNpOEI0OGNWVWxaV2RoZFhsR3N4ZStYdEpsYUNBREpJNFFCQUFCQVBqdlkxei9nanVSZ2hxUkRSNDdKMTlnOFUrVGwzMG9WQklEa0VjSUFBQUFnbisyUHhlTkdxUGRVMXQvNHdPR2prWkpWNjN4Rlh2N1Bwd29DUVBJSVlRQUFBSkRQRGtuU2laUGRXWDNUOE15TVRvUzZUVi96Nm1LL25pYUVBWUFVRU1JQUFBQWdid1YzN1J6eHVOMURKN3Q3c3ZxK3gwNmNWRHdlTjN6Rk96UFNyQ3NEd1ZBNU5SRUFra01JQXdBQWdQeStvRFZkQjQrZlBKblY5engwOUpoY3Boa3JiV2ppZmtLNmdWb0lBTWwvYUFJQUFBQjVhM282L0hUWHllNVlOdC96NE9HaktxdGZNV1c0dUp3V1haSUFJR21jTlFBQUFKRHZEaHpyT3BuVkVPYlFzZU14ejhyVlhFdGJicVFJQUNBNW5EZ0FBQUNRN3c0T2o0eTZ4OGJIcy9hR2g0NGNpL21hVjVkUzlKS2s1d2FDSVlOaUFJQ2xFY0lBQUFBZzN4MlFwSzVRZGdiblBUTThySkhSVWJldnNabVN0OVJLMmtJeEFNRFNDR0VBQUFDUTc0NFpoaEU5ZmpLVWxUYzdjdXlFSk1uWHRJcVNQK2NsRkFFQUxJMFFCZ0FBQUhrdHVHdm5qTmZyNmNuV05OV0hqeDJYcDZRMDRxbXNwdkRQZVJGRkFBQkxJNFFCQUFCQTNvdEZZM3RPWkxFbGpHOUY0eFNsZnA0WEI0SWg3aTBBWUFsOFVBSUFBQ0R2elVRaWU0OTNoU0xaZUs5RFI0OUZ2YzFyU2lqMTg5Ukl1b1ppQUlERkVjSUFBQUNnRU96djZ1N0orTFZ0UEI3WDBlTmRocStweFVPUlgrVEZGQUVBTEk0UUJnQUFBSVhnWURnY2R2VU5ER2IwVFU3MUQyaHFldHJGb0x6enVwVWlBSURGRWNJQUFBQ2dFQnlVcEs1UWQwYmY1TkRSWTVJa1h4UFRVOC9qcGtBdzVLVVlBR0JoaERBQUFBREllOEZkTzN0TjA1ek1kQWh6NVBnSitTb3FwODFTUDRWK01iK2s1MUlNQUxBd1FoZ0FBQUFVQkkvYmZhd3JsTmxwcW84ZU82R1NocVlaU250Qkw2TUlBR0JoaERBQUFBQW9DT0dabVQxZDNUM3hUTDdId2FQSElpV3IxdElNWm1HdnBBZ0FZR0dFTUFBQUFDZ0lzVmhzMzdFVFhaRU1MbDlkb1I2enRLbVphK2lGWFIwSWhsb29CZ0NZbjVzaUFBQUFRSUU0ZktwL3dCMk5SbVdhcHUwTDd6blZwMmcwYXBUV04xSFNpM3VscEk1QzM4aHRPM2FYU2xvaHFVeFNpU1N2cExDa1NVbkRrdm82Mjl2aVZBY0FjeEhDQUFBQW9GQWNqTVZpUm05ZnYxcWFWOXErOE9OZElVbFNhVU1qSmIyNFY2aEFRcGh0TzNZM1NMcFUwbFpKV3lSdGxyUlJVck9rcWlWZVByTnR4KzZRcENja1BTcnBYa2tQZHJhM1Jha2lRUEVpaEFFQUFFQ2hPQ2hKSjA2R01oTENkSFgzeU92emgwMmZuMm1ZRjNkcklCZ3E3V2h0bWNxWEZkNjJZM2VUcE1za1hTRXJkTGxVMHVXUzZwZXhXSStrOVluSDZ4SS9HOXkyWS9lZGtyN1UyZDYyajZvQ0ZCOUNHQUFBQUJTRTRLNmRaNTcvc3RlT251enByY2pFOGsrY0RNbFgzeENXMWUwRUMvTkxlcUdrWHpwdHhiYnQyTDFTMHBXeUFwZkw1L3habGFWVnFKZjBSNUwrYU51TzNUK1c5TUhPOXJZalZCbWdlQkRDQUFBQW9HQ1lwdXRRVjZqN3Vrd3MrMWpYeVppN1lhV0hVazdLSzVYREVHYmJqdDJWc2xxMVhDRXJkSmw5MURxb2pGNHI2UlhiZHV4dWwvUjNqQjhERkFkQ0dBQUFBQlNNbWZETW5oTW51NitWWk5pOTdPTmRvVmpaamJlV1VNcEplWTJrUDhuMG0yemJzZHN0YTd5V3EzVis2TEkyVDhySksrbnprcDYzYmNmdTJ6cmIyOEpVSGFDd0VjSUFBQUNnWU1UaThZUEhUNFlpc3NianNNM1U5TFRPRGcrN2Eyc2JLT1RrckFrRVE5ZDN0TFk4YXRjQ3QrM1lYU1hwR2xtQnk5V0p2MTh1YTJhaWZQY0dTU1hiZHV4K0EwRU1VTmdJWVFBQUFGQklEZ3llSHZLRVoyYms5ZGlYdy9UMDlrbVNTbXJyS09Ia3ZVN1dyRUFwMjdaajkzcWRDMXhtLzF4WDRPWDFLbG16U3IyRHFnTVVMa0lZQUFBQUZKTEQ4WGhjb2U1ZWJWaTN4cmFGOXB5eVFoZ3ZMV0ZTOFFaSmY3WFlFN2J0MkcxSTJpVHArc1RqT2tuWFNxb3Awako3KzdZZHUzL1QyZDcyZGFvUFVKZ0lZUUFBQUZCSURrcFNWM2UzclNGTWQrOHBlVXRMWjh5U1VnYm1UZDZXUURDMHRhTzFaYjhrYmR1eDI1UzBXVmJRY3IyazU4aHE1VkpCVVozbkM5dDI3UDVwWjN2YklFVUJGQjVDR0FBQUFCU000SzZkNHplKzRuZFBuK3p1dGJYZlVNK3BQcFZVMTRabDgxZ3poVzd5OU5RbnR1M1kzUzNwdWJJQ0Z6K2xzcVFhU1IrWDlENktBaWc4TG9vQUFBQUFoY1F3ZE9oRUtHVHJNbnRPblpLN3RzR2dkRk5qZWx4dmxQU25rdHBFQUpPS2QyM2JzWnNCaUlBQ1JBZ0RBQUNBZ2pJOUhYNm02MlIzek01bGRuWDN6SGpyRzMyVWJtcThsVjY1UzJsOG53YWZwSGRSREVEaElZUUJBQUJBb1Rsdy9HUW9hdWNDQjArZk1UeFYxYlNFU1VOWkl3MWcwdlFtaWdBb1BJUXdBQUFBS0RTSHpnNlBlQ1ltSm0xWjJFd2tvdEd4TWJlbnZJcVNUUU1oVE5xdVMwelZEYUNBRU1JQUFBQ2cwQnlTcEs3dUhsc1dkbnJvakNUSlcxMUR5YWFocE1vcmo0OHVTV202aVNJQUNnc2hEQUFBQUFyTlljTXc0bDJoYmxzV05uaDZTSkxrcWFBbFRMcG9EWk8yR3lrQ29MQVF3Z0FBQUtDZ0JIZnRESHM4bmw2N1c4SVF3cVN2YkdVWmhaQ2V6UlFCVUZnSVlRQUFBRkI0NHZIOUowUDJoREJuUjBiazluaWlocHN1TmVueWxudmtLZk5RRUtsak1HaWd3QkRDQUFBQW9PQ0VaMmIySE92cWl0aXhyT0dSRVhuOEZTYWx1anpsVFhSSkFnQkNHQUFBQUJTaVExM2RQYmEwSWhnZUdaWGJUM2VhNVdKY0dBQWdoQUVBQUVCaE9qQXhNV21lSFI1WjlvS0dSMGZsOGhIQ0xKZW56Q052aFplQ0FGRFVDR0VBQUFCUWlBNUowZ2tiWmtnYUhpR0VzVXRGU3ptRkFLQ29FY0lBQUFDZ0VIVzVEQ05peHpUVkk2Tmpjdmw4bEtnTnlwdjhNa3pHbWdWUXZBaGhBQUFBVUhDQ3UzWkdQVjVQVjZpN2Q5bkxHaDJma052SGVDYTIzSHk0WFl3TkE2QzRQd2NwQWdBQUFCU2lTQ1M2NS9qSjBMS1hNelkyTHBPV01MYXBwRXNTZ0NKR0NBTUFBSUNDRkkxR0R4dy9lWEptdWNzWm41aVFXVW9JWTVlU3FoSjV5ejBVQklDaVJBZ0RBQUNBUXJVLzFOMXJ4dVB4WlMxa1ltSkNaa2twcFdrakJ1Z0ZVS3dJWVFBQUFGQ29EczlFSXE3K3dkTnBMMkI2T3F4b05FcExHSnVWcnl4amdONGtxeUJGQUJRV1FoZ0FBQUFVcWdPU3RKd1prc2JHeDYyTFprSVllMjlDR0tBM1daTVVBVkJnbjM4VUFRQUFBQXBSY05mT1U2WnBUcDQ0dVp3UVprS1M1R1pnWHRzeFFDK0FZa1FJQXdBQWdJTGxjYnVQbmdpbFAwUFNiRXNZdWlQWnI2U3FSSjR5QnVnRlVGd0lZUUFBQUZDd3d1SHdFOGU3bGgvQ3VFb0lZVEtoWWxVWmhRQ2dxQkRDQUFBQW9HREZwSU5IVDZRZndveU9XU0dNMjhmNEpabFF2ckpNaHNFQXZRQ0tCeUVNQUFBQUN2ZGl0NlRpeE9EcFFVMVBoOU42L2Nqb21Ed2xwUkpCUVVhWVhsTytlcWIvQmxCRTV5V0tBQUFBQUFWN3NldXJQUmFQeDlYVm5kN2d2S05qWS9MNDZES1RTZVVyS2Q5Rm5LVUlnQUk3TDFFRUFBQUFLRlQrVFMvcWt3eDFoWHJTZXYzbzJEaUQ4bVo2SHpYNDVISnpXd0tnT1BCcEJ3QUFnSUpsVnF5TWxaUlg2M2pYeWJSZVB6d3lJdFBQVk1xWlpMZ00rUnNJdWdBVUIwSVlBQUFBRkxJU3cxZVhka3VZb1ROblpmanBMcE5wZEVrQ1VDd0lZUUFBQUZESXh1S2xOVHB5b2l1dEZ3OE9uWlc3b3BKU3pMRFMyaEs2SkFFb0NuelNBUUFBb0pDZE5mMTE2Z3FsTnpEdm1lRmhlUWhoTXM0d0RKWFdsbEFRQUFvZUlRd0FBQVh1cWU2ejVwNitVWk9TUUpFYU0vMTFtcHFhMHNEcG9aUmZQSFRtck54bGpBbVREZjU2eG9XWnh4UkZBQlFXUWhnQUFBcGNKQkw1STBsL1EwbWdHSFcydDBWYy90cHBTZW82R1VycHRXUGo0d3FIcCtXcHJLWWdzNEFRWmw2RU1FQ0JJWVFCQUtDQUJZLzBsY2ZqOGQrVjlORTlmYVBiS0JFVTVRVnZTY1dJNlNuUjhSUkRtTDZCUVVtU3Q3cVdRc3dDczhTVXU5VHRoRlhwWlc4QXlOZzVpU0lBQUtCd3hhVVB1a3l6U3BJaDZkdDcra2FiS1JVVW9YNXZlWjFPbkV4dFhKaFQvUU9TQ0dHeXFhVFNtOHUzSDVMMFFVbVhTSXF5TndCa0FpRU1BQUFGNnBFamZTc2xmZEJ0bXFzU1AycVE5QjNHaDBFUjZvbVYxS2JlRXFaL1FKNlNVcG1sZEpQSkZyY3ZKeTFocGlUZElXbGpaM3ZiRnpyYjI4WWxoZGdiQURMeU9VY1JBQUJRc0Q0aHlYQ1pyc1k1UDd0WjBxY2xmWVRpUVJIcGMvbHFkZlRFdnBSZTFOdlhyNUlxV3NGa2s4dHRaUHN0NzVUMEY1M3RiU2N1K0htWHBMWHNFUUMyZjg1UkJBQUFGSjVIanZSZEp1bWRobUVjbStmWEg5N1ROL3B5U2dsRnBNZmxyOVhBNEtDaTBlUjdtWnc0MlMxM2JRT2xsMFdScWF6MUFucEswb3M2Mjl2ZU9FOEFJMG1ISFZJa2NXb0ZVRmdJWVFBQUtFeWZsV1NhcGpteHdPKy90YWR2dElWaVFwSG9NLzIxaXNmakdodzZrL1NManB3NHFkSW1obEhLbHVoTVRPTjlFNWwrbXlGSjc1RjBYV2Q3MnoyTFBPOFpoeFRMTURVREtDeUVNQUFBRkpoSGp2VGRJbW03SkpsdXMzcUJwOVZKK3U2ZXZsRVBKWVlpY05KVldpVko2ay9NZUxTVVNDU2k3cDVlbFRZMFVucFpjbnIva0dLUldLWVdINVgwVDVJdTZXeHYrNWZPOXJhbG10enNZNDhBeUFUR2hBRUFvSUE4Y3FUUGtQVDV4RC9qcHVuYXNNalRiNVIwdTZ6WlFJQkNkdFR3K09ReVRaM3FIOUNWbDIxZDhnV2gzbE9LeGFJcWJhUWxURGFjUFRhaThWTVphd1d6VzlKN090dmJua3poTllRd0FES0NsakFBQUJTV3QwaTZYcElNd3podUdNWlNNeUg5K1o2KzBWZFJiQ2h3UnlYSlUxS3VvVE5uazNyQmlTNXJjaHhhd21UZTJhUERPblA0YkNZV1BTRHBYWkpla0dJQW84NzJ0dU9TenJCM0FOaU5FQVlBZ0FMeHlKRStyNnlaajZ5VHZNczFtT1JMdjdtbmIzUU5KWWhDMWRuZWRrYlNHWmVuUkNOalkwbTlabnhpUXFiYkk1ZTNoQUxNa0hnMHJvRm5UdXZNRWR1SFBZbEorbWRKV3pyYjIvNjlzNzB0M2NGdEgyVXZBYkFiM1pFQUFDZ2M3NU8wYnZZZnB0dE05dTZ4UnRMMzkvU04zbng1WTBXWVlrU0JPbXFZM3V2SEo1THI4dExjMUtob1pFYlRnMzBxcWFjMWpOMm1oNmMxOE14cHpVeEU3RjcwUTdLNkhqMXV3N0lla1hRcmV3dUFuV2dKQXdCQUFYamtTRitOcEkvTy9abHBtdXRUV01SekpkMUJTYUtBSFltYlhvMk5qeWYxNUNzdTNhS2E2bW9ON0w2SGtyTlJOQnpWNE40aDlRVDc3QTVnVHN2cWV0Um1Vd0FqT2FNbHpDUzFCaWdzaERBQUFCU0F1UFRSdU5XaVpkYWd5MlZVcExpWTkrL3BHMzBkcFlrQ2RTQnV1RFUrbnR3OXJkdnQxdHZlL0FZTlBueXZKbnRQVW5yTEZKdUo2ZXpSWVlVZTZOVm85NWdVdDNYeC95WnA4eks3SHMxbnR3T0ticHJhQXhRV1FoZ0FBUExjdzBmNjFzbnFpcVI0NG1HNFhPbmVOZjc3bnI3UjlaUXFDdENlbUZtaXFlbms3Mm5mOU5ydDJyeHBvNDUvKzZ1S1R0RWdJUjJScVlpR0RwM1Z5ZnU2ZGViSXNOMVRVRDhsNmNiTzlyWS83R3h2RzdKNzNUdmIyMDVKT3NKZUJHQW5RaGdBQVBMZnB5VjU1LzdBTkYzcDN1bFV5eG9maHRGSVVXaWVNVnh1SlRzbWpIVWNtZnJNWDM5WVpuaFNKNzd6YjRwSEk1UmlraVpQVDZuL3lVR0Y3dS9SOFBFUnhhSzJObjBaay9SQlNkZDN0cmRsdXJYS2ZleE5BSFlpaEFFQUlJODlmS1R2T1pKKzc4S2Z1OTN1cG1VczlqbVN2a0Rwb3NBY2xPR09qVStrMXFLbHVhbFJmLytwajJuaStDRjEzZmxOS1I2bkpCY1FIcHZSbWNOV3E1ZFRqL1Zydkg4aUU4WDFBMG1YZGJhM2ZhR3p2UzBicWRqOTdGa0FkaUtFQVFBZ244WDF1WGwrT20yYXJsWExYUElmNytrYmZRTUZqRUxSMmQ0Mlk3ak1nYkh4aVpSZmUvWGxsK3F6SC91SXpqN3ptTHJ1L0tiaXNSZ0ZtaEFlbTlIWm84UHFmckJYM1EvMjZ1eXhFVVdtb3BsNHEyT1NYdG5aM3ZhR3p2YTJiQTdTY3k5N0dZQ2RDR0VBQU1oVER4L3UyeTdwbG1jSGdrbDg0MndZeGxHYjN1SnJlL3BHTjFMU0tKd3JYek0wZE9aTVdpKzk4Ym10K3V6SC8xSm5uZ3JxeFBlL1hyUkJUQ3dTMDhUQXBFN3ZQNk9UOS9lbys4RmVuVGt5clBEWVRLYmVNaXhwaDZUTE85dmJmcGJ0N2Uxc2J6c3NLWlRMSXVmQUJRcUxteUlBQUNEL1BIeTR6eTNwc3hmOUlpNlpwbXZVcHJlcGxQVGZlL3BHbjM5NVk4VVVwWTY4WjdnT1RFOVBYejg5SFZaSmlUZmxsOS84L09mcXN4Ly9TMzM0RTdlclM5S2FONzVEaHF1d3Y5T014NlhwNFdsTm5wN1MxTkNVcG9lbnM5a2o2OWVTL3JpenZXMS9qb3ZoTGtsdnk5RjdqM0RnQW9XRkVBWUFnUHowRGttWHpYdHlkN3VyYkh5ZmF5UjlVZEs3S1hMa3ZWZzBLT24zQm9lR3RHcGxlc01telExaVl0RzQxdnlmdDh2MEZzNGxkV3dtcHFuaGFVMmZuZGJVMldsTmo0UVZqMlo5SEp4VGt2NjBzNzN0dXc0cGxudVV1eEFHUUlFaGhBRUFJTTg4ZkxpdlhOSW5GL3E5NlhadHNQa3RBM3Y2UnUrNXZMSGl1NVErOGxvODlyK1MvdjU0MThtMFF4anAvQ0Rtd0ZlbVZYN1ZhK1QyZStUeHUrWDJ1ZVV1TlJOL1duODNYSVlqaXlNV2lTazhPcVBwa2JEQ28yRk5qNFExTXo2VHkxV0tTdm9uU1IvcmJHOXpVZ3VRdXpoNEFOakZvQWdBQU1ndkR4L3UrNWlrVDh4N1lqZlVWVmJ1WDVPQnR4MlRkUDNsalJVSDJRUElaemUrK2kyUnQ3MSt1L21IYi8yOVpTL3IzdDBQNjBOLzgybVZycnRScGV0dlh2QjVwdGVVV1dyS25malQ5SnB5bHlUKzdqRmxlbDB5dmFZTU16T1g1dkc0RkptWVVYaHNSalBqTXdxUHppZzhGdGJNaEtPbTNINUkwcnM3Mjl1ZWRHSzkyYlpqOTJGSnVSZ2o2eDJkN1czZjRNZ0ZDZ2N0WVFBQXlDTVBIKzVya3ZTaGhYN3Zjcm42SkdVaWhDbVg5SU05ZmFNM1hONVlNY21lUUw0eS9DdENEd1FmVzJ0SENQUEN0dWZxL1lGMzZZdGYrVGVaVmF2bHFWMC83L09pNGFpaTRhakNTNjJieTdBQ0c2OUxMcmRMTGsvaTRVNDhURU9HMnlYRFpWaC9OdzBaeHJuZ0poYU5LVFlUVXl3U1UyUXlvcG1KaUdiR1p4U1pqQ3J1M0ttMVQwdjZpS1N2ZGJhM09Ybis3N3VWbXhBR1FJRWhoQUVBSUwvOGphU3loWDVwdWsxdkJ0LzdDa2xma3ZRSDdBYmtLMWZWNmwvdjNYL1BPMDZjN05iYTFhdVd2YnkzL082cmRkOURqMmh2MXdNTGhqREppc2ZpaWt4RkZDbU9ZYkRqa3I0bTZTT2Q3VzJuODJCOTcrS3pENEF0NXlHS0FBQ0EvUERRNFZOYjQ0ci9RVndMZjFuc2RwdHJNN3dhNzlyVE4vcjc3QTNrcTVLVzF2OHNxYWpUdjM3cnYyeFpubUVZZXNsTk55bzgwa3ZocHZCeEp1bUd6dmEyUDh5VEFFYXlCdWZOaFFtcUMxQllDR0VBQU1nZmQwZ3lKU2srNTc4NXpyaGNydW9zck1kWDl2U05Yc2J1UUQ0eVRNL0RudlV2aW5YZS9SdmQ5WnY3bDcyOHNmRngvY2YzZnlodjdUb0tkMmw5a3Q0dXFhMnp2ZTIzK2JUaW5lMXRweVR0eWNGYmg2azJRR0VoaEFFQUlBODhkUGpVelpKZU5kL3Zac01ZdzJXY3lOTHFsRW02YzAvZmFCbDdCdm1tczcxdHpGTy8rVEhmMnVmcXIzWjhYcDEzL3lidFpZMk5qK3NESC8ya1RnK1B5M3ZKeXlqY2hVVWtmVUhTNXM3MnRtODZmT3lYeGR6RHJnU3dYSXdKQXdDQXd6MTArSlNSdUlGWmxHbWEyWnpxNURKSlg1YjFyVGFRYng0bzNmaVM1MGd1L2RXT3orblg5KzNXTzI5N296WnZUSDUyOThlZWVrYWYvUHcvYW1Cb1JMNnIzeUpYU1FXbE9yOU9TZS92YkcvYlh3RGJjcGVrUDJhWEFsZ09RaGdBQUp6dlRaS2VzOVNUUEI1elJaYlg2MjE3K2tidnVieXg0aHZzSXVTWkJ5Uzl2M1RqaStTdVhhL2RUOTJsWDkvM2ZsMnljWU5lY01OemRNVmxXN1J1ZFlzYUcrcmw5VnBqWGNkaU1ZVjZldlhRbzQvclYvZmNweWVmMmF2U3V2WHlYLzk2dVVvcktkR0w3WlAwb2M3MnRwMEZ0RTMzeWhwUTJHRDNBa2dYSHlBQUFEallRNGRQZVNYdGw3VFV0Q3ZoaW9veWJ3NVdjVUxTOHk1dnJIaWF2WVY4c1czSDdwV1NldWIrTEhMbXVNSjllNldSRTVvZU8vUHN6ejFlcjl5bVcxTlRrNHJINDNLNVRIbnJOc2pkZkwwOGRSc296SXYxUy9xNHBIL3JiRytMRkdEZGVWelNOVmw4eTlkMXRyZjltR29GRkE1YXdnQUE0R3p2MWRJQmpBekRPQ1pwU3c3V3p5OXJmSmpuWE41WU1jYnVRajdvYkcvcjNiWmo5MUZKejZZbzdwcDFjdGVza3lUNUlsT0tUcHhSZkhwVThjaVU0ckdvL0taSExuK3R6TElHR2FhSFFyellwS3h1azUvdGJHOHI1TStDKzVUZEVDWksxUUlLQ3lFTUFBQU85ZERoVTlXUy9pcVo1NXFtYXppSHE3cEYwbGNrTVhVMTh1MW1ldDZtTElhN1ZPN0tsWkpXVWtwTG01SDA3NUwrdHJPOXJic1lQcG9sdlMrTDd6ZEtGUU1LQ3lFTUFBRE85VmVTYXBJNm9idmR1UjRWOUxiRStERC94bTVEbnJoSDB0c29oclJOU1BxNnBEczYyOXU2aW1pN0gyTFhBMWdPcHFnR0FNQ0pWL21IVDYyVjFSVXBLVzYzNllUQktiNjBwMi8wR3ZZZThzUXVpaUF0QnlYOXVhVFZuZTF0N3kyeUFFYWQ3VzFIWlkxN0F3QnBJWVFCQU1DWlBpMnBKTW5uaGd6REtISEFPcGZLR2grR3VYcVJEemZUSVVtSEtJbWtSQ1RkS2VsV1NWczcyOXYrcnJPOWJhaUl5NFBXTUFEU1JuY2tBQUNjZG5WLytOVDFrbjR2MmVlYnB1dVVwQmFIclA0bVNmOHE2YzNzU2VTQlgwdTZoR0pZVUpla3IwcjZXbWQ3MnltSzQ5ekh0S1JYVXd3QTBrRUlBd0NBdzhTbE95UVptdjNmVWlkenQ5dDAyQ2E4S1RFK3pGZlltM0M0WFpJQ0ZNTjVwaVQ5U05KL1NPcnNiRytMVVNRWGVaQWlBSkF1UWhnQUFKeDBaWC80MUNzbHZYajIzL0U1djFzb2tIRzd6VFVPM0pSLzJOTTNHcnk4c2VKUjlpb2M3SjdFWVdaUUZCcVExQzdwenM3MnRtR0tZMUcvbFJSVGRvWjJHS2U0Z2NMQ21EQUFBRGpFZzRkUG1aSSt1OUR2NDNNZWM0eTRYSzQ2QjI2T1Y5TDM5L1NOVnJGbjRWU2Q3VzJEa3A2a0pDUko3K3hzYi9zM0FwaWs2czJZcEtlejlIWXpsRGhRV0FoaEFBQndqbmRJdWp5Wko4NkdNWWJMT083Zzdka2c2V3ZzVmpqY0x5Z0NEVXY2SmNXUUVyb2tBVWdMSVF3QUFFNjRtajk4cWt6U0oxTjluV21hMHc3ZnROZnY2UnQ5SDNzWUR2Wnppa0EvN1d4dm84VkZhaDZtQ0FDa2d4QUdBQUFuaU92UEpLMU05V1VldDdzK0Q3YnVDM3Y2Um05Z0o4T2hkc3RxQ1ZMTXZrODFTQmt0WVFDa2hSQUdBSUJjWDhrZk90VW82Y01MRGZxeWlLaHBtdXZ5WUJNOWtyNjNwMiswaHIwTnArbHNiNHZJbWlXcFdJMUk2cVFtcE95Z3BLRXN2QTlqOUFBRmhoQUdBSURjK3h0SlplZjlKSWxBeGpDTUk0YVJON082ckpQMDczdjZScG1GQms1VXpPUEMvTHl6dlcyYUtwQ2F6dmEydUtSSHN2QldjVW9iS0N5RU1BQUE1TkNEaDA1dGxmU0hTMTZDenhQSW1LWXIzNzRoZmEya1AyV3Z3NEdLT1lTNWs5MmYva2M0UlFBZ1ZZUXdBQURrMW1ja21Vay9lMDRnNHpiZC9qemMzcy91N1J0OVByc2RUdExaM2haUzlxWWNkcElKU1QrakJxVHRJWW9BUUtvSVlRQUF5SkVIRDUyNlNkSnIwbjI5eDJOdXlLZnROYXlIVzlMMzl2YU4xbElENEREUEZPRTI3K3BzYjV0azE2ZnRZV1crdTlBNHhRd1VGa0lZQUFCeVlQZWhVMFpjK254cTQvQ2U1NVJoR0w1ODJOWkUrRExYYWtuZjNNdjRNSENXN2lMYzVwM3M5dlIxdHJjTlM5cWY0YmRoNm5DZ3dCRENBQUNRRy85SDByUFROcWM2TVpKcHVoeC93emhQK0RMWGRra2ZvaHJBUVFhS2NKdnBpclI4dXlrQ0FLa2doQUVBSU50WDdJZE9lU1hkdnREdmt3bGszRzdUa2ExSURDMFp2c3oxNmIxOW95K2dSc0FoZW90c2U1L29iRy9yWnJjdjJ5TVVBWUJVRU1JQUFKQjk3NUdVMUhndUN3VXlicmU3eFVrYmxFTHdNdmRGcGd4OWQyLy9hRDFWQWc3UVgyVGJ1NHRkYm90TWh6QlRGREZRV0FoaEFBRElvdDJIVGxWTCt1dDBYanNua0JrM1RkY0tKMnhQbXVITDNCZXRrdlN0dmYyTUQ0T2M2eW15N2Uxa2w5dmlHV1V3S09sc2J5T0VBUW9NSVF3QUFOblZMbWxaTXdPNVhNYlJYRytFRGVITFhDK1Q5RkdxQm5Lc21GckNURXU2bjEyK2ZKM3RiUkZKajFNU0FKSytqcU1JQUFESWp0MkhUcTJWOUw3bExzYzB6Wng4TTVyaWVDOHB2c2o0eEw3K3NSZFNTNUJEQTVKaVJiS3REek0xdGExK1N4RUFTQlloREFBQTJmTXBTYVhMWFlqSGJkWmtjNlZ0YnZWeTBaT3MvK1NTOUoxOS9XTXJxQ2JJaGM3MnRwaUtaNFlrV3NIWTYrRU1MVGRLMFFLRmh4QUdBSUFzMkgzbzFIV1Nick5oVVRHMzI5eVFqWFhPZlBoeTBWTlhTdnIydnY0eGt4cURIRGxWSk50NUg3dmFWbzltYUxsakZDMVFlQWhoQUFESWpzOHBqVXpqUW9aaEhEY01JMlBuNzdTNkhFbEpoeS9HL09ITFhMK2pOQWN1Qm14UURDRk1UTkp1ZHJXdERrZ2FvUmdBSklNUUJnQ0FETnQ5Nk5UTEpiM1lqbVdacHV0MEp0WnhXY0ZMQ3VGTGt2NTZYLy9ZUzZnNXlJRytJdGpHL1ozdGJRUUdOdXBzYjR1TGNXRUFKSWtRQmdDQURIcmdVSzlMMGgxMkxjL2pOa3Z0WEw4c2pmZVN6dlhKZis3ckgydWlCaUhMaXFFbHpLUHM1b3dJWm1DWjR4UXJVSGdJWVFBQXlLeDN4QlcvSWk3cnYrVnl1OTIyakFlVGcvRmVVdFVvNmI4WUh3WlpWZ3d0WVdpeGtUL2xPa094QW9XSEVBWUFnQXg1NEZDdlg5SW41LzRzUHVlL05BeTZYRVpadXV1VDRTbW1reG52SlZVdmt2UUphaEt5cUxjSXR2RXhkbk5HUEVJUkFFZ0dJUXdBQUpuelo1S2FGL3BscW9HTTZYSjFwYk1TbVd2MVlqMHh6UzVIeVdyZjN6KzJqYXFFTE9rdmdtMThodDFzdjg3MnRxNE0xQi9HN2dFS0VDRU1BQUFaOE1DaDNoV1NQcHpzODVNSlpOeHVNNlhtTXc0ZDd5WFZWVEVrZlh0Ly8xZ3p0UXBaVU9ndFlmbzYyOXZPc3Bzenh1NHVTVEdLRkNnOGhEQUFBR1RHeHlXVnAvUENoUUladDhkY21jenJjenpGOUxJczBQdXBRZEozOS9lUHVhbFd5TEJDYndtemwxMmNVWFozU1lwVHBFRGhJWVFCQU1CbUR4enEzU0lwWU04VitMUC9UYmxOYzhIV0lOa2E3eVZUa2xpTm15UjlpdHFGVE9wc2J4dFVZUStHdW8rOW5GRjJ0NFFacGtpQndrTUlBd0NBL1Q0anlkWlpmVnlHY1dTK254ZElsNk5rZlhoLy85akxxVjdJc0lFQzNyYWo3TjZNWW5CZUFFdGYwMUVFQUFEWTU0R0R2UzlRWEsrMWU3bW0yeHlmKys4OG1HSjZ5ZFZJYy9uZjJqOHcxa0pOUXdiMUZQQzJkYkY3TTZlenZXM0E1aktPWkh5bHQzL0kxUFlQWGE3dEg3cEYyei9VeUY0RU1vKysxUUFBMk9TQmc3MkdwTTlMT3I4bnZ3MXBodGZ0cms1N1VVblBjcFJaaGowdnJwUDAvZjBEWXkvYzJsQStRNjFEQmhSeVN4aENtTXg3UXRJYW01WTFscEUxM1A0aFE5S3RrbTZUOURwSmxjKyszL1lQTldubkhlUHNSaUJ6Q0dFQUFMRFBHeVE5OTZLZkxqK1FpWHZjNW9hVXgzdEo4b2w1RXI3TTlYeEp0MHY2SUZVT0dYQ3lnTGZ0QkxzMzR3NDdkczIyZjZoYzBsc2x2VS9TMW5tZVVTNnBYaEloREpCQmhEQUFBTmpnZ1lPOTNrUXdzTGcwQWhuRE1FNFlockV1dVNjbi82UThERi9tK3ZNREEyUDNibWtvL3ltMUR6YnJMdER0Q2t2cVkvZG0zRUVibHpWaHkxSzJmNmhPMG50bGhTOTFpenh6Um9YZEhROXdCRUlZQUFEczhXNUpHMU42UlpLQmpPbHlEVWhhdCtpeUhCSytHQmxld0FXLy91YUJnYkZydHpTVTgrMCs3RlNvSVV4UFozc2JVeDVubnAwaHpQSmFwR3ovVUwyc0ZvUHZsVlNXeEN0MmFlY2RkUE1FTW93UUJnQ0FaYnIvWUc5MVhQcllBa0ZCY2hZSlpEd2VkOG1Dcnl1czhWNVNmVXFOcERzUERJeTlZRXREZVppYUNKdUUyQzRzZzUzZGtkSUxZYlovcUZyU1I1UjgrRExyNit3K0lQTUlZUUFBV0w2UGFFNFQ3d3UvYWs0NW9MZ2drUEc0emJYcExiQmd3NWU1V2lYZElla0RWRVBZcEZBSHJ5V0V5VjQ1VDBrcXRXRlpaMU42dGhXK2ZDRHhxRXJ4dmZaSitnRzdEOGc4cHFnR0FHQVo3ai9ZdTFyUyt4ZDdUbnpPSTJWeERaa3VsM1V4bmRJVTAwYkd1eDBaR1hweEdsTll2Ly9Bd05qcnFJMnc4U2E2RURFelVoWWt1bnpaMVJvbXVURmh0bitvWE5zLzlERkp4eVY5WEtrSE1KTDBaOXA1UjR3OUNHUWVJUXdBQU12emFhWHdqV2VxZ1l6cGNuV2xGcjVrYnN5WE5NS1IrUmVRM3ErWDh1OEhCc1kyVUIxaHcwMzBxS1NSQXR3MFdzSmtqMTBoek9KVFZHLy9rRS9iUC9RUldlSExKNVJlK0NKSlg5Zk9PMzZ4NkFhZG52UWNQajFwc0d1QjVhTTdFZ0FBYWJyL1lPODFrbjQvM2Rjbk15NnYyMk5HRmw5S1VYUTVTa2ExcERzUERJeTNiV2tvbTZaMllwbDZKRlVXMkRZUndtU1BYU0hNNlhsL3V2MURQa2tCU1IrVzFMVE05OWd2NlUvbTNZalRreHNsdlZ6U05ra3JKZDBvYTVZdEFNdEFDQU1BUVBvK2IxZUdzRkFnNC9XNEcrZC9CZUhMUEV1N1R0SVhaQTFHQ1N4SGw2U3RCYlpOaEREWmM4eW01Wndmd3RnYnZraFdTNXZYYStjZFk1SjBlSEN5VE5LTEpMMU0wc3NVMThZNUg5UTNiNnJ6RWNBQU5pQ0VBUUFnRGZjZjdIMlpwSmRrWXRsekFwbXcyMjJ1UHZmUHpFOHh2ZXpsR3hsY2RoSkxOS1EvUGpnd2ZzL21ockwvcHBaaUdRb3hzRGpPYnMwYXU4YmZHWkFrYmY5UWphUjN5eHB3ZDRWTnk0NUplc3ZoYjN6Q0xYM2lnN0phdkx4QWt2ZWlFNUtoZjkxVTU3dVAzUXJZZ3hBR0FJQVUzWCt3MXlWclJwNk1NZ3pqcUtTdHRIcFplb2tYTFA5ckJ3ZkduOXpjVUhhSTJvbzBIUyt3N1JucGJHOGJZTGZtVi8zWmQvVEpPbTMvMEQ5SmVydFNtMnA2UVZWbFB0MTQrVWE5NitWdGoxeTFmbFZIWEdwZTR2TzVUM0Y5bUYwSzJJY1FCZ0NBMUwxZDBwV1pmaE9QMnh6SmRQeVNoMTJPa2xsK3BhUTdEdzZNUDI5elE5a1UxUlZwT0ZaZzIzT1VYWnBWSit4WVNLanZ4RjNMWFlicGN1bUs5YzI2K2NwTnV2bktTM1RWaGxWeUdZWWtQVy8yT2ZIRlA2cy9zS25lZDRaZEN0aUhFQVlBZ0JUY2Y3RFhKK2x2cy9GZVhvODdZd09ENW5QNGt1U3lyNWIwUlZsTitJRlVIUyt3N1RuTUxzMmV6dmEyMFcwN2RwK1JWSlB1TXFiRFU0ckgwNXN4ZWtWMWhWNXd4U2JkZk9VbXZlQ0tqYW9xOHkzNW1nV0NtRjlzcXZkOWx6MEsySXNRQmdDQUZNU2xQek9rNW15OGw4Zmp0blhLWlNQREM4aHlsNk5rQkJManczQVRnVlFkTDdEdElZVEpUUjFLTzRTWm5CNVAvbHpoTnZXY1M5Ym9waXMzNmFZckw5SFcxWTNwbnQvbWZzNU9Tdm9qZGlOZ1AwSVlBQUNTZE4vQjNnWkpIMDVtYXVubE1nempwTXN3VnR1eXJBeS8ySUhoeTF6L2VuQmcvSW5ORFdYN3FjRklRWStrR1VtZUF0a2VRcGpzNjVKMGJib3ZucHlhV1BUM3F4dHFkUE5WbCtqbUt6ZnErWmR1a0svRWE4dEt6d2xpUHJhcDNuZWMzUWpZanhBR0FJRGtmVnhTeFlVWHJEYUZCZWN4VFZlZnBHV0ZNQVU2M2t1cWl5MlhkT2ZCd2ZFYk50ZVhUVktGa1l6TzlyYll0aDI3dXlSdExKQk5Jb1RKdnVQTGVmSG94TWg1Ly9hVmVQVzhTOWZwcGlzMjZlYXJObW5OaXRvTWZSWkxjZWx4dytyT0NTQURDR0VBQUVqQ2ZRZDdOMHNLTEhIaGF0dEZzZGZ0VHZzY1hRVGp2YVM2MkNza2ZVblNIMUNUa2VKTk5DRU0wcldzYWFwSHhzNXF5K3BHdmVDS2pYcmhWWmZvK2t2V3lPTTJGenozR0VzTnI1dThtS1RBcG5wZmhGMElaQVloREFBQXliazlsZlBtY2dNWnI4ZTlKcFhuRitGNEx5bXRxQ0c5NjlEZytEMlgxSmQ5bTZxTUpCMHZrTzBZN214djYyWjNPci8rK0V0TWJWMVZvYTB0NWZyWUc5K3FGZFVWU2IvV3hpRG1TNWZVKzRMc1BpQnpDR0VBQUZqQ2ZRZDdiNVQwdSttK1BvMUFadGcwWGJYSlBKRXVSNHN2NUlKZmRSd2FISC84a3ZxeVBkUnFKT0ZJZ1d6SFUrektuRmh5bW1xWFlXaE5nMCtYcmE3VXBhc3J0SzZoVE1ZeVBoUnRDR0pPU3ZwcmRoMlFXWVF3QUFBczRyNkR2WWFrejltMXZHUUNHZFBsT2lIcHFzV1dRL2lpeFZxOUxNUXY2ZnVIQnNkdnVLUytiSnphalNVY0xKRHQyTXV1eklsNVE1Z3F2MGRiV3lwMDJlcEtiVzJwVUZtSmFldWJMak9JZWU4bDliNVJkaDJRV1lRd0FBQXM3dldTbnArSkJTOFV5SGpjNXZSQ3I4bGsrRklBWFk2U2NabWtMMHQ2TzFVYlN5aVVjVlFJWVhLZ3M3MXRjTnVPM2VPbXl5amIyRlNtUzF1czFpNnJhbjBYblFjeU1MQnVPa0hNRHkrcDkvMkVQUWRrSGlFTUFBQUx1TzlncjFmV1dEQVpOemVROFhqZEsrYitqdkZlRmw5UUdzdC9XMko4bUc5UXk3R0lRZ2xobm1GWFp0ZUJnWWtOa2w1K29IczB1cjZ4VEY2M2E5RVAvN2lSOHlCbVZOTDcySE5BZHJnb0FnQUFGaFNRdENuTDd4bnhtTzYxU2x3NnAzMWhiaXk5Z0dVdFA0azN0R1g1aTJ6SE1wZi9MNGNHeDYra2ltTWhuZTF0NDVKQ0JiQXBqSUdVWVFjR0pzb09ERXhzUHpBdzhhVURBeE9IWlkwbjlFOWJWbFZVTGhyQXpJcWZIOFRiSlQ3bi8wdjR5Q1gxdmg3MkpKQWR0SVFCQUdBZTl4M29yVkpjSDg5QU01RkZHWVp4MUdWb2Mvb0xzT1VweTNyREhJMzNrcXBTU1hjZUdoeC96aVgxWldQVWVDemdzS1NXUEY3L25zNzJ0ajUyby8zMkQweGNaVWpiSkwxYzBnc2tlWmUxd055MWlIbEkwbGZZbzBEMkVNSUFBREMvajBpcVcvWmMweW55dU0yemFiMlFMa2ZwMkpLNCtmaDlxanNXY0VqU0xYbTgvbyt5QysyeGYyQ2lSdEx2U0hxWnBKZEthclo5UEpmc0J6RVJTZi92a25wZmpEME1aQThoREFBQUYvak5nWjZXdU9JZk1DNjhZTTFDSUZQaWNaY24vZVNzdDNxNWVJbFpubUk2RTF0ejIrSEI4ZDlzcWkvN0tqVWY4OTE3NS9uNi81WmRtT2FPSDVnd0pUMUhWdWp5TWtrM2FKNmhIUEk4aVBuOEpmVytwOW5iUUhZUndnQUFjTEZQU1NxTnowbGRGZzFrYkV3THZHNzNobVNTQXh1ZWtvTHNkam15Zi8yWFhQNC9IaDRjZjJSVGZka1RWSDFjSU45bkZxSWxUQXIyRDB3MHkrcGk5REpaclY1cWszbGRuZ1l4UnlWOWtyME9aQjhoREFBQWMvem1RTS9Wa3Q1NjhjWHJJb0hNN05YdE1oTUV3MUNQeTJVMEo1c2NwUG1VVk5Zb004dk9icGVqWkpaZkl1bk93NFBqMTIycUx4dmxLTUFjK1Q2ejBPUHN3b1h0SDVqd3loclA1YVd5Z3BlcjBsMVdIZ1l4Z1V2cWZaUFVBaUQ3bUIwSkFJRHpmVzZwYStuNG5QOFd2TXFkZmFUQWRKbTlDNllIU2N4eVpQOU1SMG05ZmJxTHRYLzVxYjN0aFRaSitsZXFQK2JxYkc4TFNSck8wOVUvMmRuZXhvdzNGOWczTUxGaDM4REVIKzhibVBpSnBDRkpkMG42a0pZUndNejk2TGRWNW1aTit2WWw5YjVkMUFZZ04yZ0pBd0JBd204TzlHeVQxUVE5aFl0WisxckllRDJta2V4emszeEtpZ3B1dkpkVXZlbnc0UGg5bStyTHZzelJnRG1lbHRWYUl0ODh5SzZUOWcxTWxFbDZrYXpXTGkrWHRISHV4M05tV3ByWXUwQ2JXOFFNU2ZvemFnYVFPNFF3QUFCSStzMkJIcGVzVmpETHVGWmVYaUJUNG5HdllieVhqTDF0c3Y3dThPREVRNXZxL1l5bGdWbDdsSjhoekFQRnVzUDI5WTlmSmNOSWF2cm9JZ3hpUHJpNTNqL0FZUTNrRGlFTUFBQ1d0OHFHNXVqbnJwbFREbVRHM0c2elBzTUJ3NEpMSytEeFhsSmRpbGZTOXcrZm5yaHVVNTEvbU1NQ3l0OXhZUjRxbGgyMHIzLzhvdW1qRlk5TFJuS2ZERVVVeE53ajZSc2Mwa0J1RWNJQUFJcmVidzcwK0dUTmlKUVJ5UVF5THBmcm1LUXJNeE11TEx4RXdoZGp2cjl1a1BRMVNXL2c2SUNrTTNtNHp1T1NIaXZVSGJLM2Y5eGxTSzFhWXZwb2dwanpURXNLYks3M3h6bWtnZHdpaEFFQVFQcFRTYXV5OFVZTEJUSmVqemxsYjdpdytOS0tjTHlYaFpjdy8yREJyejl5ZXVJREcrdjhYK1R3S0hxZVBGem4renZiMnlLRnRCUDI5byt2bE5YSzVhV1N0c1dsMnFRK0J3aGladTNZWE84L3lPRU01QjRoREFDZ3FQM21RRStEcEEvbjRyM25CaklsWG5lZFBlSENBa0hEd25tREhZdTFkL2taWGZiQzRjczh5Ny9qeU9tSjNSdnIvSTl3cENEUDNKUHZHN0MzZjl3cjZVYWQ2MkowOWNXZm9VbCtMaERFN0pQMEdRNEx3QmtJWVFBQXhlNWpraXB6dkE0eHI5dGNaKzhVMDR1R0MzWXMxdjdsSzFQTE4xTDU1MXdlU2Q4N2Nucml1bzExL2pNY0trWEx6TU4xdmljZkMzcHYvL2dHbmV0aTlDSko1VXU5aGlBbUtmOXZjNzAvektFTU9BTWhETkwybnEvODZvb0RKL29QM25YN2JYeW9BOGhMOXg3b3VTUXV2ZHZJOFhvWWhuSFVNSXhOTml3cDJYQmhPWXUxZi9uSzFQS1g3SEtVakhXUy92M0k2WW5mM1ZqSFdBcEY2dm84Vzk5UlNiL05oeFhkMnovdWwvUmlTYk16R2FYMU9VZ1FzNmgvM1Z6dnY1L0RHSEFPUWhpazdaSzFLN2JmZE4ybVR6Ly82dDJubmpyWXZYdDhNdnlvcEtja1BYWFg3YmVGS0NFQWVlQjJTZTU0Rm9PRitYamM1akphV1REZXk2SkxNR3haOW1zbC9ibWt6M1BJRktXWDVkbjYzdVhrOFdEMjlJOWZLZW1saGxXdU4ybVI2YU5UUVJBenJ6NUpIK0lRQnB6Rm9BaXdIUCs4YTg5L1hidTE1UzB6a2FqMkhqMmx4L2FmMU5IUWFjWGo4Yk9Tbmt3OG5wWVZ6anh6MSsyM1RWQnFBSnpnM2dNOWJaSWVjTUpKc3NKZityUy8xSHZsY2svaG1ReGY4bWlLNlhrWGFNUHlJNUp1M2xqbmY1Q2pwM2hzMjdIN1JrbjUxb3JnUFozdGJmL2lsSlhaWTAwZmZhdXNsaTdiTkdjUTlFeDhyaVM5VE1Pd2Y1bTV2QW1iUDRoNXkrWjYvM2M1a2dGbklZVEJzbjM5dm9PUGJWM2ZlTzNzdjRmSEp2WDQvcEFlUHhEUzZiUGpjNThhbDNSWWlkWXlpY2VUa283ZmRmdHROUEVHa0ZYM0h1aDVRRktiRTA2WTlkWGw0NmJMVlpiT210RGxLTzN4WHRKeFV0STFHK3Y4UXh4QnhXSGJqdDNma1BTMlBGdnRqWjN0YlVkejllWjcrc2Rkc3FhUGZxbXMxaTdQMVh6VFIyZndNNFlnUnBMMDg4MzEvbGR3RkFQT1F3aURaZnYwajRMZVRhc2JUcTVwcWxseDRlOU85QTdwOGYwaFBYMjRSOVBoQlZ2R2pzbHFMVE8zMWN4VGQ5MSsyd2lsQ3lBVDdqM1E4M3BKLysyUWsyZGZZMjFsWTZydlNwY2pXOFo3U2NmL1Nub1Y0OE1Vdm0wN2RxK1I5ZVZSUGsxUmZhU3p2VzFUdHQ5MHp3WFRSMHVxemZVTlNaRUhNUk9TTHQ5Yzd6L09rUXc0RHlFTWJQR1ovM20wOGZLTlRjZnFxOHQ5OC8xK251NUt5U3oyaEt4ZzVpbWRDMmtPMzNYN2JWRktIRUM2N2ozUTQ1RzBSOUlsVGppWnVrM3pzYnFxc3V1U1hUTGhTMGE3SENYN3puKzVvYzdQZEs4RmJ0dU8zZjhpNmQxNXR0cGY2bXh2KzVOTXY4bWVKS2FQZHNKTlNSRUhNWCt4cGQ3UEdGYUFReEhDd0RaMy9PU3g1MTEzYWNzRFpiNFMxMkxQR3g2YjFCTUh1dlg0L3BNYVBMKzdVakltSmUzVnVWWXpUOHBxTlhPYVBRQWdHZmNlNkhtdnBDODU1Y1JhVnVwOXROeGZldjFpUzZITDBRVkxNWEsrL2xGSnQyeW9ZOGFSUXJWdHgrNHRrcDVSL2sxaTBkYlozcGFSY1l1ZTZUdC8rbWpEV0hyNmFDZmNtQlJoRVBPNHBCdTJOUGdqSE1tQU14SEN3RmFmMy9uNFcyKzRZdTAzUFc0enFlZDNuVHFqeC9lZjFOT0hlalFWWHRhNW9rZm54cG1aRFdmMjMzWDdiVFBzRlFDejdqM1FVeW5waUtSNnA1eGtheXZMVG5uY1p0TjhyeUI4eVZtWG8yU1czeTNwbWcxMS9rR09yTUt6YmNmdW4wcmFubWVyZmJpenZjMjJGbjdQOUMwOWZiUmhPUEZ6WXhuTHpQOGdKaWJwZVZzYS9FR09Zc0M1Q0dGZ3UzLzg1Vk9mYTcxODdRZFRlVTBrR3RQZW83MTZiRjlJUjBLRHlYWlhXc3FNcEgwNmZ5RGdwKzY2L2JaZTloSlFuTzQ5MFBOcFNlME9PdUZPTk5aVytobnZaWkVsWkRsOFNYSFp2NVQwaWcxMS9oaEhWK0hZdG1QM2F5VDlPQTlYL1gyZDdXMy90SndGUE5OblRSK3RGS2FQSm9oeDFMYi93NVlHL3djNGlnRm5JNFJCUm5UY3ZlK1hWMTNTdkMyZDE0Nk1UMW16SzZYWFhTa1pnN29nbUpHMDU2N2JiNXRpendHRjY5NERQUzJTRGtrcWRjckoxM1M1OXRSWFYxeHU2MGs1UitGTEFYWTVTdFpmYjZqemY0b2pyREJzMjdHN1FsYTM1NVk4Vy9YVGt0WjB0cmROcFBLaVovb1duajQ2cGVPSElNWUoyMzVTMHVWYkd2eWpITW1Bc3hIQ0lHTys5ZURoUTV0V055eHJoSDRidXlzdEpacTRPWnVkTnZ0cFdhMW1UckFuZ2NKdzc0R2VyMHQ2dTVQV3FkVHJDZGFVKzFzemVVWm52SmVNcjM5TTBvczMxUG52NVNqTGY5dDI3TzZROVAveWNOVS8zTm5lZHNkU1QzcTZ6NW8rMmtoeSt1aVVqaVdDbUZ4disydTJOUGgvd2xFTU9COGhERExtMHo4S2xtOWQxeGhxYnFpcVd1NnlNdFJkS1JuRG1qTUFjT0x2VDk5MSsyMWo3R0VnZjl4N29PY3FTVTg0N2J4WFUrNC9WT3IxTEc4TUI4WjdjY0lGVUsrczhXSDZPZHJ5MTdZZHUxOHU2V2Q1dU9vaFNaczcyOXNtNS92bDAzMWpGMHdmYmRSbUxEZ2dpTW5WdHY5d1M0UC85UnpGUUg0Z2hFRkczZjdqMzE1eTllWlZlMm9xL1I2N2xqbmJYZW1KQXlFTm5NbEpGaEtYZEV6bldzM01kbWs2ZXRmdHR6RXVBT0JBOXh6bythV2tiUTQ3NmNXYmFpcGpobUdZS2IrUzhWNmNkZEZqTGZndVEzcnArbHAvbENNdS8yemJzYnMrY1M1Zm1ZZXIvNDdPOXJadnpQN2o2YjZ4SkthUE5qSVhIQkRFWkhzOVJ5VnQzZExnNytGSUJ2SURJUXd5N282ZlB2YXkxc3ZXL0t5MHhHTjdmUXYxbmRWaiswL3FxVU05bXByTytVUkk0NUwyNlB4V00wL2VkZnR0WjZrRlFPN2NzNy9uVmttL3luWTNsNld2NjQxalRUV1Y2KzA2YXpQZVN3N0t4cmhvK1o5WVgrdi9HNDY2L0xKdHgyNUQwdi9LR2hjbDMreVc5SUl2dk91cTlab3pmYlNVelBUUkJERUZFc1Q4OFpZRy96OXpKQVA1Z3hBR1dmSDNQMy95VDFzdlgvdDNwaXN6VlM0U2pXbmYwVk42YlA5SkhUazVxRmoydWlzbDQ2UXVIZ2o0NEYyMzN4YWhaZ0NaZGMvK0hwZWt4M1RoTjhFT0NHUzhibmV3cnJJc3VmRmdDcUhMVVE3S1BZdmh5NnlZcEczcmEvMTNjZlRsajIwN2R2KzVwTS9uMHpwNzNTNWQwbHdlZTkzem03OVhVKzV0MVR6VFI2ZFNtUWxpN04yZ0xLN25nNUplc0tXQkdkcUFmRUlJZzZ6NXAxODk4L1hyTDEzOTlreS96K2o0bEI0LzBLM0g5NS9NVlhlbFpFekxtajc3U1owL0VERGpDUUEydW1kL3oxc2xmWE1aT1VIR1ZQcExueW9yTGJrcW5iTTBYWTV5Y0hGakpMM3NQa25YcksvMW4rSUlkTDV0TzNiZktPa2VTVzZucit2S21sSnRhYW5RMXBZS2JXZ3FrMzFmYkJIRTVHa1FFNUYwM1pZRy85TWN5VUIrSVlSQlZ2MzdidzQ4ZE9tR3B1ZG02LzBjMWwwcEdYMjZ1TlhNM3J0dXZ5MU03UUZTYzgvK0hwK2tnMHBscXRrc0JqSU5WUldqYnROVmtjcVpPWi9EbHdKczliS1kzMGg2TWVQRE9OdTJIYnViWkxXVWMrUTRNTDRTVTV1Ynk3VzFwVktiVzhwVk5XZDRQU05ERlowZ3h0NE55dkI2M3I2bHdkL09rUXprSDBJWVpOV25meFIwYjFoVmYySmRjMjF6TnQvWDRkMlZsbHg5U2Z0MWJwYW0yVll6SVdvVXNMQjc5dmQ4Uk5MdGRwMGhiVDVobmw1WlcxV1h6QnN3eFhTT0xtU001U3pma0tSUHI2LzEvUlZIb2pOdDI3SGJLMm1YcEpzY2MxRnVTS3ZyL2RxeXFrSmJWMWRvVFlOLzBmdDlncGdjTGpQM1Fjd1JTVmR1YWZCUGNqUUQrWWNRQmxuMzZSOEY2Ni9ZdVBMRWl0b0tmeTdlZjNSOFNrOGM2TmJqQjBMcUh4ck41NkljMHNYVFp6OXoxKzIzVFZETFVPenUyZDlUTCttd3BLcE1uQzJYZS9KMG02N0hHNm9xcmwxc1lZejNrcU1MbU9XSEw3UGlrbDYydnRiWHlSSHBQTnQyN1A2YXBIZm1lajBxL1I1dFdWV3VMYXNxdEhsVmhmd2xaa3FWbkNBbWg4dk1iUkR6TzFzYi9MczRrb0g4UkFpRG5QanNUeDY5OXJxdHE0UGw1MTF0WkwvaWgvclA2ckY5SVQxMXFGdVQrZEZkYVNteHhJM24zRll6VDBvNmZ0ZnR0OFdwZVNnVzkrenYrVWRKNzh2R21UT2RFMmxaYWNtamxXV2wxK2ZpeE14NEx3c3YxTEIvclFZa1hidSsxdGZOVWVrYzIzYnMvbE5KZjVlTDl6WmRodFkzbG1sTFM0VzJyS3BRYzIzcHNpczhRVXdPbDVtYklPWmJXeHY4YitWSUJ2SVhJUXh5NW5NN0gzL0xEWmV2L1Mrdng4eDVwWTlHWTlwM3JFK1A3VCtwUTEwRCtkWmRLUm1qU25SajBybFdNMC9kZGZ0dEk5UkVGSnA3OXZkc2tyUlhraWZiSHlySm5sVHJLc3RDWG8rN0pac25aTVo3V1hqQlJtYlg2Z0ZEdW1WZHJZOFo4UnhnMjQ3ZEw1ZTBVNUlyVys5WlYrRjlOblRadUxKY3BSNlg3VldOSUNhSHk4eHVFRE1rYWV2V0J2OEFSek9RdndoaGtGUC84SXVuUHRWNitacVBHb2JobUVvL09qbXRKL2FIOU5qK3ZPK3VsSXpqdW5nZzRNTjMzWDRiZzBraWI5Mnp2K2UvSmIzZUNXZlZCVDV2cHB2cXFrb01NZDVMemk1U3NoTyt6SDNtWjlmVitqN0MwWmxiMjNic3ZsVFNRNUlxTS9rK0hyZExtMWFXVzkyTVdpcFVYMW15L0xwTkVKT1R6d3NIQmpIdjJOcmcvd1pITTVEZkNHR1FjMS81OWQ2ZlhyMTUxWFpIVlBnTG50Q2Q2SzcwNU1HQzZhNlVqRWxKZTNRdWxIbFMwdE4zM1g3YmFXb3JuTzZlL1QzUGw3VGJpV2ZZMlgrNlhNYStwcHJLUzUxOWNpL2NMa2ZwTDk5WTdyTmVzYTdXOTNPTzB0ell0bU4zZzZ3QVprTW1sdDlVVTZvdHF5cTBwYVZDNnh2TDVEWU4rK3M1UVV4T1Bqc2NGTVRjTGVrbFd4djhkQzhIOGh3aERCemhtdzhjMnJ0NTdZcmMzNVFzY0pFZWpjYTE5OWdwUGJhdllMc3JKYU5iNTdvMHpZNDNzLyt1MjIrYm9RYkRLZTdaMzNPL3BCdWRmTGIxZVQyUDFGYjRiM0RtU1QxMzRZc3pXNzBrLzhva25uVmEwblhyYW4xZEhLblp0VzNIYnIra3V5UTl6NjVsK2twTVhiS3lYRnRiS3JTNXBlSzg2YU16V3U4SlluTHlXZUtBSUdaYTBsVmJHL3dIT2FLQi9FY0lBMGY0OUkrQy9pMXJWNXhjdGFLNk5tZVZmY0Y3ai9QL05Ub3hyU2NPaFBUWS9wUHFPejFhN0x0dVJ0YllHK2ZOMG5UWDdiZjFVcXVSYlhmdjcvNWRTVCt3amxybm50NXFLdndIL0NXZUxjNDZrZFBsS04yMVNuSDVEMG02ZVYydGovQTZTN2J0MkcxSytwR2tWeTAzTEdpcDkydnJLaXQwV2J2RTlORVpQUVlJWW5MeXVaTGpJT1pqV3h2OGY4c1JEUlFHUWhnNHh1MC8vdTNhcXk1WmRiQzJ5dS9OZWtWZjlNdmZoVi9kM1Qrc3gvYWYxSk1IdXpVeEZXWW5uak9nODF2TlBDVnA3MTIzM3paRjBTQVQ3dDdmN1piVmpXN3p4VWV3czA1MUsrc3FaMXlHc2V4Qmd3bGZGbCt3dzhLWHViNndydGIzUVk3YTdOaTJZL2UvU0hwM09xK3Q4TG0xT1RHZzd0enBvdzBuSEE4RU1UbjVqTWxSRUxOUDBqVmJHL3hjYUFJRmdoQUdqbkxIVHg5NzRYTXVYWE8zcjlSalpMV1NKOWtLWnFHWFJhTXg3VHZlcDBmM25kVEJybjdGWW5UWG5VZFUwa0ZkM0dybUJFV0Q1YnA3Zi9jZlMvcW5wUS8xM0o3MkRNTTQwVnhYdVRhM0oyNm1tRTUzcld4YzkxZXZxL1g5bENNM3M3YnQyTjB1NmRQSlB0OTBHVnJYV1BiczJDNHJGNWsrbWlBbUU1K1ArZkY1azRNZzVnVmJHL3dQY0VRRGhZTVFCbzd6ZC8vN3hIdHV1R0x0bDAzVGxaMEtubVlBczlBenhpYW05ZmlCa0I2bHUxS3loblh4REUzUDNIWDdiV01VRFpKeDkvN3VDa2xISkRXazl2bVEvVk9nMTJQK3RxR3EvRG01T1dFejNrdTZhNWFCOVQ4ajZmcDF0YjVqSE1HWnNXM0g3cmRKK3NaU3o2dXQ4RDRidW14YVdTNXZDdE5IRThSa1lQc0pZaTcwMWEwTi9nQkhORkJZQ0dIZ1NGL3FmUHBmbm5QWm1uZG52SUxiSE1CY3FMdC9XSS9TWFNrZGNVbEhkYTdWek94QXdFZnZ1djIyR01XRHVlN2UzLzBwU1I5ZDNtZEZkazZIbFdXbFQxYjRTcTdPN2ttYUxrZnBybFdHeXlkb0dIckIyaG9mSndlYmJkdXhlN3VrSDBxNnFOdWZOWDEwbVRhdnF0Q1dsdklMcG84MkhGSEhDV0x5NDdNb0MwRk1uNlN0V3h2OFp6bXFnY0pDQ0FQSCtyZDc5OTkvK2NhVk4yYXNjaTk2TTJMWWV1REU1blJYT2tCM3BlVVlseFhHekk0Mzg1U2twKzY2L1RZdVVJclUzZnU3VjBrNkpNbG4zNGt4YzZmR3hwcUtzMjdUVlozNWs3T1J5ai96NStLaUFNS1hDKzdIL21GdGplOERITW4yMmJaajkwMlNmam4zTTZHcHBsU2JWNVZiMDBldm1ETjl0R0hQM2llSXlmaHg0dGpQcFF3SE1XL2UydUQvSGtjMVVIZ0lZZUJZbi81UjBMV3V1ZTc0aGxWMXF6TlNzWmM1RGt6SzY1TDR5OWpFdEo0NDJLMUg5NTFVNytBSU85b2VYVXFNTWFOenJXWU8zblg3YlJHS3ByRGR2Yi83YTVMZW1ibVRwSzJueWJPcjZxdXFNM3RTWnJ5WGROY3E0Mld6OEJ2ODd0b2EzNDg0bXBkdjI0N2RWMHY2amM5clZtNXF0a0tYemF2S0w1bysybGh5eHhQRXBQcW1CREgyYnBBaC9YeHJnLzhWSE5WQVlTS0VnYU45K2tmQjJzczNyRHpSV0ZkUmJtdkZ6bkEzcEl1ZXU4Q0xlZ2FHOWVpK2szcmlZTGZHSjJtUmJyTnBXYlBsWERnUWNEOUZVeGp1M3Q5OVpXTGZadVZjdHR4QXhtMjZubXlzcWJnNk15ZGp1aHlsdTJZNURGOW1EVXU2Zm0yTjd3aEhkWG9lN3gxMVBYbHMrTFduUjZiL1krUEs4ckkxU1V3ZlRSQmovMW9TeE5pMlFST1NMcnUwd2MvRUJVQ0JJb1NCNDMzbWZ4Njk0cnF0TFk5WGxKVzZiYW5VYVU1SG5jNEJZeVQ1d21nc3B2M0grcTN1U2lmNkZZMHg3RWtHbmRMRnJXYjIzblg3YmFSZ2VlYnUvZDAvbC9TeTNKdzhVejk5bHBWNmYxdGQ3bnVPdlNkZ3dwZDAxOG9CNGN0Y2owbHFXMXZqbStiSVRzN2p2YU5Oa2w0cTZXWHh1RjVxR0twWlZtMGhpTEZsTFFsaWJObWdEMTdhNFA4Q1J6bFF1QWhoa0JjK3QvUHgxOTV3K1pvZmVqMXVZOWtWT2tmZGtKSmQ5dGprdEI0L1FIZWxMSXRJMnEveloyaDYrcTdiYnd0Uk5NNTA5Lzd1V3lYOXloa24wdVErSGVxcnlrNlVlTnhyR2U5bDhRVm5Nbnh4V1BCeW9TK3ZyZkc5bDZON2ZvLzFqbm9OcVUxVzhQb3lTVmZiWHA4SllteFpTNEtZWlczUTQ1SnV1TFRCVDNkcW9JQVJ3aUJ2ZlBFWFQvNzFEWmV2L2FTeHdJa3JGOU5STC9sY1kza0hZcy9Bc0g1TGQ2VmNHdEw1d2N5VHNsck5URkEwdVhQMy9tNlhwRWNsWGVPOGsrcUNCLzNNcXJvcXovSnVKQmp2SmQyMWNuajRNdGYvV1Z2aisyK09jc3RqdmFNYmxHanRJdW5Ga3NvemZ1Tk1FR1BMV2hMRXBMVkJNVW5QdmJUQi8xdU9mcUN3RWNJZ3IvenpYWHUrZisyV2x2K1RWbVhPZGdCajR3VlFOQmJUUHJvck9VVk0wbUZkSE02Y3VPdjIyNWoyS2d0K3ZiLzcvMHI2RDZlZnhPWUdNaTZYY2FDNXRuTExzay9WdEhwSmFjM3lLSHlaTlNicHVyVTF2a1BGZUd3LzFqdjYvOXU3OC9ESThvTGUvNTlUVzVaSzBudlM2VWt2c3pMZGsrN3BaZEk5d0lDQ0lNTXdBK01WOWNwNEZhOWVlaEFkTmhYMS9zVG5lcEZoRTFFVWFQaUp3aWlpZ095Z3lJeUNPRnQ2ZW1DWVhtZnRKTDBuNmV5cDlaejdSMVYxS3RWVlNTM25WSjF6NnYxNm5ucXluWHpQa2pybmZNOG4zNlZkMHN1MEVMeGMyNUFIWjRJWVc3YVNJS2JpSGZyenJldmEzOFpkSHZBL1FoaDR6dC8rMTFOUHZHQno5L2FLM3NoMW5JNjYybTVJNVZab1p1WXpzeXNkUERxczB4Y21lVU80eDdRV3hwckpCVE5QM24vdlhmUXBzOUVEeDA2MVNUb3VhYU9YYm1odGtjaWphN3ZhOTFaOWl5WjhrWWZIZTZsMEwzOGs2ZVpOcTlwaXpYQk9Iem96M2E5TTZQSnFTYmRJYW5IRmd6TkJqQzFiU1JCVDlnNE5Lek1ZN3d4M2VzRC9DR0hnT1gveTVjSEl0WnZXbmRyWXMycHQyVzlpRjQ0RFUvNWlwU3N5WjBhbmRQRG9rQTRkSDZHN2tuczlyNFVCZ0hPek5EMXovNzEzcFRrMGxYdmcyS2wzU1hxZjEyNXVxenZhajBaYkkxdHJ1RmpWSjF4d3VOQW1IdStsMHUwL3NHbFYyOTErUEljUG5abGVKZW1ubEFsZFhpWHBDdGMrT0JQRTJMS1ZCREZsN2REcnRxNXIveHAzZWFBNUVNTEFrKzc5eXNFcnRsK3o0ZWsxSzZPdFhwbU91cGJIaXVXV05TMUxSNTgvcDROSGgzVHNPYm9yZWNDOHBDZTF1TlhNRS9mZmU5YzRoNmEwQjQ2ZVdpUHBHVWtyS2prNTNYQ2oyN0M2S3g0TUJGcXFUU29ZNzZWeGY5ODZoeS81N3RxMHF1MXpYajl2SHpzekhaQjBrNlJialV6b2NyT2tnR2NlbkFsaWJObEtncGdsZldscmQvVDEzT1dCNWtFSUE4OTYvOWNPdldoZzI4Yi9iRytOQktwN3J2RldONlJ5QzV1YlQralE4Ukc2SzNuVEtTMmVQdnNKU2NmdnYvZXVKSWRHZXVEb3FZOUllbXN0SjJzamJucUdZWXowclZuUlYrbEZpaTVIamYxYk5qQjh5Wm1WZE5PbVZXM0h2SGF1UHBZM2ZiU2tWMHBhNDZvd290SXlDV0pzMlVxQ21LS21KRzNkMmgwOXpWMGVhQjZFTVBDMFAvM200NysycjMvTC94OEtCaXA4dnZGSkFMUE1nOXZwMFNrZFBFSjNKWTlMU2pxaXhRTUJQM0gvdlhlZGJhYUQ4TURSVTFkTE9pb3BiT2ZKVzQrYllDUVVmS3huWmVlZU1pOU9oQzhOL0p1NUlIZ3BYUHBKU1hzM3JXcWRkL1A1K2RqcDZZZ0twNDgyWEI1R1ZGb21RWXd0VzBrUWM1bTNiTzJPZm95cUR0QmNDR0hnZVIvOXpvOC9NckJ0MDVML0hmZHJONlJ5SDk1TWM2RzcwbEc2Sy9uRkJWMCtROVBSKysrOXk1ZURlVDV3OU5RL1NmbzVKKzl3VHQwUXU5cGJIMS9SM3JxTExrZTFYaEVkUERidUMxL3kvZldtVmEyLzdyWno4ckhUbDA4ZlhjbU9FOFEwZU44Sll0endkM3BJMGkxYnU2TlV5b0FtUXdnRFgvalV2eC85N3Zack4veFVzWGUyMTZhakxydWlVdVYvejJmbkUvcmhpVk1hUERxa1UrZnBydVF6YVVrbnREQVFjSzdWekpDWGQrcUJvNmYyU1hxNG5uYzdPMitPNjFkMmpZVkR3VFdsQ25hMFpZZkRCUk8rMkh2Tlg4SWJONjFxL1V3ano4UEhUcGMzZlhRbHUwWVEwK0I5SjRocDVOOHBKV24zMXU3b2o2bTZBTTJIRUFhKzhONHZEd1kycjEvOTlOVWIxMTdwcCttb3l5MnMydTArTXphbGcwZUdkZWo0aUtibjRyeVIvR3RTQzJQTTVNYWJPWHovdlhkNVlpck1CNDZlK2s5bHBxNXR5SjJ2eGh2bDlNYTFxenJwY21SekpPSENoeldIOTNST21XNUpoK3Q1N2gwOHZYajZhS1BNNmFNcjJVMkNtQWJ2TzBGTW8vNU85Mjd0anY0QjFST2dPUkhDd0RmZSsrWEJqcTFYcmovVnU2NnJxL2diM052VFVTOVZtRkhqU1crYWxvNmRQS2ZCSThNNjh2dzVwZE8wakcwQ2xxUm5kZm4wMmMvZGYrOWRybmtEUEhEMDFKMlN2dXlXdTJDbDE0bFFNUEJFNytvVk8rb1dMamhjTU9POTJMWHRWVDJ3SDVHMGQrT3ExbG1uOXVIZzZha2kwMGNiOXZ5TkNHTGN1KzhFTWZYZS8yY2tiZC9XSFhYMVdFOEFQRmhmQXhyaC9WOTc3THFkTDdqaThJcU90bEN6andOVDdiYk14Ukk2ZEp6dVNrMXNWZ3RkbVhMaHpJL3Z2L2V1aVhwdnlBTkhUNFVrSFpaMG5SdnZpT1VzSG0xdEdWemQyVDdBZUMrTnE0aDRzTlhMVXZlYnoyeGMyZnBHdTdiOTRPbXBnS1E5eW9RdVB5M3BoU282ZlRSQlRORXlDV0pzMmNvbURHSmV1YTA3K2wycUcwRHpJb1NCNzN6dzY0ZHUyOWUvK1JzdGtaQlI3bHU5MmJvaGxidnNtYkVwRFI0ZDFxRmpkRmVDaGxRd1E1T2twKzYvOTY2VVV5dDg0T2lwMzVEMFYxNjRPNVphZk4yS2p1ZmFJdUVyUFhVREozeXhlZnR0Q1YveS9mckdsYTEvWGUxMkh6dzl0VjZad09YVzdNYzExZXdIUWN4U0t5Q0lxWFNsVFJURTNMZXRPL3JMVkNtQTVrWUlBMS82eUxkLzlMdjcramUvUHhBdzVOZnBxQTJIVDNZajc1Y3lzeXVkMStEUklSMTVqdTVLdUNTdVRFdVZSYk0wM1gvdlhhTzFGbnovMFZPZGtwNlcxTjN3bTFYMWdVeDY0OXFWQWNPdzkxR0FMa2YxZi9DcTE1NldPZGg3VE5MZWpTdGJ5eHJRYy9EMFZGalNpNDJGQVhWMzJyWDNCREZMcllBZ3B0S1ZOa0VRTXk3cCttM2QwUXRVSDREbVJnZ0QzL3I0ZDUvOHU5MWJOOTFsNTBuZ3AzRmdsbDIrUkExekxwYlE0OW51U3NQbkpuaWpvWml6dXJ6VnpKSDc3NzByV1c0Qjl4ODk5WDhsL1grdXUzRlZzUEtBWVR5MWNlM0theHV3NnFvS2RqSjhhZklwcG0yL3QwZzZMdW1talN0Yml3NnVQWGg2NmtwbEFwZFhLVFBHUzRkOWZ3ZUNtS0psRXNUWXNwVStEMkorZFZ0MzlHK3BJZ0FnaElHdi9jMFBUZ3h1dTNMOVRYYWNBRjZjanJxbS9TeGpoOCtPVGV2Z2tTRWRQRFpNZHlVc0p5WHBtQlpQbi8yaisrKzk2M1RoZ3ZjZlBiVkJtVll3YmE2K2lTMno4clpJZUxCN1JjZUFLMi9VZERteWVmdHQ3M0pVanIvZnVMTDFseVJwOFBSVXU2U2YxRUx3Y3AyemZ4T0NtUEp2bFFReGxhN1VwMEhNQTVKZXNhMDdhbEVkQUVBSUExOTc3NWNQUnE3WnVIWm9jKy9xbmxyZi9NMHlEa3ladGNwRlB6RXRTOGV5M1pVT1AzdFdLYm9yb1h6anlnWXl5ZzRFL0h1LzlCTnZDUVNNTjNycWhsWms1YXM3Mmc5M3RyWGM0S3FiTStHTHpkdmZrUEJGa3BReUxjMGswMStLcGMwVmtsNmlDcWFQSm9oeHNFeUNHRnUyMG1kQlRGelNqbTNkMFJQYzhnRTB2TTRLMU1ON3YzeXdlOGUxRzU1ZnQ2cWpyZVlnbzhIandGUzY3WFoyUXlxMzdQelpsZWl1aEVxdFd4blZyOTl4azJvZFJxWGhOemRENmx1ellpNFlDTFM3WXJzWjc4WG1iWGRzdkplU1RFdEtwRTNGMDZZU3BxVzBaYm5nSENHSUtmL3ZTeEJUNlVwOUZNVDg0YmJ1Nkh1NHd3TndUVDBWcUljUGZPM1F3SjZ0R3gvdWFHOEpWUHJHOS9OMDFKY3RhNVJmUWpsbG54MmIxaURkbFZDQlgvaXA3YnI2aWpXMmx0bUlHNTFoNk95bWRhdldOM1FialZyTHA5V0xyUS9TVmV4SDByUVV6d1l2eWJSbCs0RW5pSEd3VElJWVc3YlNCMEhNRVVtN3RuVkhFOXpoQVRTeWJnbzB4SjkrODRlL3RLOS84MzJSVU5DeENuU3pkVU1xdCt4Y2Q2Vkg2YTZFSld6cFhhVTN2UEpHWDl6MElxSGdvZDdWWGJzYnNqMTBPYko1Kyt2WDVjaTBMTVhUQzhHTHVWenVRaERqdXVzQlFZejlXK254SU9hV2JkM1IvK0lPRDZBUjlWSEFGVDc2cno5KzM5Nyt6ZTh5S2oxQm1tZzY2dVZLcUhWYjV1TkpIVG8rb2tlUERtdm83RVhlbE1oV2lBMzk2bXQyYS8zcVRsL2NBRmRFV3crdGpMYnRydXQ2NlhMa2lqMnROSHpKZERIS0JDOUowNnA4cXdoaVhIY2RJSWl4ZnlzOUdzUWMyTllkdlpzN1BJQjYxNlVBMS9uVWZ4ejkxbzNYWHZGcXV5dlNmcHlPMnBheWwvamh1ZkZwUFhwa1dBZVBEbXRxTnNhYnM0bjFYOVdqMTk2eTFUYzN3L1dyT3MrMWhFTTlkYm5oK2lCOGFhWXVSMm5MVWp5VmJlMWltcXBtYUJlQ0dQZFhoZ2xpN045S2p3VXg1eVJkdjYwN09zRWRIa0E5NjFTQWEvM2RRMDhmdjI1VGQzbFRlTklOcWJheXkvaWhaVms2ZnZLOEhqMHlyQjgvYzRidVNrMG1GQXpvN2p2M3FpdmE2cGNiNCt6bTdsVlJSMiswZERseVlQdWRDVjhzTFc3dGtqSXRaL2FOSU1aMUZXS0NHUHUzMGtOQnpDOXM2NDcrRTNkNEFFWHJ2aHdDTktQaHN4TjdvcTB0dzFkMHIxaFp2NHBHOHdRd2xXNWt3REMwZFV1UHRtN3B1ZFJkNlpFamRGZHFGamRkZjRWckFwamNRM010Ny8xZ0lQQ3NJVzEzTWxVZ2ZMSDN1bHgxK1NWK1BXVmFpbVdEbDRSRG9iSlZ1SHFyOWorY1pjdmZmbkVwVlplNXhDOWFEcnhISFMrejZBb3FYNnNyOXIyTVg3Qi9Pek1sT3JML2x1M1hwRzhSd0FCb1pEMExjSzMzZmVXeHEzZTk0SW9qcTdyYUk1VlVybXVwNk5NTnFiSjl6SFZYR3FTN2ttKzF0WVQxR3orelR5MFJiL3hQb0p4em9hTTFNcmkyS3pyZ3hJb1o3NlZ4ZTdyVTVkSzBkR2t3M1hpNitQVFJScjMybVJZeHJxc1kweUxHL3ExMGNZdVlPVW5iYnVpT251UU9ENkJSOVMzQTFUNzA5VU92SExoaDg3KzJ0WVFYWnhKTVIxMWIyUlg4c0p5eUxjdlNNYm9yK2RJckJxN1d3TmErdlBlRGQyNUxwYmEwczdYbC9KcXU5bTQ3VjhKNEwzWnR1MzFkanBLWFdydVlTcVN0aGg1bmdoajNWNDRKWXV6ZlNwY0dNZSs4b1R2NlllN3VBQnBWN3dJODRTUGYvdEU5Ky9vMy8za3dFR0E2YXJ2S0x2T0hsVDQ4R2NyT3JuVGlsQjQ5TXFUbno0enpCdmF3bFoydDJ2KzZ2UW9FakNYKzR0NjZtVnFXdEhIZENvVUNnWm9Mbzh1UnZkZmdxc3ZQZm1KYUM2RkxQRzJwMnFGZENHTHMzeGlDbUFidk8wRk16dU9TOXQ3UUhVMXhod2ZReURvWTRBa2YrN2NuUHpXd2JkT3YyMStaY0ZjQWMybjVlbmREc2ltQUtYVCs0b3dlT1RLa3dhTkRtcHlodTVMWDNQblNiZHE2WlYwTjd3RDNtWnlKYWVkVnZUWGRrUWxmN0wzK1ZsdStaZVFHMURWTFRCOXQxR0VmYWl5WElNWjFsV1NDR1B1MzBpVkJqS2xNQVBNWWQzY0FqYTZMQVo3eE45OC8vbEQvTmIwMzIvMm93emd3cWptRVdlNEIzTElzSFIrNm9FZU9ET25IejV4Uk1wWG1EZTF5dldzNzljYmJkbGQ1NDNMdnJXdHNjazQzWFh0RlZTY1A0NzAwYms5enY1SE90bmFKRlV3ZjdjU1E1UVF4OW04TVFVeUQ5NzI1ZzVpUDNOQWRmVHQzZHdEbFlIWWtJT3ZzMlBTTDI5c2lRMWRkc2VhS3VsVWdEQWZMbGt2S2RqaUF5VlNVREYyL3VWdlhiKzVXTEpIVW9lT245QWpkbFZ6dHAvWmNYZlgwR1ZiZS9FVnVDMlE2MjFvcVBuR2NERitZWW5wNXVaWXVzZnpwbzQzQzkxeXAwcXVmcThWeTZPL0RyRWtPSDArN3kyVFdKRnUyc3NHekpnMUwra1B1N0FEYzhGd0dlTTY5WHptNGR2czF2Yy8zck82TTFuYkNOTmQwMVBYdWhyVGs2dkorNGZ6RkdUMXllRWlQMGwzSlZhN3RXNlBYdjZ6ZjlqdVNHd0taZFYxUmRiUkdsajFaNkhKazEvWlh2aUVwMDdvVXVpVFNwaXhicmwrMGlLbTJGRnJFTExVQ1dzUlV1dElHdFloNTdRM2QwYTl6ZHdmUTZIcy80RmtmK05wak8vZHMzWGl3SzlvYXJPV2hnRzVJcWpGb3F2eVJ1bFJGeWJJc0hSdTZvRWNPMDEycDBRS0dvVjkvN1UxYTA5WHU2TjJwRVlITWZEeXBiUnU3bDl3ZndoZTd0ci84SlJkUEgyMFduVDY2a3RVUXhOaS9aUVF4UzYyQUlLYlNsZFk1aVBuU0RkM1IxM04zQitDRyt6N2dhUi8rNWc5L1lWLy81bitJaElNVnpsck5kTlRWUGJ6VS9oQmQ3c05oTEpIUzQ4ZEg5UENSSVQxM211NUs5YmJydWcyNmRkKzFkYjFUMVN1UUtUb2VET085Mkx6dDVTMmR5R3Z0a3F4MVNudUNHSWUybFNDbWFKa0VNYlpzWloyQ21DbEoxOS9RSFQzRDNSMkFHKzc1Z09kOTlGK2YrRC83K2plLzJ6QU11aUZWdW15RHV5R1Z1KzBYSm1iMDhPRWhQWHBrV0JNejg3enBIUllKQlhYM3oreFZkS251T2c3ZnRad01aS1puNDlweDVmcEYyOGg0TDNadC85SkxwNjJGMENVemZiUmw3N0VpaUhGb1d3bGl5cjlORThSVXV0STZCREcvY1VOMzlPUGMzUUc0NVg0UCtNSW4vLzNJbDNlL29POU8yMjc2VEVkdCsyTnl0UUZNUGt2UzhaUG45Y2lSSWYzb2Fib3JPZVdsTjI3UmkzZHNkczFkek81QXBqMFNVYytxS0YyT2JOdiswa3RhV3BnK09sWjArbWdIamh0QmpFUGJTaEJUdEV5Q0dGdTIwc0VnNWlGSnQ5elFIVFVGQUM2NTF3Tys4WGNQUG4zNCtpM2QyMnk1MlRNZHRlMFB4b1poN3pHTUpWSTZSSGNsMjNXMFJYVDNuZnNVRGdWY2VVZXJOWkJKcFUxZHUyR05vNDlJelI2K1hKbytPclY0K3VpNlZub0lZaHphVm9LWW9tVVN4Tml5bFE3c2Y4b3d0T3VHN3VpVDNOMEJWSU1wcW9GbGpKeWYyQk50aTR4czdGbTV4czRhQzlOUjEvNGc3TVJEWTJza3BCZHQzNklYYjk5eXFidlNJM1JYcXRsTGRsNnBVQ2h3YVNZYVI5NmpWdlVuUWEzVFhrL1B4aDJiVHRuUjg5bkZYWTRzbFpnK3VzYTNpR0Z6QVV4ZnpmVFZqcFhKOU5XMmJLVUQrLzlCQWhnQWJuMVdBM3pqQTE5OWJPT04xMjE0YXMyS2FFdXAwNGpwcUd0L0FLdDNONlJ5bDgxMVYzcjR5TENlZVBxMEVuUlhxc2k2bFZIOXo5djN5Q2p4eE8vNGphZ09MV1F1VHMxcno3VWJiTnVZWmgzdkpWbnU5TkdOcnZ6UUlzYWhiYVZGVFBtM2NGckVWTHBTbThwOVJsSi9mMDgweHQwZGdOdnU3NER2Zk9qcmgxNjY5NFpOLzk3ZUdnbFVmR05uT21xYkhuV3JlNGkwTDJneU1yTXJuVGlsaHcrZjFMT254aHg3U1BTVG4zdDV2NjYrWW8wamY2dDYzdldXZXBjYWxuVGwrbFUxcjdqWnVoemxwbytPVlROOWRLTXJRQVF4RG0wclFVelJNZ2xpYk5sS0c4cDlaWDlQOUx2YzJRRzQ3WjRCK05hZmYvdEhkKy9yMy96eFVEQWdwcU91OW1Ha3NvZmJXaDhrN1F4Z0NsMlltTlVqaDAvcTBTUERHcCtlNHdRcFl2UDZsZnJGVjk3b3podVVqVE10YlZxN1FwbnJRaTJSaElPNzZxTHdKVkhRMnNYVGxTQ0NHSWUybFNDbWFKa0VNYlpzWlEzbDN0ZmZFLzFsN3V3QTNIaS9BSHp0WS8vMjVGL3V2V0hUVzVpT3VwcUhrT1VlWmN2Y2xqcDFRMXJ1Q1RiM1hVdlNpYUVMZXZqd1NmM3dLYm9yNVh2amJidTFmazJuKzI5V05heGdlamF1blZmMVZobEpPTGhMTGdsZVRNdFNMSjBMWGk2ZlB0cnpGU0dDR0llMmxTQ20vTnM2UVV5bEs2MmkzREZKVy90N29oZTRzd053ZmIwVzhLTlBmLy80OTNaY3MrR2xURWRkYTludUNXQksxMjByRzhja2xranBFTjJWSkVrM1hObXRPMjdaNnIwYlY0VXJHSnVjMDk3citrU1hvNHpNOU5GV1JkTkhlNzR5UkJEajBMWVN4QlF0a3lER2xxMnNzTnhmN2UrSi9pMDFZQUIyWUhZa29Bcm54NmRmOXN6STZMUFg5SzNkN0lZSGdvYU5BK1BDeWxvOTluT3BaVnNqSWIyb2Y3TmUxTDlaRnlabTlYQ1RkbGNLQmdONjZhNHJIU25iY3ZvOVd1RXNTeDJ0TFdVdDZPZndKWjF0N1ZMTDlOR054S3hKekpya3F2ZlRjbVV5YTVJdFcxbEJ1UTlJK2d5MVh3QU5ld1lDa1BHK3J4eGMyWDlWNzFEdjJxN081YzRzdWlFVlc5Ylo2YWpyMFEycDNMSXZkVmM2TXFUSG56cWxSTkwvM1pYMmJkdW9sKzI1eWw4M3RSS0ZyKzJNYWtWN2E4TnV0STBJWHhhbWo3WnNtejdhRjVVaVdzUTR0SzIwaUNuL1ZrK0xtRXBYdWt5NWNVazcrbnVpSjZqNUF2QkVmUlh3dXc5OTdkQzIzZGR2L05HS2p0WlFxYk9LNmFpTEYrRDFjV0NxTFQrZXpIUlhldWp3a0o0WkdmVmxkNlhXbHBEdXZuT2ZXaU9OYld4WmowQW1sa2pwaG8wOWRiKzVOaUo0V1pnKzJuSjArbWpQVjR3SVloemFWb0tZOG0vNUJER1ZyblNKY3Yrd3Z5ZjZIbXE4QUR4VFJ3V2F3WWUvOGNNN2J1N2YvTldXU0tqb25aenBxQy8vWmE5TVIrM29NWlEwT2ptcmh3OFA2WkVqUXhxYjhrOTNwWmZ2dVZwN3QvVTF4YzF1YkhKT2UxK3dzVzQzMVhxR0w0dW5qN2JxT24yMDU5OHZCREVPYlN0QlRORXlDV0pzMmNvaTVSNlJ0S3UvSjVxZ3RndkFDL1ZTb0tsODlGK2UrSU1YYnQveUowYWd0Z29pMDFIWDl0RHBaQUJqNnpFc1lCblMwOE1YOU5DVG1lNUtjUTkzVjFyWjBhbzN2VzZ2QWdIMzNsN3MzTExwMllSMlh0M3JtL0JsOGZUUnpUeXNORUVNUVl6N0s5d0VNZlp2WlVHNXQvVDNSUCtMV2k0QUw5d1RnS2IweVFlTy9NT2VyUnYvdSsyQndGTExNaDIxL2Z0WjV3Q21jSlh4WkVxSGptZTZLejN0d2U1S3IzdkpWbTNkMHQwME44SDJjRmdiMW5RNXQzMkdzL3UrZVBwb1UyWno1eTcyVjVJSVloemFWb0tZOHFzQkJER1ZyalJiN29IK251amRYQVVCdUxKK0FXREJmUTgrOWNOdFY2Ni9rZW1vaXhmZ3QrbW83ZGlXcFI2eWM5MlZIajdzamU1S3ZXczY5U3UzN1c2YUcyTGFOSFZkNzFvWk5pY2xUZ1l2bHFTa3g2YVA5bnhGaVNER29XMGxpQ2xhSmtHTUhWdDV6cEN1NysrSlRuQUZCT0FFcHFnR2JIVHEvT1RlYUd0a1pFdnY2bldPaGdkTVIxMjMvWFQwR0M2ejhOb1ZVZDMrb3ExNnpZdTI2cW5oQzNyNDhKQU9uVGl0ZURMbHl2Zi95L2RjN2VuenQ4S1pxVFU5bTdBMWdIRXFmTWxOSHgzMzZQVFJibmhmTUgyMXZTdGkrbW9IeTJUNmFqdTI4aDRDR0FCT29pVU1ZTE1QZnUxUTc0NXJlcDlkdDZxajFiRkFnT21vN2QvUGVuZERNcW9wMjFnMHU5SlR3eGRjMDEzcG1yNDFldjNMK3B2cVJubHhhbDREMTlVK0FMSGQ0WXNsS1pHZHhTanVvK21qUFY5aG9rV01ROXRLaTVqeXF3YTBpQ25ETjdmM2ROek9GUStBcStzVUFDNzM0Vzg4ZnZQQXRrMy9GVzJMQkd3UEQraUdWUHN4TFBNcHVGSGRrTW85aW1OVGMzcm84RWs5ZkhoSW81T3pEWHUvQnd4RHYzYkhUVnF6b3IyNWJwcW1kTTJHTmRXWFplTWRPR1ZhbDJZeDh2UDAwWjZ2TkJIRU9MU3RCREhsVnhFSVlwWXdLK21HN1QwZEo3bmFBWEIxZlFKQWNSLzUxZzkvOVlYYnQzdzZIQXJhOTREUGROVE83R2NkcHFPdTVlSGJLR01OSjBaRzlkQ1RKM1hveEttNmQxZmFlVzJ2YnIzNXVxWTd4emV0V2FtV2NOQ3g5L2RTVEN2WDJxWDVwby8yZk1XSklNYWhiU1dJS1ZvbVFVd2wzcm05cCtQRFhPVUF1TDR1QWFDMGovM2JreCsrdVgvejIydCthSyt3NXN0MDFCVXM3NUZ1U09WS1pMc3JQVmluN2txUlVGRDc3OXlyYUZ1a3FjN3RtYm00ZGwyMXdaSDNkaW5KUzYxZG1EN2E4NVVuZ2hpSHRwVWdwbWlaQkRIbE9DUnAzL2FlRG5jT3VnYUFlZ1NBOG4zNmU4ZStzL082SzE1Wjh3TSswMUhidjU4Tm5vN2E3cU5ZdUdTdXU5SkREblpYdXVYR0xicGx4K2FtTzYvSEorZTE3d1Y5dHYrOTgrVlBIeDFuK21qL1ZhQUlZaHphVm9LWThxc05CREc1eTYya3ZkdDdPaDdqeWdiQUUzVUlBTXY3L0NQUFBuUGRwblZYVmZYUVhsNU5TbFdYWGZQRFFhM1JBZE5SMjNFVWw2dGZueGdlMVVPSE05MlZZZ2w3L3RIWDBSYlIvanYzcWxTWE96K0x4MUxxMzlKank5ODVKemQ5ZEs2MUM5TkhOMEVsaWlER29XMGxpQ2xhSmtGTUtYKzJ2YWZqSFZ6UkFIaW0vZ0JnZWUvL3lzR09iVmV0SCtsYnQySkZ4U2VvQzhhQnFUaHM4R2czSktlbm8zYXlHMUs1ZGV0RU1xM0huenFsQjU4OHFlUERvN0pxR0V2azFwdXYwODVyZTV2eW5GN1QwYTdWSFcxVnY0OXptRDZhaWhSQmpGUGJTaEJUdEV5Q21FTERrclp0NyttWTRXb0d3RE4xQndEbCtjRFhIcnYycHVzM0hsN1YyUmF1Nk9Sa09tcjc5OU5uNDhCVVdxZk8vV2hzYWs0UEh4N1NnNGRQNnNKRVpkMlYxcTVvMTYvZGNaTU1vL2x1STRsa1dqZHM3SzdxUGN6MDBWU21hci91RXNSVVd3cEJUSlUzRFRmdmUrMUJ6QjNiZXpxK3dWVU1nS2ZxRFFESzkyZmZmUHpXbS9zM2Y2czFFaTR2QjZFYlV0WGI0cmZwcUN2YWppb2VHSjRhR2RXRGg0ZjAyUEdSc3JvcnZmNWwvYnFtYjAxVG5zZmpVL1BhZDExZjJYOVhwbyttUWxWdEFRUXg5bThaUVV5Vk53ODM3M3YxUWN3WHQvZDAvQnhYTHdDZXF6TUFxTXhILytXSmQ3NXcrK1lQQlFPQkNzSUpwcU51bm5GZ0tsdERKUTgrNVpTYVNLWjFhSm51U3B0NlZ1b05QMzFqMDU3RDA3Tng3Ym1tOU14SVRCOU5wY3JPQWdoaTdOOHlncGdsYjVUdTIwNmJmcUZna1NsSjEyL3Y2VGpEbFF1QTUrb0xBQ3IzeWZzUGYyWmcyNlpmTG5sU01oMTFUUmNxdWlIWmN3d3pzeXRkM2wzcGpiZnQxdm8xblUxNy9yYUZROXE0ZHZId1Rrd2ZEZHNxVmdReERtMHJRVXpSTXBzM2lIbno5cDZPVDNERkF1REp1Z0tBNnR6M2c2Y2U2Yjk2L2Q2aUp5VFRVZHUvbno2Zmp0ck9oNE5peXo0MU1xcUhEZzlwT2g3WHJmdXVhOXJ6MXJRc1hkZWI2WWJGOU5Gd3JISkZFT1BRdGhMRWxGL044SFVRODVDa1c3YjNkSmhjclFBMFFvaERBRFRHNmRISkYwZmJ3c05YYmxpenZzS2FrYjJWSFo5TlIxMjhFTVBaWTFqK0ttMDVpazRHTUtWYzI3ZFcxL2F0bFdsSmMvR0VwdVpqbWs4a20rcWNEUWFEc2l4cExKWmkrbWdzeWFyMXZDdFNRT2t5cTErYkpXZXVnNWVWYThPSzdObld4YVZVWGVZU3YrakVNWFc4ektJcnFIeXRydGozNVg4aFpVbi9hd2NCRElBR29pVU0wRUIvOHFWSDErMjV2dTlreityT05xYWpkbkEvbTNRNmF2djMwMWowYVRwdGFubytwcW41dUpMcHRPL096MEFnb0dBb3FHQW9wR0F3MkpRelFhSEJsU3hheERpMHJiU0lLVnBtYzdTSWVlK09ubzcvemRVSmdLZnJCd0JxODZkZlA3UnI3N1pOZzUzdExVR21vM1pnUDVtTzJxYjlOQzc3TkgvNVdDS3BxZm00Wm1KeG1SNGVpRFlZQ2ltVURWNENTd3llRGRTdG9rVVE0OUMyRXNRVUxkUGZRY3d6a3ZwMzlIVEV1RElCOEhUZEFFRHQvdUpiUDN6RHpUdTIvSDBrRkxTOWlzMTAxQTRldy9KWGFjdFJkRVVBay8yeTFQS1daV2ttbHREMGZFeHpIdWl1bEdudHNoQzhBSzZzYkJIRU9MU3RCREZGeS9SdkVQT0tIVDBkOTNORkF1RDVlZ0VBZTN6c096OSs3d3UzYi81OXd3allkc0l5SGJYRHg3Q0dmVndvdTNIVFVaZS8vT0pXTU9XV25YSmhkeVhETUM1MU1Rb0ZReklDM0FiaGtRb1hRWXhEMjBvUVU3Uk0vd1V4OSszbzZmaGxya1FBZkZFbkFHQ2Z2L25lc1cvc2VrSGZhMndKQkd5cnpCZGJsdW1vaXkzY0RPUEFWSHNNWThsTWQ2WHArZnAzVndvRWc1ZGF1Z1NEUVM0MDhHNmxpeURHb1cwbGlDbGFwbitDbURFWnVuNUhUOGNvVnlFQXZxZ1BBTERYNXg5NTl1ajFtN3V2ZHl3OG9CdVNJeGRIMzNkRE11d3AyN0lzeldSblY1cUxPOU5kS2RQYVphR0xFUVBxd2xjVkw0SVloN2FWSUtab21mNElZdDY0WTMzSFo3ajZBSEFMT3NBRExqTjA5dUtlYUd0a1pHUFB5bFcyVjE2WWp0cWhoMzQ1ZGhRYk1SMjFrMlViaHFITzFoWjF0cllvbFRZMUZZdHJlajZtUktxMjdrckJZTGFMVVNpa1FKQUJkZUZlVEYvTjlOV3Vlajh0VjZiM3A2OStRTkpudWZJQWNCUCtQUWk0MEFlL2R1akszUys0NHRpYUZkRUkwMUZYdUR6VFVkdTBuMGJWKzFqTnRzU1RLVTNPeDhydXJzVDAwV2o2Q2hndFloemFWbHJFRkMzVG15MWk0cEsyNzFqZjhSUlhIQUMrcWdNQWNNYWZmZlB4bCsyN1lmUDkwZGJ5Y3hpbW8yWTZhbnYyMC81dVNPVXVuK3V1TkZta3V4TFRSNE5LV0MzWGRZS1lha3NoaUtueXB0VDRmZi9ESGVzNzNzT1ZCb0R2N3Y4QW5QT1gvL0xFVzE2MFk4dGZCc3Q4NEdRNmFuc0RnV1dYYmZMcHFCMDUzbm5mU0tWTmpjM09LMkdKNmFOQlJjeVc2enRCVExXbEVNUlVlWE5xM0w0ZmtiUnp4L3FPcEFEQVpmaFhJdUJpdjNucmpyOGFQREw4eVpvcU5IVU9ZQ3BkZ1p2R2dYRitPbXBuYXRhT3BlbEduY2VZS2ZpR2FWa0toTU5xaVlRVmtDV1pwbFRubVpVQXAxa09GR0E1c0Rhclh2dHZ1ZUNZRmluRmNtQmpMRGUrbjVZcjA3Sm5yUTV2cHlYcFRRUXdBTnlLbGpDQUI5ejNneFAvdGVPYURTK3E2a1JtT21yN3Q0WHBxSjNabHJ4dnBFMVRGK01wbVVWK25FNmJtWEZqREtQeU5BendhNFdNRmpFT2JTc3RZb3FXNmU0V01RZDJyTys0bTZzS0FMZWlKUXpnQVdmR3BsL3k5TWpvU01VVkdCdGF3YmloY3I1azJZMllqdHJCYXFiaDRJSDFTZ0JqV1pZbUNnS1lmTUZnUU9GUVVPRmdRQUVyMjBJRzhEaGF4TmkvSWxyRU9GaW1lMXZFbkxXazMrT0tBc0ROQ0dFQUQvamQxKzB4ancrZDMzbG1kR3EybHFkaXBxTjJiSlcySEVXL1RVZGRkdGtGMzVpSUpWWHVoTldYQXBtQW9ZQmxFc2pBMHdoaTdGOFJRWXlEWmJvemlIbnJqZXM3SnJpYUFIQXpRaGpBSS83Z3YrMGRPL3pjMlJkTnpjWlNybndJYjBRM3BEcVhyWHFQQTFPMy9henZkTlJMbVlvbFZHMG4vbUF3cUhBb3FGQWdJTU95R0Q4R25rUVFZLytLQ0dJY0xOTmRRY3czYjF6ZjhVOWNSUUM0SFNFTTRDSHZ2R1AzRTRlT2oveGlQSm15dkR3ZHRTMFArRGFzMU12VFVkdTNuMFpONjdPekc5SnNJcW1ZWmMvK2hvSkJSWUpCaFExRGhrbVhKWGdMUVl6OUt5S0ljYkJNZHdReHM1TGV3dFVEZ0JjUXdnQWU4OWJiZG43eDROSGgvMk9WK2krL3k4ZUJjZE4wMUU3dXA3dzRIYlVhTnc1TUxKblNYTnIrUndYRE1CUU9CUlVKaGJLQkRETXN3UnNJWXV4ZkVVR01nMlUyUG9oNTk0M3JPMDV5NVFEZ0JVd3JBWGpVcC8vajZCZHZ1bjdqenk1M1JqczlIWFhkWjBQeXpIVFVOWVF3aHNQSHNOaFBqVG9IYW5uZlNLWk5UU1JTeTFhK0RSdi9BcVlzcGROcFdXS0dKZmk4b3Nhc1NRNXRLN01tRlMyek1iTW1IWkswNzhiMUhTbXVHQUNhNHQ0T29IRSsvOUF6UDk1MlpVOS9kWlh0WXNzeUhYV3hoWm1PMm9GdHlYN0R0Q3hkTEhNZ1hqdERtUHdmbXFhcHRHbktNZ3h1aS9CblpZMGd4cUZ0SllncFdtWjlneGhUMHQ0YjEzYzh4cFVDZ0ZmUUhRbndzT0h6RTN0T25yMDRXbmtsdS9ZS0V0TlIyeFVWT0hOZ3ZSREFXSkltNXBOS043aDNVQ0FRVUNRVVVrc3dxSkFoR1pZcDV6cFpBSldqYTVMOUs2SnJrb05sMXJkcjBwOFR3QUR3R2tJWXdNTis1M1Y3RWllR0x1eStNRGticisxQm1lbW9LMWlsTFVlUjZhaWx5VmhDbGJRZHIwY3NFc3dMWklLeTFCb0tLRURqR0xnQVFZejlLeUtJY2JETStnUXh3NUxlemRVQmdOY1F3Z0FlOTg3WDdoNSs0dW5UcjVpZFQxUTkvUXZUVWRkZU9OTlJWL2JMMC9HRTRpNmZzQ2dVRE1xeXBIQWdvUFpRVUsyaEFKMlYwRkFFTWZhdmlDREd3VEtkRDJKKzQ4YjFIVE5jR1FCNERTRU00QU52ZjgydUh6eDJiT1R1Vk1xcytFR1o2YWlMTDh4MDFMVnZZcW5sNXhJcHphVzlkWTZsTFV1V0pVV0NtVUNtSmNqdEU0MUJFR1AvaWdoaUhDelR1U0RtQ3pldTcvZ0dWd1FBWGtRdEV2Q0ozN3gxeDZjR2p3MS9sT21vYThkMDFBNzg3YlBmaUtmU21rbVpuajdYMHBZbFExSmJNS0FvZ1F3YWdDREcvaFVSeERoWXB2MUJ6S1NrdDNJbEFPQlZ0S3dHZk9hei8zbjhnVjNYWGZHeWNrNS9wcU91YlI4WHltWTY2bkwyTVdXYUdvOHRub3JhcUhBbGhwMS9GY08rWTIxSUNoaUdrcWFwaE1tZ3Z2QklKWTVaa3h6YVZtWk5LdjhhWDlXL1BkNTg0L3FPVDNBRkFPQlYvUHNPOEpsejR6T3ZPREY4NFhtN0sxdUdTOGFCY2JSU1dlOEFwbTdIc0w3ZGtJcXhMRXNUQlFHTW0xZzIvSDdhc2hRd0RMV0ZBb3FHQWdvem9pOWMvcjZsUll4VDIwcUxtS0psMnRNaTVrRkwraVJuUHdBdm80WUkrTkFIdi9wWTEvYXIxdzlmc1c1RlY2bFQzeTJ6SWJscU9tcVB6b2JraGVtb3grY1RTbHJMTE4vQWxqQk9IWmRBdHRWUlBHMHBaZEZDQmk2dHpORWl4cUZ0cFVWTStkZjZzdGFha3JSejUvcU93NXoxQUx5TWxqQ0FELzNPNi9aTUhYMysvTDZKbWZsVWJkRUIwMUdYM2srbW95NzNRV2d5Vmp5QWtTUy94eEttbFhtRkE0YWk0WURhUXdFRkRmNy9BWHZSSXNiK0ZkRWl4c0V5cTI4UjgzNENHQUIrUUFnRCtOVGJiOTkxN05EeFUzZkdFaW1ycG9kd3BxT3VlVnZVc1Axcy9IVFVNL0drWWlibm81UUpZeXhKa2FDaGFEaW85bEJRUWZJWXVPWEJtU0RHb1cwbGlDbGFadVZCek5PUzNzT1pEc0FQQ0dFQUgzdnJiVHUvZWZEbzhPK2IyVzRRVEVkZGZHR21vNjU5RTRzdFA1OU1hVFpORjV4aUZnS1pvRHJDUWJXSEF0eVEwZmdIWjRJWWg3YVZJS1pvbVpVRk1YZnZYTjhSNHl3SDRBZjhEdzVvQW4vOTcwZitmdSsyelc5b2huRmdLdDRXdjQ4RGsvMnkzdVBBSk5OcFhVeWtWYzR3S0VZRksvYmFtRENsOTY5NENVSERVTm95RlV1WklyNUN3eXAzakJIajBMWXlSa3o1bDhORjMvenN6dlVkdjhLWkRZRDdOQUJQK2Z4RHp6eldmOVg2M1U2RUUweEhYZnVEZ0orbW8wNmJsc1pqU1ptVmx1SFRFT2JTOG1XT1FwejdTY0F3bERaTnphZnB6NFVHVlBBSVloemFWb0tZb21XV0RtTEdKRjIvYzMzSEtHYzFBTCtnOVRQUUpFYk9UN3p3dVRQajUrd09KNWlPdXZiaS9UUWR0V1ZKRS9IeUF4aG4rS01OaVdsWk1neEQwVkNteTFKTGtGczI2bmdXMERYSm9XMmxhMUxSTWt0M1RYb0hBUXdBdjZGR0J6U0ozMzdkbnNUVHc2TTNuaHVmbm5meUlieXFzaHN4SGJWOVcxL2VrZzBhQjZiZTNaQXV4aEpLdVNRRDhVdDNIa3VaTVdTQ2VZRk1oRUFHOVRnSENHSWMybGFDbUtKbFhyNkNCeVRyUHM1a0FINURMUTVvSW0rL1k5ZTVKNTQ1ODdMcHViaFo4cUdhNmFpTGJBdlRVUzlidGlGTnhaSktNSkNKNHcvVnBpV0ZERU1kNGFBNncwRkZBdlFzaG9NUHpnUXhEbTByUVV6Uk1oZStpRXZhdjNOOUozY1ZBTDVEQ0FNMG1iZmZ2dXVSeDQ2UHZER1pTdGYwMU01MDFMWHowemd3czRtazVrenF5dlZrV3BsWE9CQlFaempUUWlaRUlBTW5IcHdKWWh6YVZvS1lvbVZtdnZpL085ZDNQczNaQzhDUENHR0FKdlNidCs2NDc5R2p3eDljOUJ6TmROUWx5bVk2NnVYRWttbk5wQWhnR3NtME11UHh0T1FGTWtFQ0dkajU0RXdRNDlDMkVzUVVLZk9JTEgyQXN4YUFYMUZEQTVyWVo3NS8vRi8ydktEdlZVeEhYYXBzcHFOZWJ2bVVhV284bmxiaGhNcTFUK0ZjNi9hV0VhRzVmSGFrMnMreHpBeExwbVVwbGtvclRVNEdNV3NTc3lhNS9rSENNcVJiZHZaMlBzalpDb0I3TVFCZit1S2p6NTNZdXFYNzJubzl0R2UreVhUVTl1MW40N29obWJJMEZrc1dmYmduaENteWZBTkNtSHdCUXpKTmFUNlZGcE5lVS9tenV3Q0NHUHUzckVtRG1BTzdlanZ2NWl3RjRHZDBSd0thM1BObngzY1BuNStZY096QjB3MFBFVTB5SFhXOS96N2pzVVRUdHE3dzRtNmJWaWFNYkE4SDFSVUpxVDBVb0JJZzNyOTJGVURYSlB1M3JBbTdKcDJWOUM3T1VBQitSLzBMYUhLLy9kbzlNMGVlTzNmVDJPUmMwczV5bVk3YXdXTlkrTk02akFOVHVQekZlRUlwaThhVVhtVmFsZ0tHY1NtUWFRdFJIV2cyQkRIMnI0Z2dwbWIzN09ydG5PVHNCT0IzMUxvQTZCMTM3SDdtaDArZHVuMCtuclRzZW1ndlhnalRVVHUybjNVc2V6cVJWSnorTEw1aFdwYUNocUhPY0ZCZGthQmFDV1NhQmtHTS9Tc2lpS25hTjNmMWRuNkJzeEpBTTZDbUJVQ1NkTTl0Tzc4emVIVDRIV25UclBrQnYybW5vMjZDY1dEbWtpbk5wa2xnL1BwQWJscFM2RklnRTFKTGtHcENNL3pkN1M2QUlNYitMZk41RURNcjZUYzRHd0UwQzJwWEFDNTU4MDl2LzhqZzBlRy9xYVdNcHA2TzJvN3RsbnVubzA2azBwcE9wYjM5d0lpeWo3TnBTWkZBUUYyUmtMb2lJVVVJWkh6OTk3YTdBSUlZKzdmTXgwSE11M2YxZGc1eEpnSm9GblRvQjNDWmYzanc2WWQyWE5ON3MyMWhBOU5SMjdTUGpadU9Pak1WZFRKdlZoM0R2cjlWaGI5a1ZMQ1VVN01qVmJXUFpVN0o0dFRzU0pXWGZmbFpFVEF5NFV3c2JTcHAwaUtLU21FdDd6bG1UYXEyRkovTm1uUkkwdDVkdloxcHprQUF6WUovYXdHNHpLblJ5UmMvYzJyc3RKdkdnWEYrT21wbmFwcU9KZDFHL2NhQnNTeXJJSUJCc3pLei8rSnVEUWEwSWhKV1p6aWtVSUQvNS9nRkxXTHNYeEV0WXBhVWx2UW1BaGdBellZUUJzQmxmdnUxZTh5bmhpL2NlR1pzZXE2YWgzWW5Bd0c3TjRUcHFKYzNIaytJR3JJYm5uRGR4YlF5TzlRV0RHcEZKS1RPY0ZBQmFoVzhUUWxpSE5wV1h3WXhmN0dydC9NeHpqb0F6WWJxRW9DaTN2bmFQYU0vZnViTWk2ZG1ZOHMrZjN0MU9tcGJBaGlmVDBjOUVVOG9VYS93b040aGhVdERFUzltTmFZbEdZYWhqbEJJSzF2QzZnZ0hxV0I0R0VHTS9Tc2lpTG5Na0tSM2M3WUJhRWJVa1FDVTlMYmJkLzN3NExHUi81RklWdEVPd2dQVFVZdnBxSmNzZXlhZTFMelpQRVBoV3V5UUxlc3pMVXNCdzFCSEpCUElSTU5CQnFCcnhyY1BRWXhEMitxYklPWXR1M283WnpqVEFEUWpRaGdBUy9yTlY5LzRENDhjR1hxUFpWazFCd0pNUjEzTjhvMlpqanFXVEdtR3FhaFJJOU95RkRRTWRVVkNXdGtTVW5zNHlFSHhFSUlZKzFkRUVDTkorc0t1M3M1dmNJWUJhRmI4Y3dwQVdUNzcvV05mdmVuNmphOHQ2d0pTNzI1SWhudTZJVGs5SFhVOVFxOWtPcTN4UkNvekNHdkpubENHSStzdTV4Y05PLy9LUm4zZW84WDN6N0MzYkp2M3I3STV3MHJOQUZWNnVVVGEwbnlLMFlhYW9yTElyRWtPYmFzblowMmFOS1N0dTNvN3ozQm1BZUMrQ2dETCtNSWp6eDY1NGNxZXJVdGVQQm94RGd6VFVkZCtETE1mMDZhbHNYaENhZXZ5Z2doaGJGaVdFR2JSOHJsemR6NWxLazdMSzM5WEdBbGlITnBXendVeGI5N2QyL2tKemlnQXpZenVTQURLTm5UdTR1NlRaeStPbDY2cHVYOGNHS2FqTHIzZGxxU0wrUUVNZk1kdGYxckx5cnhhZ3dHdGJBbHBSU1NrU0pDcWlTL2ZPM1JOY21oYlBkVTE2VUZKbitSc0F0RHNxT2tBS05zN1g3c25kdXprK2QxakU3TUpwd01CK3hkbU91cmxYSnhQS0VrQWcwWTk1R2ZmZTIzQmdGWmxBNWx3Z0FhN3J2b2JPVkFBUVl6OVcrYlNJQ1lsNlUyN2V6dHA4Z2FnNlJIQ0FLakkyKy9ZZmZMeHAwNi9jaTZXV0Z5UllqcHFtN2E3TWROUlQ4VVNpbHNrTUs1OWVHMHl1VW01MmtOQnJXb0pxeXNTVklnYWl6L2V5d1F4RG0ycjY0T1k5Ky91N1R6TUdRUUFoREFBcW5EUGEzWisvOUdqdzcrVnpvM2h3SFRVenUxbkhjcWVUU1ExNjd1cHFJazkvTUswTEFWa3FDTVUwdXFXa0xyQ1FkRkF4dU5uRjBHTVE5dnEyaURtYVVudjRjd0JnQXhDR0FCVmVmT3Jkbnpza2FQREg3Y3JQR0E2Nm9LZjFtazY2bmdxcmVtVWYxdUhFOFg0aTJsSkFjTlFWemlrMVMxaGRZUkRWR1M4ZW00UnhEaTByYTRNWXU3ZTNkc1o0NndCQUp1ZVRRQTB0OC85MTFQZjMzWGRGUyt4SXhBb2QyR21vN1puVzFLbXFkRlljdWtLdFdkblJ5cnpyMStuMlpFdUxkL2cyWkVxTDl1b1lmL3NPMzdMemNZV01LUjQydEpjTWtYdzVyV0tKTE1tT2JTdHJwazE2Yk83ZXp0L2hUTUZBQmJ3RHlRQU5Ua3pOdjJUSjRZdkROWDFRZGFoMzNERk9EQjFPb2FtWldrOG51U0JGYlpwNUh2SnRLUnd3TkRLbHJCV3Q0WVZEUVg1ZzNqbDcwNkxHSWUyMVJVdFlrWWx2Wk96QkFBV0k0UUJVSk4zdm5hM2VlemsrWjJuTGt6T1ZCTUlWQlFlTUIyMTdOcWw4VmhTS1JJWStEQVFNQzBwRWd4b2RVdFlxMXZDYWlPUXFjdHh0N3NBZ2hqN3Q2d0JRY3c3ZC9kMmpuS0dBTUJpaERBQWF2YXVueG00K09TeloxODRNVE9mcWlZUXNIOWhwcU5leXNWWVFnbUhaMElpMy9IUUE3Q1BqNHNscVRVWTBPcldzRmExaE5VYXBOcmoydmNoUVl4RDI5cXdJT1orU2ZkeFpnQ0FQZlYzQUNqcXIvN2xSM2UrZVB1Vi85d2FDUzE3YmFrNGJLaDRyQWwzeklia3RuRmdwdU5KVGFmTjhzdW9ja3lZcXZlRk1XR3FMN3ZNSHpnMUpreDE1Mm10KzFmNXpHeUdJVm1XTkp0S0s1SDI3NkRVbnExWU1rYU1ROXRhMXpGaTRwTDZkL2QyUHMwWkFRQ1g0MTlDQUd6emxsdHYvTW9qUjRiZWJkbmN5b0xwcU8wcGV6NlpXaFRBb0RhMFFQSG8zeTM3aDR1R2dsclRHdGJLU0VqaEFOVWgxNXdYdEloeGFGdnIyaUxtandsZ0FLQXhkWDRBVGVvejN6djJqL3UyYmZwNVd5NDg5WjROeWFmVFVTZFNhWTBsVXlyTXgyZ0o0K1RmdU1peXRJU3A3ZjFSNWdxcktUdGdTQ25UMGt3cXJaUkp4TmJ3Q2lZdFloemFWc2RieEJ3MnBGMjdlenVUbkFVQVVOOTdENEFtOTRWSG52M1I5cXZXNzZqcG9zTjAxTFpzaTJtYXVoQkx5cXltTEdPcFplMmJwcG9ReHFIdDhFa0lVL3A4dFMrRXlSY3dwSVJwYVNhVmtrbmpzY1pWTWdsaUhOcFd4NElZUzlJdGUzbzdIK1RkRHdDbDBmNFdnQ09HejAwTVBIZG0vRUs5SG5DcmV6eDNwaWJ1cHVtb1pWa2FpeGNQWUx5S05ncHdtbWxKSWNQUXluQllhMXZENm9xRXFEQTE0bHlsYTVKRDIrcFkxNlFEQkRBQXNEenFGQUFjOFk3WDdrNGNIN3F3Ni96Rm1WZzF2ODkwMUxZVXIvRllncW1vL2Z1SXloYld3YVZBcGlXc05hMWhkWVJETkNPdTUzdUlJTWFoYmJVOWlEa3I2ZmQ0eHdQQThnaGhBRGptYmJmdk92WERwMC8vMU14ODNHUTY2b0tmMW1FNjZvbFlRbkVibnl4NElBZUJndFFTTkxTbU5kTkNKaG9LY2xEcWNlMGdpSEZvV3kwN3kveXRQYjJkazd6YkFXQjVoREFBSEhYUGJUc2ZIRHc2L0wrU3FYUjV2K0NpY1dBcVZlazRNUGFWZmJuWlJGSnpEQzRLT1BaUWJVbHFEUVcwdGpYVFFxYU5RTWJaMElBZ3hxRnR0U0dJc2ZTTlBiMmRYK1JkRGdEbElZUUI0TGczdjJySHB4ODVNdnlSY3BaMTB6Z3dYcDJPT3A1TWFUckZhS0lOZmVLcWNYM0VaOTU3QzdYbkJUS3RRYXBYanJ5dkNXSWMydGFhZ3BoWlNXL2gzUTBBN25nT0FJQkZQdmVERS8rMjV3VjlyMWpxaXNSMDFMVnRTeXB0YWl5UmttbFo5cFZkNVRUVlZYZjdzbTJHcERMZklZWlRmL2NTeXpvd1E1SlRzeU5WT2o5UzNXZEhLckZTUi8rT1J2bkxtWlkwbTB3cm5pWVV0Ylh5eWF4SkRtMXJWYk1tdldQUGhzNC80MTBOQU9Yalh6VUE2dWJzK015cmpnMmRmN1pVM2EvdTNaQ2NmamlzOVFtL3dsOHhMVXZqaVdUWkFRd3VaN0ZEZFZ1ZjM5K2xscFdwWkhXR1ExclhGdEdxbHJCQ0FhcGR0dnp0YVJIajBMWlczQ0xta0tTLzRCME5BTTdWN3dHZ1poLysycUdPSFZldlA3V3hlMlhYb290UnhZUHh1cU1iVWtWdFFRem53aUJMMHRoOFhFbXIwdU5ZMlVKK2J3bGo3OSsveExMMWJBbFQ0LzVWM0JLbXdoWFkwOXJIblMxaFNyMEREVU5LbXBabWtpbWxtbnpjSmxyRTJMK2lPcmFJU1V2YXUyZEQ1eUZxTmdCUUdmNGxBNkN1M3ZIYTNUTkhuajgvTUQ0OWw2em1vY2FwaXJ2VGxXMm5wNk9lcUNLQWNSUGE3cUJaV0xrcHJ5TmhyV3VMYUVVa3BFQ1Qva3VNRmpIMnI2aU9MV0wrZ2dBR0FLcERDQU9nN3U1NXpjNFRqeDAvZGVkOFBHa3hIWFh0MnpJVlR5aEdpZ0Y0am1WSjRVQkFxMXNpV3RjV1VWYzQxSFFWTTRJWXQ1YTVaQkF6Sk9rUE9ZTUJvRHFFTUFBYTRqZGZmZU8zSGprNi9MdFdCYzN4bVk3NmNuT0psR2JUSkRCby9NTWthanZXbGlXMUJBTmEweHJSdXRhSU9zUEJwdWt6VGhCai8wb2NEbUorWTgrR3psbk9jQUJ3NGprQ0FCejJtZjg0ZXQ4TCt6Zi9VbmtYTFBkTVIxMzJ1QU1PdG9LSnA5SzZtRWpWVk5sMnk1Z3dpNVpuVEJoN3Q2T21HWklZRTZhTTFUbDIzVElrV1lZMGwwcHJOcG1tVWxwRkFaNGRJOFp3eVRHOXZKUXYzTFNoOCtlcHZRQkFvNi9OQUZDREx6ejh6S00zWHRNN1lNUGpkT21MbTgrbW8wNlpwc1ppU2RreDhXMzFVemdUd2xTMWo0UXc5dTVqaVZURXNUQ3RRWU9JRzVKTVNYUEp0T1pTL2cxa0NHTHNYNG1OUWN5a3BPdHYydEI1bHBvTEFGU1A3a2dBR203a3d1UXRUNThhTzF2am8zVDlIcUlyVHl0czNSYlRzblF4bHJJbGdQRTNPdDdBWCs5bVExSTBIRlIzVzBScld5TnFEUVk0YThzb2dLNUp0cFh5ZXdRd0FGQTdRaGdBRGZmMk8zWW5qZzlkdVBIcytQUjg4U1U4Tmc1TUZhdXRaTm1Mc1lSU0JBd05mMWdDR3ZtZURoaFNWeVNrbnJhSTFyU0dGUWtFT0dlWEtJQWdwbVlQU3RZQnpqNEFxQjBoREFCWGVQc2R1OC8vNk9rekw1bWFpeTlxNE1GMDFJdE54QkpLa0NyQU80L0RxTU5mS0dnWVd0a1NVazk3Ukt0YndncjdJSkFoaUxGL0pUVVVrNVQwcHBzMmRIRkJBQUFiRU1JQWNJM2Z1bTNuWTROSGgvOUhNanZlQWROUkx6WWRUMnJlcEE0TUh6ODRvNlpqYlZsU0tHQm9WVXVtaGN5cWxwQkNBWVAzVTFsbEVzUXM0UU0zYmVnNnpGa0hBUFlnaEFIZ0ttOSsxWTdQUFhSNDZIMlpyNWlPT21jK21kSk0ybHVqd1BCQURqVDIvQXNIQWxyZEVsWlBXMFFyVzBJS0d0N2NEN3QvbVNDbUlrOUplZzluRkFEWWg5bVJBTGpTNTM1dzRwc0QxMis4cmVvTG1ZK21vMDZtMHhwTHBHUTVWTXQzYW5ha1NvKzEvYk1qTFN4WnlleEJYcHdkYWNubGpWci9McFZ0aWVIejJaRXFQYzhOQjhQa2F2Y3hsalkxbGZEV3lGS0dBNy9NckVsbGVjVk5HN3J1cDFZQ0FDNjVwd0dBazc1eThQbGpOMnpwZVVIRkZ6SWZUVWVkTmkyTnhoS096b1JFQ09Qa2U2VElzb1F3TlljSTVhelFQU0ZNK1d1b1Z3aVRZMG1hVDZjMWswaDdJcEFoaUxGL0pjc1U4NW1iTm5TOWtkb0lBTmlMN2tnQVhPdTVNK00zRFoyYnVPajRRMXhWeXp2ZkRjbXlMSTNIRTB4RkRjQ3hoL3IyWUZBOWJTM3Fib3NvR2c2NmVudnBtbVQvU3BZb1psVFNiM09XQUlEOUNHRUF1TmJiNzlnOTgrUnpaL2VNVHM0bVNqMUFsUGZONmg1T0t2bXBFMkhReFhoQ0tRWldBZUF3UzVrV1R4MmhrTmEzWndLWjlsRFF0ZHRxOXk4VHhCVDF6cHMyZEkxeWRnQ0EvUWhoQUxqYVcyL2Y5ZHloRTZkdW00c2xsNjl1K21nNjZzbFlRbkhYTjRFaElRTHZOajhlWjhNdzFCVUpxYmU5UmV2YUltb05CZnp6WGlDSUtXZGI3NWQwSDJjREFEajIrQUFBN25mZ08wLysxay9zdlBJdmdvRkE2WXRYeFgzK3ExbmUrWEZnWmhOSlRhWHFsOEJVUHlaTVJVZXIvTzB3N0R1V2pBbWptc2VFcVhSVUdLZkdoQ2w5M2pNbWpOM1h0V0xMRzVLU2xxV3BlRW9KMHgwSk1XUEUyTDhTUTRwTDZyOXBROWZUMUR3QXdCbTBoQUhnQ2Z0L3V2K2pEeDhlK2xRMUR5cjJWWmFkSHdjbWxrcHBPc1VvTU0yRDloM3d4cnZCa2hReURLMXVEYXUzdlVWcldzTUtCd0xlUFY2MGlDbFY1aDhUd0FDQXMyZ0pBOEJUdnZEUU13L3V1bmJEQzh1OWtqbnluK0xzbDNhM21FaW1UWTBuVWpLdCtqNktHUlV1WUZSLzFNcGJ0cWxhd3BRdWdaWXdaUzd2bzVZd0ZidzluTHUrR1pXWG5VaWJta3ltbERZYkV5UFJJc2EybFJ5V3RHdGdRMWVTMmdZQU9JZVdNQUE4NWRUbzVDMG5Sa1pIN0g1QXFiVEdhL2VEdW1sWnVwaEkxajJBQVlCYXRRUUQ2bTZOcUxlOVJTdGJ3Z3JVK1Y5OHRJaXhiZlBlUkFBREFNNGpoQUhnS1crN1k3ZDVZdmpDcnRPalU3TkxMZWVsNmFndFNlT3hoTkxrTDQxaHVYTjl2QjM4K3hid3M3WmdRRDF0TFZyZjNxSVZrVkRkbWx3VHhOUzhrZ01ERzdvZTVCME1BTTRqaEFIZ09XKzdZL2ZvajU0NTg2S0oyVmphanZJYVBSMzFSQ3l1cE5zSGcrQ0pHSzU5ZjFxOFAxM0lrTlFlQ21wOWV5YVE2UXc3SDhnUXhGUzlrak9TZm85M0xRRFVCeUVNQUUvNnJkZnNmT0xnc2VGZmpDZFRWckhLdjFOUEZYYVhQUlZQS01ZNHZPNTZwbWVINnJZKzhvem1lRjhia2pyQ21VQ21weTJpYURqb3p2MXMzaURtbm9FTlhaT2NKUUJRSDRRd0FEenI3bGZ0K01KRGg0ZisyTXI3VDdpWHBxT2VTeVkxU3g4a0FJMTRXbS9RK2dLR29SWGhrRFprQTVuMlVNQmR1OUI4UWN6WEJ6WjBmWkVURFFEcWg5bVJBSGplMy8vbjhYL2V0MjNUejFSNlVYTnl0cERsbGsyazBocFBwRnpSRXNDb2NDR25aa2RhdEx4aDAzYVhPemRORFRNazFUNERsR0Z2MlRidlg4V3pJMVc0QWx2MjBURHNlKytWczJ6RisyZlV0aDJHemVkWEdXOFF4MmFYVXZFWm9GS21wYWxrU3JHVWZVMERtVFZwMlpYTVN0bzJzS0ZyaUpvRUFMaXM3ZzBBYnZmbHdlZWUzSEhWK2h2c3VmZzVPeDExMmpRMUdrdktMYjJRQ0dGRUNMTk15WVF3eTY2dTFuZmcwdHZoZUFoeitVbGU3eEFtWHlKdGFpcVJWc0tzL1NwSkVMUGtTdDQrc0tIckk5UWdBTUNGZFc4QWNMdVBmUDFRcFAvS250Tlg5cTVlMDhpSGtlWEt0aXhMby9NSnBieDJJeUNFc1RkRWFIQUlVMmtzUUFpejdPcHNPNEtFTUl2RnM0Rk1zb1pBaGlEbThpL1Nsbjc4aitlbWI1OUxXeW5wMHY4RTBzcDBZTElLdnFmczE4VytaMGt5RHd6ME1ib1pBRFQ0ZWc4QWRmZlJiejYrY2VENmpVK3RXeGx0c2V0QnhPNEg4ckg1dUJJdUd3YUdFRWFFTUxaRkNJUXd0UjVCUXBoU1B6STBuMHByTXBsUzJxejhJa29RcytpTDlJbTU1TTk5LytMOFlRZFdkU21ZeWZ2YzB1S0FwekRzTVpmN25KQUhnSitFT0FRQS9PTEo3blduOU5TcFYvMUUvNVlIb20yUlFFMFBJUTQ4akUvRUVxNExZSlN0NFpMSWM2dzUxbkM3dGxCUWJhR2dMRm1hUzVtYVRpUlY3dGptTmIwZlN2eHk2VEtyWDV0VDc5djhjbWRUMW1jZENtQ2toVWsvYkowQ2EvL2dTRzQzOGdPYXdwZFZ5ZmNKZGdBMEN2VVRBSFczZjNERXlGYlVjcS9sdmk3bmU1ZXVaOXVtcG43aDF1MmIvemdVREZSNDBYT3VHOUpNUEtucHRIdnJlNVcwRlBGV1M1ak1rbTVwQ1hOcGVWckMyTHVQSlpxbU9OYWlpWll3OW01SG1TMWhpakV0UzNPcHRLYktIT2k4MlZ2RVdOTHBiNDNPM25ZMmtaNm5OcEk3SkNWRG5jSlh1dFRQQ0hRQXVPRWFEOERmb1VsaEVCSXNFWTRFU3dRb2pydHBidWJkTCsvZmZGYzlIa0NXSzNzK21kSkVNdTN0bTRISFE1aEtRd3BDbUdvakJFS1lXbytnRjBPWW1vOTFEU0ZNdnJSbGFTNloxblJ5NlVDbW1ZT1kwL0hVbTc0OU52YzlhamFPV0Rhc0tmalpvczhKY29EbVFRZ0RORWQ0RWl3U25nU1hDRmFLQlMyZTg1T3AyR2YzWG5mRnZrb2ZQdXg4ZUV1bU0xTlJtNWE3anhVaFRIMGUzb3VIRkc0UFlhb0lFUWhoYWp0K05ULzRWN084OTBPWS9LVlNscVdaWkZvenlaVDlGV0NQQmpGeDAvcjIzNTJkZmh1MUkxZGJNcWhaNm51RU9JQjNFTUlBN2c1UWdpVUNrM0pEbGFZK3h3T1dHWGhOV04vZHRtbmRGWlU4ZmR2MThKRTJMWTNGRTJXUFdlRHFtd0VoakwzNzZPTVFwdEtRZ2hDbWpPMHc1UHg3eEdjaFRMNmtaV2s2a2RKY0ttMWZKZGhqUVl3bFRUODBHYnYxNkd4aWxCcVdyNlYxZVZpVFh1THpYSUJqY2VnQUY5VzdBVlJuLytCSXNZQWtxT0toU2JIUE9UOXRFSTNITzErM0p2cTlqZDByb3ZWODhMQWtqYzdIbGZKSXRjYXBFS2JxaHpOQ0dIdTNneERHM3UwZ2hMRjNPeHdPWWZJbFRGTlR5WlJpS2JQMmlyQ0hncGp4WlBxUHZueGg5dlBVQ3JCRXRhVllXRlBzbFF0dTBodzJvREhYZE1EWDhscWpGSVlvcGI1SGlPSkNHMlptcjNuTmxldSt0cnF6TGJoY3NtRFhBODM0ZkVKeHl6di9XQ0tFcWMvRCs2WGxIUWhobGc0cGF2MjdFTUlVTHV4b2Q2NnFRb3BhOTdFNVFwajhoUkpwVXhPSmxKSzFESnJ1Z1NBbVpWbVAvOTNaNlY5TVc2SzFBK3hXTXFRcDlpSzRBV3E5RXdBZWttMlZFdFRsNGNseW9Rcm5pRTljTXpYMTh0ZHMyL2l4MWtqSUtQWFViZGZEekZRc29WblRXM1ZkUWhpSHdvOVN5eExDMkJzaXVENkVxVEZFSUlTUkV5Rk1ibGxMVWp4dGFqS2VWTEthYTdlN2c1alU0ZG5FNng2ZWpEMU5UUUF1a1F0bFVrVStOL08vVDJnRHYrSUJFNTVTMERLbFdJaFM2bnVBZGt4UDczL1ZqczN2Q0JpR1l3OGNzNG1rcGxMZUd4dVBFTWFoOEtQVXNvUXc5b1lJaERBMjdLTTdReGhiamwrSmhZb3RhMG1hVDZVMUdVOHBYVWxyUnBjR01UTnA4MlAvZUc3bXo2a0J3TU9XQ20zeVAwOHh0ZzE4VSs4R25GSWlVRm51eFhzV05YbGhiUGJETDkyMitUVk9QR3pFVXlsZFRLUTkyZDZiRU1haDhLUFVzb1F3OW9ZSWhEQTI3S1BiUXhnYnJ6ZGxkajgxTFV2ektWTVRpYVRLeW1OY0ZzU2tMWjM4NnVqTUhSZVRacHk3UDVwRWZrdWFKVDhTMk1EVjlXNmdYUHNIUnlvTlZBSWNOVFRDSzgza1YzWmYwN3ZWem5GZ1VtbFRZL0drdkRvL1pQVWhURVdQZHVWdkJ5R012ZHZoa3hDbWRFaEJDRlA3UGpvM1J0YXl5N28waEZuMFpHZFptazJsTlJWUExSMjB1eWlJR1lxbGZ1WGZ4dWNlNXE0UEZEK3R0VGlZeVgyZXpQOGVVMytqSWZWdU5LK0NjVlJDV2h5Z0ZINU5LeFY0UmppZGp0elJIdnFQYS92V3JMSGpBZEMwTEkzR3ZERVZkZFUzQXhlR01KVSsxaExDMUZLMjRkanNRWVF3dFlVVWhEQlZiSWRSMjNzdlpWbWFTYVkxa3lnUnlMZ2dpSW1aMXBmLy91ejA3M0hIQjJwbXFTQ1lFV0VObks1M3cxL3lXcXVFU256TS81ejNCM3hyOWR4ODl4MVhyUHh1NytyT2xsb3ZtR1B6Q1NVc2I3ZHFKWVJ4S1B3b3RXeVpUNkdFTUdVdVR3aGp3ejRTd2xSVGRzcTBOSjFJYVNhVkxtdEQ2aEhFV05MRjcxMmN2L1daK2VRRWQzdWdiZ3JEbXFRV1FwdGNVSlBpTUtHMkt6NWNJOXRpcFZTb1V2aVJ2em1RdFhsNmV1ZnQxMjM0aDg3MmxtVzd4cFU2Y1M3R0VvcVozdTlXYkZTNFFDWGp3aERDRkZtV0VNYmVmU1NFc1dFZkNXRnFMVHRwV3BwTXBEU2ZDMlFhRk1TTUp0UHYrdXFGMmE5d2x3ZGN4MUpCTUtPQ3dJYWdwam53UU81aWVlRksvaXRZOEhtWXZ5TlF2YTNUMHovejZ2NU43NHVFZ2hWZktLZmpDYzJrL1RHdUd5R01RK0ZIcVdVSlllemRSMElZRy9heCtVSVkrL2R4WVltRWFXb2lubFRjTkNzc3E3WWdKbWxaRDMzMnpQUWJ1YnNEbnBZZnp1UmVsOElhdWo0MVFiMGI5c3ZPQ2hRcTQ4WGZCNDJXRzBDNTJCaEFJUzBrK21iZXg5eVVnY25zejExdnorek11MTY1WTh2L3JPUkNPWjlNYVNLWmJwNmJRYjFEbURKLzBiWVFwb1lIczZyMzBZRnhZUWhoSENpN3hJS0VNRFllYXgrR01MblBMRWx4TTYySmVFcUpna0RHZ1NBbS9zUk0vSTZEVS9HVFZGOEFYOHZ2OHJRb29KR1VQRERRbCtZUWViemVqY3BrQTVhd0ZvY3BoVjhIT1ZLb1EzZ1N5YjczY2g4TFg1Rzg5MlpFaTF0YTVVS1ZPVW56MlZlc3lNczNGL21mU01iKytvWFg5OTFTemtVeWtVcHJQSm1TNWFQSkRXdDdjQ0dFSVlRcFVyWmgvN0ZiZWg4TjU4b3ViM1cxdmdOTGJ3Y2hUQlV4aVAzbmVqVWhUUDRYbHFUNVZGb1RpYVJTMlc2c2RnWXhVeW56ejc1NGZ1WVRWSUdBcHBjYm55Yi9sY2g5enZUY0hxbDNZOEgrd1pIQ1lDVmM4RG5UTHNQT0lLVWw3eFhKdmxwS0JDejVueTkxYnFja3plUUZMSE5hSExiTStpbGNxY1R0d2ZSMys3ZjBiRnpxQXBrMlRZM0d2RHNWdFRNUEx2NExZWng4QUcxSUNGUGovamtad3RpMmo0UXdOZTdqNVcrUXVvVXdaZStqWWQ5Mk9CSTBHV1h2bjJsWm1rdWxOWmxJeVN5WjZKZS9kV2xMVDMzcC9NeWRNMm1UOFNRQUxLZXdxOU9sRjJQU3VLamUzVXoyRDQ0VWhpcjVuOU5GQ0xYSWhTbnRSY0tWL0krNXoydHBNUlZUSm1qSmY4MW1QOFo4Y2p6elcvc1VhM1VXekR1SGd3WG5kSzVMVmE3clZFSlNLbUtheG4vcmlueDhTOC9LOW1JWFNNdXlORHFma0IvdlRvUXdoRENFTUM0T1laYjRkVUlZYjRZdytVekwwbXdxcmNsRXNrZ0x5N0syMEhwa0t2WW5oMmNTeDdJUFZ3a3RUS05iT0V0TDRSZ1RBTERvZXFMRkxXY1N1YzhKYUFoaGFnbFpBaXJlSllPUUJkVnFrOVNhZmJYbGZWMzQwWWxXVW5GSms1SW1zaDl6TDY5Y0pIT3RmVnExT0l3cTFjSW4vK3VsanFlcFRPaVVhOWtUMCtVdGZvcUdVZXRuNXpiZnZubk50OWF0aUlZS2Z6WTJIMWZDcHcwNDNSTENsQTRwQ0dFSVlRaGhDR0c4RThKVWNJb3Yrbkhhc2pTVFRHa3FrY29iVkczcFg1NU1tVi85VXFZYlVwc3kvK2pKMVVVNnNuWGI1UjYyRm5WVktQSjU3aFhQZXlXcC9nRk54eXdXemtoS01GZ3dJWXoyRDQ0RTh4N1dDaC9nR0k4RmxZcGtLektkMlkvdGtxSjVIK3ZWQlMwdWFTejdHcytHTGZNdVBGNkJ2QXBnZm1Xd1ZZdGJBTFhZY0Q3T1M3b29hVnFaVmo2NWozT3FZVkRncTZlbVgzTDd0cjVQdGJlRUwxMGpKMk1KelpuKzdVSkxDRU1JUXdqVDdDSE01U2M1SVV6OVE1aDhLZFBVVkRLdG1XU3FaQUdtZE9IKzhibFhEOGRTMHlXS2JzdldWVHF6SDdza3JjcldaMnA5R0l0cmNUZ1QwMEkzNTl3L081cTJpelBRWkZKNTRVenUycENnOVl6UFFwanNBTGlSZ3JBbFF0Q0NHclJJV3BGOXJjeFdWRHF6MzIrVU1Va2prczVsd3dhM0NHZVBVNWNXQXFwb1h0amk1UEU0cTB3SWRWRU9obEE3WnFiZmVPdjJ6YjhmREFRMEZVdG8xdlQzR0dhRU1HcTZFS2JTV0lBUVp0blYyWFlFQ1dGSy9jaXdiMXM4RU1Ma1M1aW1waE5wemFZVzV4bm5FK2w3dmpFNis2OVZYUFpEeW9ReHF5WDFaRjlPL1ZNcHFVd3drK3NXbmZ1bnlZVDgwMFVhUUhHNWJ2K0VNelhjTStzdUc3WVVqcHVSQzF1QVdxeVExQzFwYmZiVjdxS0wxVE9TVG1RckxHN1FLbWxEOW5pdFVlMy9RYXZVR1VtSHNoVzN1cmw1ZnZaOU83ZDAzeGtQQkl4bUdFYSsrdG1EQ0dFSVlZcVVTd2hUOVJFa2hDbjFJN2VITUV0c3JXSGY4WXVicGlianFmUjBLdjJEKzg1TXY4bW1XMENMcEcyU3JxdnpyU2N1YVZUU0JVbW42bjJmQjlEUTU1MzhjQ2FtSnVyVzVKb1FKcTlsUzJIZ1F0Z0NPNjJTZEZVMlVHaDM0ZmJGSlQwZ2FjcEYyM1NqcEJjMCtIcHhRdEtQcFBwT1N2U3p2VjI3T2kzckRRZW41cjhWa2lJR3JlenFlNk1wNXhlTlFMd2pFbXB4ZER2OGN2TTFhdnRsbzVtUG5SdTIyMmplNDJjNHNmVkdZNDZkbGVrcWExbVdMRXV5TEZteUxKbFczczlNeThvc0kxbG1kamxKTWkzTHRDUXJKYVduRXVuWVJDcDFZVFJobnJieFVHK1J0Sy9CZis3VGtuNmdHcm9VQS9DMHd2R240bjVzTlJOcXhFcnpXcmNVamhIQm9MaHdTalJic1Zqbjh1MGNsN3NDR0NuVHhhalI1K1oxa3Zva25WU21POUtZSE81ai90STEwU3UyZGJiK2xTR3RtUXNFbnZ1bjA1UGY0alJ5OC8wYUFId3R2NnRRN2g4U3VYOWF4cXNzMDFDbVZYQ1BNZ0hNU3BmVU9RQTByMXl2bDg2ODdDQ3RURXVaUytOUEhSam84L1RnNEk0L1dCVUVMcmxYaFBjWDZ1emxjbjhBazNOQzBoTnkxMEIyWGNxRUlEM0s5QjhQTlhoNzBzb0VWaGUwTURQVXRHejZ6OW5WMFVqSGY5K3c0dk5CdzdnMlYrRjk4T0xjLy83dWhabERuRW9BZ0RvcEZyd1VTaWpUZXFRYzdjb0VMU3VWNlZxODFnVjFjak43SDg5MVI3ckFueDFBbWM4Q3VRSEFZOG9FTTU3cHltUjdDSk9kbWFod2VsNWF1S0RSZHFuKy9aeHJFVk5tWEpobmxSbk16bTNYalU1bGdwa1Z5b3dQMDZHRmdYa2JKYVZNSzZKSlpmcVVUMmxoOEwreUE2MjJZQ0I0ejVWckRyUUVqSmNzdXRKYm12djIrYW0zSFpxTW5lUjBBZ0E0SktqTVB4U01DdTVkK2Exb0ExcVlEU2szY0g1dXdvRkdkdkdQYTJGdzN0dy9UcWF5TDJaUEFtQ0hoUEtDbVFNRGZYRzNibWpONGNqK3daR0FNc2w2N2tVckY3alZGbVhHTmxucHNlMGVVK2EvWEdlVStXK1JtL3RKQjdQWGdmd2d0clhFMS9VMHAwd2dNMXZrTlo5L1ROOXgxZHAzZDRRQ2R4VzlzcHZXbWMrZG1uamIwSHh5Z3RNSkFHQ1RnQmFDbDNMK2s5dFM1RjQ3cDB6NDBpN25aamtxSnFuRi80MmV6L3VZQzE3bXM4c0JRRDJaMmV2UG5LVDVBd045cnBtTnJhb1Fadi9nU0d2ZWhiNVZ0SFNCdDZ5VXRGRUxYV3U4OVA2Tkt4UEtqR1kvT2o0MmlvTVZ6aFl0VERHZkd4Y3FVdUtWKzVrVDNhRE03TVY1N3ZXOUsxNjByYlBsbDVkYWVEWnRIdjdreWZFL21FNlpUS3NKQUtpbERtN2szWWR5d2xvSVdmSzc4K2UzTUM4MlNIeFN0WTBwbDV1cEpKNHRhOUYwc2dXdmVONUhXckVBOEFyWGhESmxQWHhteDNWcDEwSzNBMllJZ1YrRWxla1R2VXFaUUdhVjNEbHJVaW1XTXExalJpVmR6SDd1NTZhOWhqSkJUTGpJSzVUM01WTGsrOEhzOTRQWjE2SkE1K1pWN2RmKzlMcU9YeXJudW5ocVB2bllwNGN2ZnRyS1RxZW54YU80TTZNREFLQlE3aDhLYmJwOE50Q1d2SjlWVXNlMnN2ZjdWUFoxVVpsV243a1FKWm45ZnY3SHdsZnUreVovSWdCTjV0SS9ZaVhOMW5PdzN5VWZOdllQanJRbzA0KzBVd1F2YUs2S1VwY1crbEYzWmw5UjFiZUpiN1VzWmZwYVR4Uzg1dm5UWGlZc0tmU1RhenV1ZThtYTZOOFlsaFV0OXhlZm5JcmQvODlucDc2dmhXREl5RjRuVTNtdi9IQW1vWVhRSnBiOU9RREF1NEphSEtJVXZ2TEQvOXdZTDdsS2ZtNWF0MXdBa2d0VDBubXZaUGFlbmlyeXM1UXVELzNUeWd4dVM2QUNBSlZMS0R0Y3dZR0JQa2ZINUx3c2hNbTJldWxVcHN0R0szOExZTkg1MHFxRlFXaHpyM1psL252VnJzYlBHclNVcERMaFRQN0F0Ym5CYTV1MndyWnpSZHVhMS9SMGZqRm9HQnNrU1ZaNURWa3NTVCtlaXQzN2xiTlQvN0hNZXlha1RIZ1h6SDRNWkwrWFg3R09VMmtHQUU5bzFVSUx5MEQyR3A0TFVmSS9XbG9JU2VyWlFuSkdtZGF4QUlEcXBaVUpaR2FVQ1dWc3ZZNHZDbUgyRDQ1MEtUTmxYWmpqRGxRbHJFd2dFMVhwUVduYjVLNnd4dExpMllSeU13ck5LTk42eHJmaFFIZExxT1hYTnEzK1REaGc3RnA4Uk1vT1lsTC9NVGI3Ty84NU5udUV0ejRBTkRXajRHTWo3NTFubFdseENRQ29uWm4zZkRSblJ5QmpTTkwrd1pHd3BQVnE3UFN5UURQSk5XRnUxVUsvOE56bnBRYXBiVVNYd0Z4ZnlmeHdaamJ2YTgrT1BSTTBET01kVjYvOVVGc3djUHRsUDdUS3Y3YW1MVTErNWV6a1d3OVB4OC93dGdhQXBoTW91R2U2UVZLWldSVVpvd3dBN0pWV3RqZEJMVk5nRy9zSFI5b2xiWkEzeHJvQW1sbXViM2x1UnFGeVgyRUh6Ky9jQ09PNTZaN3pQNStWaTBPYWU2NWFlOC9LY1BBdEpSZW9JSWlKbWViSnp3eFB2T05jUERYRDJ4UUFmQytnekQ4eUxibTN0ZWhGWmJvZkF3Q2NFVk5tM00zcFNsdkhHUHNIUjY0V2crNENmbGM0bzFDbzRIdVJndS9senpDVS83MUtyeFZ4TFE1bGNrRk43cFZveE1INHRjMnI3N2lpTmZ5aFpSZXNJSWlaU3BtUEhYaCs3SS9tVFN2SjJ3MEFmQ2VnVE9oaXlCdmRkQzFsV3NOd1R3SUFaNldWbmFYMndFQmZXZmNIWS8vZ3lKVmlEQmdBNVZkQzg4T2JYRmlUbS9ZNTk3MkFGb0tkZ0JhSE9Qa0RHaXBiUVp6VFFxdWF3cGV0c3dpOWZzT0tYZHM2V3orYjNiNWxxckNWdGVRK0gwOTkvUk1ueC8rU3R3a0ErSUloZDR6eFVxMllNdVBEQUFDY1p5clRNbVo4dVRERzJEODRFbEZtUEJobVFnTFFLTG1tM2JsWmhQSS96NTl0SWxsTFJmaWxhNkpYL01UYWppOGEwdXF5ZjZuQ0lPYnB1Y1FuUGpjeThXWCtwQURnU2ZrRDdPYlBjT1JWbzhxTTRRWUFxSSswcEhGbFdzWllTOTFvdEg5d0pDcXBTNWxaWFJnZkJvQ3ZYQnR0NmZ6NUsxWjhQbWdZMTFUOHl4VUdNUWNuNXYvb1crZW5IK2FvQTRBbkJQTHF4Ym5wcGYzQ2xIUktIaDVJSHdBOEtpN3AzSUdCdnN0bXF6TUt2N0YvY01SUVpwYWs5dXpIRmhIS0FQQ3d0bUFnZU05VmF6L1pFakJ1cWJxUUNvSVlVNHA5NS96TTJ4K2RtSHVXb3c4QXJ1VDFya2FWbUZHbVJRd0FvTDRzU2FNSEJ2b3VGdDZBbHBYdHNsUTRaYTZUTTY0QWdHM2VjZlc2UCtvSUJkNVEyeVcwc24rTUprMXI5QXVuSjkvMjlGemlBbjhCQUhDRlhQQmk1VldPbThVNVpjWmVBd0RVMzdTa3M3bnVTVVl0SmUwZkhNa054SmsvMjByKzRKdTV3VG9Cb0NIZXZHWE5MNjFyQ2YyaExZVlZHTVRNcGMwVGZ6MTA4VjBYaytrNS9oSUEwQkQ1d1l0WFpqWnlRa3FaYmtrV2J3a0FhSWlaQXdOOXAzTTNKa2RsdXpmbGh6SzVqNEc4ajRFaTN6UDRPd0dveGM5dVdORy9yYlAxMDZxaTFaNWxhVmJGK3RCWEdNU01KVlAvK2ZIbnh6OWU0d05FWUpsOU1MUzRhVDBBTkx0Y1hkSlM4d1l2aFNhVm1VWVZBTkFZNHdjRytrWmRXMkhQQzI4S2c1bkFNcCtYK3BsRTl5bjRTK0dzRFdhUnIwc3RtMTdpWjhVcXJFdDlYZW55aGV2WEVoWGtKUWRJWEc3Nk4xeTZudVptbkNxbVdQQ2R1LzdtUDh5RUNuNGVLQ2dqLy9kREJUL1BENUVLcjhtNTM4MS81YmVpREJiWnBtQ1I2enNBQk1xNHJ6Ujd2ZUdNcEFTSEFnQWE1bVJUL3RkMC8rQkkvZ05BNFFPQlVlSVZLSEdUTC96dmMvN0R6RkkvSzFhV2xpaFhTendBTGFkZS95RTNhL3hkcThyeWw1cENjcWx5Uy8xZXVvemx6Q0xMbURiODNwTEJDcUVEVVBLNm5ndHo4Z09jWEhBVXpydHU1Z2M5Um5hWi9JK0J2RElDZVQvTEQ0eG91UW00QjhGTFpSS1NUbk1ZQUtCaHBxZzRBZ0JRby8yREk3bWdKaGZtNUxyZkZuYTNYZXFWdjN6aDczSy9CaFlFMUp5RDY5cGxYTklVaHdFQUdpSkZwUTRBQUpmTHR2UUphR0VnL01Md3B0ajNDai9QLzBnM0xuaE5mcXZlcFZyQVlubVdwQkVWRy9jTUFGQ1hHeG9BQUdnaTJYSFhRbG9JZGNKYUhPZ1VmbDM0dmR4SDZoRndVdjdndWdRdjlwcVRkSjdEQUFCMVoxSjVBZ0FBVmNtT3NSYlc0akFubFBlOVV0L1BCVGxBSWNaNHFaL3p5b1F4QUlENm1TZUVBUUFBZFpkdGpaTWZ5a1IwZVhnVEtmZzZGK1JRZi9HWFhGY2p4bm1wcjdTa1V5THNBb0I2T2tjbEJnQUFlRXAyakp5SXBKYnN4MkRlNTduUUpwTDNOVjJuM0NsLzZuckdKMm1NS1dVRzZnVUFPQzhsNlRrcUpBQUF3UGYyRDQ3a1FwbGNNRlA0ZVM2OHlZVTUxSkdja1QvT0N5MHczT0dNcERpSEFRQWNOM0pnb0crT0NnWUFBRUNCYkd1YlZpMXVjZE9TZllVTHZrZDlhbW01S2FVRG9zV0xHeVdVQ1dMb0JnWUF6cmx3WUtEdm9xZzBBQUFBMUdiLzRFaElDNEZON2xVWTRPUStieFlNc09zdDQ4cDBUUUlBMk85U0FDTVJ3Z0FBQU5UTi9zR1JYR3VhM0tzMTcvUDgxalplWk9SOVpFcHBiN0dVR2FRM3hhRUFBTnVZa3M0ZEdPaWJMbmF6QkFBQWdBdGtaNDdLRDJyYUNqN213aHMzMU9NQ0JRL3lCQy9lTlMvcEhJY0JBR3dSbDNUbXdFQmZvdkFIaERBQUFBQWVsQjFzdUZVTHJXbmF0TkFWS2hmVUJCMVl0WkZYaHlSNDhaY0xrbVk1REFCUU5VdlNtS1NMQndiNnJGSTNVUUFBQVBoUWRyeWFkbVVDbWJic3F6WHZGU216cUZ6d1l1VlZNdUUvcHFRUk1ZNFBBRlJqV3BueFgxTEwzVkFCQUFEUWhQWVBqZ1MwRU16a1FwcVdndTlKbVc1SFBKZzNoeGxKb3h3R0FLam91amwyWUtBdlhzN0NoREFBQUFBb0tqcytUYXNXV3RPMGEzRkEwOEpSOHFXemttSWNCZ0FveVZLbTVjdkZjc09YSEVJWUFBQUFWQ1hia3FaZGkwT2FYRkRUcHNVRDk4STdrcEpPaTI1bkFGQW9KV2xTMHVSeTNZNUtJWVFCQUFDQUk3SlRjbmNvRThpMEYzd01jWVJjYlNMN0FvQm1aeW5UNVdqcXdFQmZ6WU9YRThJQUFBQ2c3dllQam9RbFJiWFFlaWEvRlUyWUkrU0toNDdUeXJTS0FZQm1OS2RNbDZQcEF3Tjl0bzJMUmdnREFBQUFWOGtHTkIzS2hETFI3S3N0KzVINmEvM0VsQmtmQmdDYWdTVnBYcG5nWmViQVFGL2FpWlZ3RXdNQUFJQm43QjhjeWJXWWlSYThJaHdkUjR4bEgwZ0F3STlTa21henJ6azdXN3lVUWdnREFBQUF6OXMvT0JKU3B2Vk03cFVMWjFvNU9qVXhKWjJTbE9aUUFQQ0ptTExCeTRHQnZyclBCRWNJQXdBQUFOL0t6dUNVQzJWeUgzTXRhYWdMbDJkRzBpaUhBWUJIeFpUcFpqUW5hYjRlclYyV3dvMEhBQUFBVFNuYnRTbS8xVXd1b0dGZzRNdWR5ejdFQUlEYnVTcDBLVVFJQXdBQUFPVFpQemdTMGVYaFRMTjNiVW9wMHkzSjRoMEN3RVhTeWdRdXNkekxiYUZMSVVJWUFBQUFvQXhGdWpibFpteHFseFJzZ2tNd0tla2k3d1FBRFdKSmlpc3ZkRGt3MEpmMDJrNFF3Z0FBQUFBMXlyYWV5Ujl2SmplTFU1djhFOUJZa3M1SVN2QVhCK0F3VTVuQUphNU00QktYbERndzBPZjUxbmlFTUFBQUFJQ0Q5ZytPdEdoeE1KUC9DbmhzZHhLU1R2TlhCV0NqdEJhQ2xyaWsrSUdCUHQrR3ZZUXdBQUFBUUlQc0h4eHBWU2FneWUvYTFDWjN0NkFabHpURlh3OUFoZExLQkxrSlpWdTJLQk80cEp2cElCRENBQUFBQUM2VTdlS1VDMlh5dzVrMlNTME5yTXRia2theUQxUUFVQ2pYbFdoUjRISmdvQy9Gb1NHRUFRQUFBRHhwLytCSWZqaVRIOUswU29vNHZQbzVTZWY1S3dCTnk1S1UxRUxRY3VuelptdlpVaWxDR0FBQUFNQm45ZytPQkxVUXpMVGtmZDZhL2JyRmh0V2NWeWFNQWVCZnlieFhMbkJKZUhGV0lyY2doQUVBQUFDYVRIYTY3Ull0QkRPNWo3bVFwbFZTYUpsaTBwSk9LZFAxQUlBM21Wb2N0T1RDbHFTa2xCOW1JM0liUWhnQUFBQUFsOWsvT0JMUzVTRk5TOEhIYVVrWE9WcUFhK1c2RGFXMEVMS2tsQTFhNkRwVWY0UXdBQUFBQUtxU2JWRVRLdklLU2dybmZjNXpCK0NNWEV1V3dwQWwxNUtGd1hCZGhvc2hBQUFBQUVkbHg2Z3BGZGJrZitUNUJGaGdLaE9vNUwrUytaOGZHT2lqTzZESGNKRURBQUFBNEFyN0IwY01MWVF5aFFGTnNPQm5RWTRZUEN5dHl3T1dSVUVMQVlzL0VjSUFBQUFBOEp4c1lKTWZ6QVMwT0tBcDlyMEFSdzRPeW0rNWt0YmlvQ1dkLzMwR3ZHMWVoREFBQUFBQW1rSTJ1Q2szck1sL01hNU44ekdWQ1V4eUg0dDl2aWhjSVZoQk9iaVFBQUFBQU1BeThnS2MvR0FtVU1iM0F0bm5McVBnYXpqSFVpWWtLZWRWTkdBaFVJRlRPUGtCQUFBQW9NNnlNMHNWQmpOTGZWVGVSNlBnODl4elhiREk5NHI5emxMUGg5VThJMXJaVjZIME1zdWFlUit0SWw4WHZzd2lYeTk2TVk0SzNPNy9BWlpVdEZrVTVMYkhBQUFBQUVsRlRrU3VRbUNDIi8+CjwvZGVmcz4KPC9zdmc+Cg=="); + +/***/ }), + +/***/ "./src/icons/search.svg": +/*!******************************!*\ + !*** ./src/icons/search.svg ***! + \******************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ReactComponent": () => (/* binding */ SvgSearch), +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__); +var _rect, _path; +function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } + +var SvgSearch = function SvgSearch(props) { + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("svg", _extends({ + width: 24, + height: 24, + fill: "#1D1D1F", + xmlns: "http://www.w3.org/2000/svg" + }, props), _rect || (_rect = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("rect", { + y: 24, + width: 24, + height: 24, + rx: 2, + transform: "rotate(-90 0 24)", + fill: "#F0F3F5" + })), _path || (_path = /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement("path", { + d: "M6 10.5c0 3 2.5 5.5 5.5 5.5 1.1 0 2.1-.3 3-.9l3 3.4 1.1-1-2.9-3.4c.9-1 1.4-2.2 1.4-3.6 0-3-2.5-5.5-5.5-5.5C8.5 5 6 7.5 6 10.5Zm9.5 0c0 2.2-1.8 4-4 4s-4-1.8-4-4 1.8-4 4-4 4 1.8 4 4Z", + fill: "#999" + }))); +}; + +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ("data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iIzFEMUQxRiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxyZWN0IHk9IjI0IiB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHJ4PSIyIiB0cmFuc2Zvcm09InJvdGF0ZSgtOTAgMCAyNCkiIGZpbGw9IiNGMEYzRjUiIC8+CiAgICA8cGF0aAogICAgICAgIGQ9Ik02IDEwLjVDNiAxMy41IDguNSAxNiAxMS41IDE2QzEyLjYgMTYgMTMuNiAxNS43IDE0LjUgMTUuMUwxNy41IDE4LjVMMTguNiAxNy41TDE1LjcgMTQuMUMxNi42IDEzLjEgMTcuMSAxMS45IDE3LjEgMTAuNUMxNy4xIDcuNSAxNC42IDUgMTEuNiA1QzguNSA1IDYgNy41IDYgMTAuNVpNMTUuNSAxMC41QzE1LjUgMTIuNyAxMy43IDE0LjUgMTEuNSAxNC41QzkuMyAxNC41IDcuNSAxMi43IDcuNSAxMC41QzcuNSA4LjMgOS4zIDYuNSAxMS41IDYuNUMxMy43IDYuNSAxNS41IDguMyAxNS41IDEwLjVaIgogICAgICAgIGZpbGw9IiM5OTk5OTkiIC8+Cjwvc3ZnPg=="); + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/index.js": +/*!****************************************************!*\ + !*** ./node_modules/algoliasearch-helper/index.js ***! + \****************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var AlgoliaSearchHelper = __webpack_require__(/*! ./src/algoliasearch.helper */ "./node_modules/algoliasearch-helper/src/algoliasearch.helper.js"); + +var SearchParameters = __webpack_require__(/*! ./src/SearchParameters */ "./node_modules/algoliasearch-helper/src/SearchParameters/index.js"); +var SearchResults = __webpack_require__(/*! ./src/SearchResults */ "./node_modules/algoliasearch-helper/src/SearchResults/index.js"); + +/** + * The algoliasearchHelper module is the function that will let its + * contains everything needed to use the Algoliasearch + * Helper. It is a also a function that instanciate the helper. + * To use the helper, you also need the Algolia JS client v3. + * @example + * //using the UMD build + * var client = algoliasearch('latency', '6be0576ff61c053d5f9a3225e2a90f76'); + * var helper = algoliasearchHelper(client, 'bestbuy', { + * facets: ['shipping'], + * disjunctiveFacets: ['category'] + * }); + * helper.on('result', function(event) { + * console.log(event.results); + * }); + * helper + * .toggleFacetRefinement('category', 'Movies & TV Shows') + * .toggleFacetRefinement('shipping', 'Free shipping') + * .search(); + * @example + * // The helper is an event emitter using the node API + * helper.on('result', updateTheResults); + * helper.once('result', updateTheResults); + * helper.removeListener('result', updateTheResults); + * helper.removeAllListeners('result'); + * @module algoliasearchHelper + * @param {AlgoliaSearch} client an AlgoliaSearch client + * @param {string} index the name of the index to query + * @param {SearchParameters|object} opts an object defining the initial config of the search. It doesn't have to be a {SearchParameters}, just an object containing the properties you need from it. + * @return {AlgoliaSearchHelper} + */ +function algoliasearchHelper(client, index, opts) { + return new AlgoliaSearchHelper(client, index, opts); +} + +/** + * The version currently used + * @member module:algoliasearchHelper.version + * @type {number} + */ +algoliasearchHelper.version = __webpack_require__(/*! ./src/version.js */ "./node_modules/algoliasearch-helper/src/version.js"); + +/** + * Constructor for the Helper. + * @member module:algoliasearchHelper.AlgoliaSearchHelper + * @type {AlgoliaSearchHelper} + */ +algoliasearchHelper.AlgoliaSearchHelper = AlgoliaSearchHelper; + +/** + * Constructor for the object containing all the parameters of the search. + * @member module:algoliasearchHelper.SearchParameters + * @type {SearchParameters} + */ +algoliasearchHelper.SearchParameters = SearchParameters; + +/** + * Constructor for the object containing the results of the search. + * @member module:algoliasearchHelper.SearchResults + * @type {SearchResults} + */ +algoliasearchHelper.SearchResults = SearchResults; + +module.exports = algoliasearchHelper; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/DerivedHelper/index.js": +/*!**********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/DerivedHelper/index.js ***! + \**********************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var EventEmitter = __webpack_require__(/*! @algolia/events */ "./node_modules/@algolia/events/events.js"); +var inherits = __webpack_require__(/*! ../functions/inherits */ "./node_modules/algoliasearch-helper/src/functions/inherits.js"); + +/** + * A DerivedHelper is a way to create sub requests to + * Algolia from a main helper. + * @class + * @classdesc The DerivedHelper provides an event based interface for search callbacks: + * - search: when a search is triggered using the `search()` method. + * - result: when the response is retrieved from Algolia and is processed. + * This event contains a {@link SearchResults} object and the + * {@link SearchParameters} corresponding to this answer. + */ +function DerivedHelper(mainHelper, fn) { + this.main = mainHelper; + this.fn = fn; + this.lastResults = null; +} + +inherits(DerivedHelper, EventEmitter); + +/** + * Detach this helper from the main helper + * @return {undefined} + * @throws Error if the derived helper is already detached + */ +DerivedHelper.prototype.detach = function() { + this.removeAllListeners(); + this.main.detachDerivedHelper(this); +}; + +DerivedHelper.prototype.getModifiedState = function(parameters) { + return this.fn(parameters); +}; + +module.exports = DerivedHelper; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/SearchParameters/RefinementList.js": +/*!**********************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/SearchParameters/RefinementList.js ***! + \**********************************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +/** + * Functions to manipulate refinement lists + * + * The RefinementList is not formally defined through a prototype but is based + * on a specific structure. + * + * @module SearchParameters.refinementList + * + * @typedef {string[]} SearchParameters.refinementList.Refinements + * @typedef {Object.} SearchParameters.refinementList.RefinementList + */ + +var defaultsPure = __webpack_require__(/*! ../functions/defaultsPure */ "./node_modules/algoliasearch-helper/src/functions/defaultsPure.js"); +var omit = __webpack_require__(/*! ../functions/omit */ "./node_modules/algoliasearch-helper/src/functions/omit.js"); +var objectHasKeys = __webpack_require__(/*! ../functions/objectHasKeys */ "./node_modules/algoliasearch-helper/src/functions/objectHasKeys.js"); + +var lib = { + /** + * Adds a refinement to a RefinementList + * @param {RefinementList} refinementList the initial list + * @param {string} attribute the attribute to refine + * @param {string} value the value of the refinement, if the value is not a string it will be converted + * @return {RefinementList} a new and updated refinement list + */ + addRefinement: function addRefinement(refinementList, attribute, value) { + if (lib.isRefined(refinementList, attribute, value)) { + return refinementList; + } + + var valueAsString = '' + value; + + var facetRefinement = !refinementList[attribute] ? + [valueAsString] : + refinementList[attribute].concat(valueAsString); + + var mod = {}; + + mod[attribute] = facetRefinement; + + return defaultsPure({}, mod, refinementList); + }, + /** + * Removes refinement(s) for an attribute: + * - if the value is specified removes the refinement for the value on the attribute + * - if no value is specified removes all the refinements for this attribute + * @param {RefinementList} refinementList the initial list + * @param {string} attribute the attribute to refine + * @param {string} [value] the value of the refinement + * @return {RefinementList} a new and updated refinement lst + */ + removeRefinement: function removeRefinement(refinementList, attribute, value) { + if (value === undefined) { + // we use the "filter" form of clearRefinement, since it leaves empty values as-is + // the form with a string will remove the attribute completely + return lib.clearRefinement(refinementList, function(v, f) { + return attribute === f; + }); + } + + var valueAsString = '' + value; + + return lib.clearRefinement(refinementList, function(v, f) { + return attribute === f && valueAsString === v; + }); + }, + /** + * Toggles the refinement value for an attribute. + * @param {RefinementList} refinementList the initial list + * @param {string} attribute the attribute to refine + * @param {string} value the value of the refinement + * @return {RefinementList} a new and updated list + */ + toggleRefinement: function toggleRefinement(refinementList, attribute, value) { + if (value === undefined) throw new Error('toggleRefinement should be used with a value'); + + if (lib.isRefined(refinementList, attribute, value)) { + return lib.removeRefinement(refinementList, attribute, value); + } + + return lib.addRefinement(refinementList, attribute, value); + }, + /** + * Clear all or parts of a RefinementList. Depending on the arguments, three + * kinds of behavior can happen: + * - if no attribute is provided: clears the whole list + * - if an attribute is provided as a string: clears the list for the specific attribute + * - if an attribute is provided as a function: discards the elements for which the function returns true + * @param {RefinementList} refinementList the initial list + * @param {string} [attribute] the attribute or function to discard + * @param {string} [refinementType] optional parameter to give more context to the attribute function + * @return {RefinementList} a new and updated refinement list + */ + clearRefinement: function clearRefinement(refinementList, attribute, refinementType) { + if (attribute === undefined) { + if (!objectHasKeys(refinementList)) { + return refinementList; + } + return {}; + } else if (typeof attribute === 'string') { + return omit(refinementList, [attribute]); + } else if (typeof attribute === 'function') { + var hasChanged = false; + + var newRefinementList = Object.keys(refinementList).reduce(function(memo, key) { + var values = refinementList[key] || []; + var facetList = values.filter(function(value) { + return !attribute(value, key, refinementType); + }); + + if (facetList.length !== values.length) { + hasChanged = true; + } + memo[key] = facetList; + + return memo; + }, {}); + + if (hasChanged) return newRefinementList; + return refinementList; + } + }, + /** + * Test if the refinement value is used for the attribute. If no refinement value + * is provided, test if the refinementList contains any refinement for the + * given attribute. + * @param {RefinementList} refinementList the list of refinement + * @param {string} attribute name of the attribute + * @param {string} [refinementValue] value of the filter/refinement + * @return {boolean} + */ + isRefined: function isRefined(refinementList, attribute, refinementValue) { + var containsRefinements = !!refinementList[attribute] && + refinementList[attribute].length > 0; + + if (refinementValue === undefined || !containsRefinements) { + return containsRefinements; + } + + var refinementValueAsString = '' + refinementValue; + + return refinementList[attribute].indexOf(refinementValueAsString) !== -1; + } +}; + +module.exports = lib; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/SearchParameters/index.js": +/*!*************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/SearchParameters/index.js ***! + \*************************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var merge = __webpack_require__(/*! ../functions/merge */ "./node_modules/algoliasearch-helper/src/functions/merge.js"); +var defaultsPure = __webpack_require__(/*! ../functions/defaultsPure */ "./node_modules/algoliasearch-helper/src/functions/defaultsPure.js"); +var intersection = __webpack_require__(/*! ../functions/intersection */ "./node_modules/algoliasearch-helper/src/functions/intersection.js"); +var find = __webpack_require__(/*! ../functions/find */ "./node_modules/algoliasearch-helper/src/functions/find.js"); +var valToNumber = __webpack_require__(/*! ../functions/valToNumber */ "./node_modules/algoliasearch-helper/src/functions/valToNumber.js"); +var omit = __webpack_require__(/*! ../functions/omit */ "./node_modules/algoliasearch-helper/src/functions/omit.js"); +var objectHasKeys = __webpack_require__(/*! ../functions/objectHasKeys */ "./node_modules/algoliasearch-helper/src/functions/objectHasKeys.js"); +var isValidUserToken = __webpack_require__(/*! ../utils/isValidUserToken */ "./node_modules/algoliasearch-helper/src/utils/isValidUserToken.js"); + +var RefinementList = __webpack_require__(/*! ./RefinementList */ "./node_modules/algoliasearch-helper/src/SearchParameters/RefinementList.js"); + +/** + * isEqual, but only for numeric refinement values, possible values: + * - 5 + * - [5] + * - [[5]] + * - [[5,5],[4]] + */ +function isEqualNumericRefinement(a, b) { + if (Array.isArray(a) && Array.isArray(b)) { + return ( + a.length === b.length && + a.every(function(el, i) { + return isEqualNumericRefinement(b[i], el); + }) + ); + } + return a === b; +} + +/** + * like _.find but using deep equality to be able to use it + * to find arrays. + * @private + * @param {any[]} array array to search into (elements are base or array of base) + * @param {any} searchedValue the value we're looking for (base or array of base) + * @return {any} the searched value or undefined + */ +function findArray(array, searchedValue) { + return find(array, function(currentValue) { + return isEqualNumericRefinement(currentValue, searchedValue); + }); +} + +/** + * The facet list is the structure used to store the list of values used to + * filter a single attribute. + * @typedef {string[]} SearchParameters.FacetList + */ + +/** + * Structure to store numeric filters with the operator as the key. The supported operators + * are `=`, `>`, `<`, `>=`, `<=` and `!=`. + * @typedef {Object.>} SearchParameters.OperatorList + */ + +/** + * SearchParameters is the data structure that contains all the information + * usable for making a search to Algolia API. It doesn't do the search itself, + * nor does it contains logic about the parameters. + * It is an immutable object, therefore it has been created in a way that each + * changes does not change the object itself but returns a copy with the + * modification. + * This object should probably not be instantiated outside of the helper. It will + * be provided when needed. This object is documented for reference as you'll + * get it from events generated by the {@link AlgoliaSearchHelper}. + * If need be, instantiate the Helper from the factory function {@link SearchParameters.make} + * @constructor + * @classdesc contains all the parameters of a search + * @param {object|SearchParameters} newParameters existing parameters or partial object + * for the properties of a new SearchParameters + * @see SearchParameters.make + * @example SearchParameters of the first query in + * the instant search demo +{ + "query": "", + "disjunctiveFacets": [ + "customerReviewCount", + "category", + "salePrice_range", + "manufacturer" + ], + "maxValuesPerFacet": 30, + "page": 0, + "hitsPerPage": 10, + "facets": [ + "type", + "shipping" + ] +} + */ +function SearchParameters(newParameters) { + var params = newParameters ? SearchParameters._parseNumbers(newParameters) : {}; + + if (params.userToken !== undefined && !isValidUserToken(params.userToken)) { + console.warn('[algoliasearch-helper] The `userToken` parameter is invalid. This can lead to wrong analytics.\n - Format: [a-zA-Z0-9_-]{1,64}'); + } + /** + * This attribute contains the list of all the conjunctive facets + * used. This list will be added to requested facets in the + * [facets attribute](https://www.algolia.com/doc/rest-api/search#param-facets) sent to algolia. + * @member {string[]} + */ + this.facets = params.facets || []; + /** + * This attribute contains the list of all the disjunctive facets + * used. This list will be added to requested facets in the + * [facets attribute](https://www.algolia.com/doc/rest-api/search#param-facets) sent to algolia. + * @member {string[]} + */ + this.disjunctiveFacets = params.disjunctiveFacets || []; + /** + * This attribute contains the list of all the hierarchical facets + * used. This list will be added to requested facets in the + * [facets attribute](https://www.algolia.com/doc/rest-api/search#param-facets) sent to algolia. + * Hierarchical facets are a sub type of disjunctive facets that + * let you filter faceted attributes hierarchically. + * @member {string[]|object[]} + */ + this.hierarchicalFacets = params.hierarchicalFacets || []; + + // Refinements + /** + * This attribute contains all the filters that need to be + * applied on the conjunctive facets. Each facet must be properly + * defined in the `facets` attribute. + * + * The key is the name of the facet, and the `FacetList` contains all + * filters selected for the associated facet name. + * + * When querying algolia, the values stored in this attribute will + * be translated into the `facetFilters` attribute. + * @member {Object.} + */ + this.facetsRefinements = params.facetsRefinements || {}; + /** + * This attribute contains all the filters that need to be + * excluded from the conjunctive facets. Each facet must be properly + * defined in the `facets` attribute. + * + * The key is the name of the facet, and the `FacetList` contains all + * filters excluded for the associated facet name. + * + * When querying algolia, the values stored in this attribute will + * be translated into the `facetFilters` attribute. + * @member {Object.} + */ + this.facetsExcludes = params.facetsExcludes || {}; + /** + * This attribute contains all the filters that need to be + * applied on the disjunctive facets. Each facet must be properly + * defined in the `disjunctiveFacets` attribute. + * + * The key is the name of the facet, and the `FacetList` contains all + * filters selected for the associated facet name. + * + * When querying algolia, the values stored in this attribute will + * be translated into the `facetFilters` attribute. + * @member {Object.} + */ + this.disjunctiveFacetsRefinements = params.disjunctiveFacetsRefinements || {}; + /** + * This attribute contains all the filters that need to be + * applied on the numeric attributes. + * + * The key is the name of the attribute, and the value is the + * filters to apply to this attribute. + * + * When querying algolia, the values stored in this attribute will + * be translated into the `numericFilters` attribute. + * @member {Object.} + */ + this.numericRefinements = params.numericRefinements || {}; + /** + * This attribute contains all the tags used to refine the query. + * + * When querying algolia, the values stored in this attribute will + * be translated into the `tagFilters` attribute. + * @member {string[]} + */ + this.tagRefinements = params.tagRefinements || []; + /** + * This attribute contains all the filters that need to be + * applied on the hierarchical facets. Each facet must be properly + * defined in the `hierarchicalFacets` attribute. + * + * The key is the name of the facet, and the `FacetList` contains all + * filters selected for the associated facet name. The FacetList values + * are structured as a string that contain the values for each level + * separated by the configured separator. + * + * When querying algolia, the values stored in this attribute will + * be translated into the `facetFilters` attribute. + * @member {Object.} + */ + this.hierarchicalFacetsRefinements = params.hierarchicalFacetsRefinements || {}; + + var self = this; + Object.keys(params).forEach(function(paramName) { + var isKeyKnown = SearchParameters.PARAMETERS.indexOf(paramName) !== -1; + var isValueDefined = params[paramName] !== undefined; + + if (!isKeyKnown && isValueDefined) { + self[paramName] = params[paramName]; + } + }); +} + +/** + * List all the properties in SearchParameters and therefore all the known Algolia properties + * This doesn't contain any beta/hidden features. + * @private + */ +SearchParameters.PARAMETERS = Object.keys(new SearchParameters()); + +/** + * @private + * @param {object} partialState full or part of a state + * @return {object} a new object with the number keys as number + */ +SearchParameters._parseNumbers = function(partialState) { + // Do not reparse numbers in SearchParameters, they ought to be parsed already + if (partialState instanceof SearchParameters) return partialState; + + var numbers = {}; + + var numberKeys = [ + 'aroundPrecision', + 'aroundRadius', + 'getRankingInfo', + 'minWordSizefor2Typos', + 'minWordSizefor1Typo', + 'page', + 'maxValuesPerFacet', + 'distinct', + 'minimumAroundRadius', + 'hitsPerPage', + 'minProximity' + ]; + + numberKeys.forEach(function(k) { + var value = partialState[k]; + if (typeof value === 'string') { + var parsedValue = parseFloat(value); + // global isNaN is ok to use here, value is only number or NaN + numbers[k] = isNaN(parsedValue) ? value : parsedValue; + } + }); + + // there's two formats of insideBoundingBox, we need to parse + // the one which is an array of float geo rectangles + if (Array.isArray(partialState.insideBoundingBox)) { + numbers.insideBoundingBox = partialState.insideBoundingBox.map(function(geoRect) { + if (Array.isArray(geoRect)) { + return geoRect.map(function(value) { + return parseFloat(value); + }); + } + return geoRect; + }); + } + + if (partialState.numericRefinements) { + var numericRefinements = {}; + Object.keys(partialState.numericRefinements).forEach(function(attribute) { + var operators = partialState.numericRefinements[attribute] || {}; + numericRefinements[attribute] = {}; + Object.keys(operators).forEach(function(operator) { + var values = operators[operator]; + var parsedValues = values.map(function(v) { + if (Array.isArray(v)) { + return v.map(function(vPrime) { + if (typeof vPrime === 'string') { + return parseFloat(vPrime); + } + return vPrime; + }); + } else if (typeof v === 'string') { + return parseFloat(v); + } + return v; + }); + numericRefinements[attribute][operator] = parsedValues; + }); + }); + numbers.numericRefinements = numericRefinements; + } + + return merge({}, partialState, numbers); +}; + +/** + * Factory for SearchParameters + * @param {object|SearchParameters} newParameters existing parameters or partial + * object for the properties of a new SearchParameters + * @return {SearchParameters} frozen instance of SearchParameters + */ +SearchParameters.make = function makeSearchParameters(newParameters) { + var instance = new SearchParameters(newParameters); + + var hierarchicalFacets = newParameters.hierarchicalFacets || []; + hierarchicalFacets.forEach(function(facet) { + if (facet.rootPath) { + var currentRefinement = instance.getHierarchicalRefinement(facet.name); + + if (currentRefinement.length > 0 && currentRefinement[0].indexOf(facet.rootPath) !== 0) { + instance = instance.clearRefinements(facet.name); + } + + // get it again in case it has been cleared + currentRefinement = instance.getHierarchicalRefinement(facet.name); + if (currentRefinement.length === 0) { + instance = instance.toggleHierarchicalFacetRefinement(facet.name, facet.rootPath); + } + } + }); + + return instance; +}; + +/** + * Validates the new parameters based on the previous state + * @param {SearchParameters} currentState the current state + * @param {object|SearchParameters} parameters the new parameters to set + * @return {Error|null} Error if the modification is invalid, null otherwise + */ +SearchParameters.validate = function(currentState, parameters) { + var params = parameters || {}; + + if (currentState.tagFilters && params.tagRefinements && params.tagRefinements.length > 0) { + return new Error( + '[Tags] Cannot switch from the managed tag API to the advanced API. It is probably ' + + 'an error, if it is really what you want, you should first clear the tags with clearTags method.'); + } + + if (currentState.tagRefinements.length > 0 && params.tagFilters) { + return new Error( + '[Tags] Cannot switch from the advanced tag API to the managed API. It is probably ' + + 'an error, if it is not, you should first clear the tags with clearTags method.'); + } + + if ( + currentState.numericFilters && + params.numericRefinements && + objectHasKeys(params.numericRefinements) + ) { + return new Error( + "[Numeric filters] Can't switch from the advanced to the managed API. It" + + ' is probably an error, if this is really what you want, you have to first' + + ' clear the numeric filters.' + ); + } + + if (objectHasKeys(currentState.numericRefinements) && params.numericFilters) { + return new Error( + "[Numeric filters] Can't switch from the managed API to the advanced. It" + + ' is probably an error, if this is really what you want, you have to first' + + ' clear the numeric filters.'); + } + + return null; +}; + +SearchParameters.prototype = { + constructor: SearchParameters, + + /** + * Remove all refinements (disjunctive + conjunctive + excludes + numeric filters) + * @method + * @param {undefined|string|SearchParameters.clearCallback} [attribute] optional string or function + * - If not given, means to clear all the filters. + * - If `string`, means to clear all refinements for the `attribute` named filter. + * - If `function`, means to clear all the refinements that return truthy values. + * @return {SearchParameters} + */ + clearRefinements: function clearRefinements(attribute) { + var patch = { + numericRefinements: this._clearNumericRefinements(attribute), + facetsRefinements: RefinementList.clearRefinement( + this.facetsRefinements, + attribute, + 'conjunctiveFacet' + ), + facetsExcludes: RefinementList.clearRefinement( + this.facetsExcludes, + attribute, + 'exclude' + ), + disjunctiveFacetsRefinements: RefinementList.clearRefinement( + this.disjunctiveFacetsRefinements, + attribute, + 'disjunctiveFacet' + ), + hierarchicalFacetsRefinements: RefinementList.clearRefinement( + this.hierarchicalFacetsRefinements, + attribute, + 'hierarchicalFacet' + ) + }; + if ( + patch.numericRefinements === this.numericRefinements && + patch.facetsRefinements === this.facetsRefinements && + patch.facetsExcludes === this.facetsExcludes && + patch.disjunctiveFacetsRefinements === this.disjunctiveFacetsRefinements && + patch.hierarchicalFacetsRefinements === this.hierarchicalFacetsRefinements + ) { + return this; + } + return this.setQueryParameters(patch); + }, + /** + * Remove all the refined tags from the SearchParameters + * @method + * @return {SearchParameters} + */ + clearTags: function clearTags() { + if (this.tagFilters === undefined && this.tagRefinements.length === 0) return this; + + return this.setQueryParameters({ + tagFilters: undefined, + tagRefinements: [] + }); + }, + /** + * Set the index. + * @method + * @param {string} index the index name + * @return {SearchParameters} + */ + setIndex: function setIndex(index) { + if (index === this.index) return this; + + return this.setQueryParameters({ + index: index + }); + }, + /** + * Query setter + * @method + * @param {string} newQuery value for the new query + * @return {SearchParameters} + */ + setQuery: function setQuery(newQuery) { + if (newQuery === this.query) return this; + + return this.setQueryParameters({ + query: newQuery + }); + }, + /** + * Page setter + * @method + * @param {number} newPage new page number + * @return {SearchParameters} + */ + setPage: function setPage(newPage) { + if (newPage === this.page) return this; + + return this.setQueryParameters({ + page: newPage + }); + }, + /** + * Facets setter + * The facets are the simple facets, used for conjunctive (and) faceting. + * @method + * @param {string[]} facets all the attributes of the algolia records used for conjunctive faceting + * @return {SearchParameters} + */ + setFacets: function setFacets(facets) { + return this.setQueryParameters({ + facets: facets + }); + }, + /** + * Disjunctive facets setter + * Change the list of disjunctive (or) facets the helper chan handle. + * @method + * @param {string[]} facets all the attributes of the algolia records used for disjunctive faceting + * @return {SearchParameters} + */ + setDisjunctiveFacets: function setDisjunctiveFacets(facets) { + return this.setQueryParameters({ + disjunctiveFacets: facets + }); + }, + /** + * HitsPerPage setter + * Hits per page represents the number of hits retrieved for this query + * @method + * @param {number} n number of hits retrieved per page of results + * @return {SearchParameters} + */ + setHitsPerPage: function setHitsPerPage(n) { + if (this.hitsPerPage === n) return this; + + return this.setQueryParameters({ + hitsPerPage: n + }); + }, + /** + * typoTolerance setter + * Set the value of typoTolerance + * @method + * @param {string} typoTolerance new value of typoTolerance ("true", "false", "min" or "strict") + * @return {SearchParameters} + */ + setTypoTolerance: function setTypoTolerance(typoTolerance) { + if (this.typoTolerance === typoTolerance) return this; + + return this.setQueryParameters({ + typoTolerance: typoTolerance + }); + }, + /** + * Add a numeric filter for a given attribute + * When value is an array, they are combined with OR + * When value is a single value, it will combined with AND + * @method + * @param {string} attribute attribute to set the filter on + * @param {string} operator operator of the filter (possible values: =, >, >=, <, <=, !=) + * @param {number | number[]} value value of the filter + * @return {SearchParameters} + * @example + * // for price = 50 or 40 + * searchparameter.addNumericRefinement('price', '=', [50, 40]); + * @example + * // for size = 38 and 40 + * searchparameter.addNumericRefinement('size', '=', 38); + * searchparameter.addNumericRefinement('size', '=', 40); + */ + addNumericRefinement: function(attribute, operator, v) { + var value = valToNumber(v); + + if (this.isNumericRefined(attribute, operator, value)) return this; + + var mod = merge({}, this.numericRefinements); + + mod[attribute] = merge({}, mod[attribute]); + + if (mod[attribute][operator]) { + // Array copy + mod[attribute][operator] = mod[attribute][operator].slice(); + // Add the element. Concat can't be used here because value can be an array. + mod[attribute][operator].push(value); + } else { + mod[attribute][operator] = [value]; + } + + return this.setQueryParameters({ + numericRefinements: mod + }); + }, + /** + * Get the list of conjunctive refinements for a single facet + * @param {string} facetName name of the attribute used for faceting + * @return {string[]} list of refinements + */ + getConjunctiveRefinements: function(facetName) { + if (!this.isConjunctiveFacet(facetName)) { + return []; + } + return this.facetsRefinements[facetName] || []; + }, + /** + * Get the list of disjunctive refinements for a single facet + * @param {string} facetName name of the attribute used for faceting + * @return {string[]} list of refinements + */ + getDisjunctiveRefinements: function(facetName) { + if (!this.isDisjunctiveFacet(facetName)) { + return []; + } + return this.disjunctiveFacetsRefinements[facetName] || []; + }, + /** + * Get the list of hierarchical refinements for a single facet + * @param {string} facetName name of the attribute used for faceting + * @return {string[]} list of refinements + */ + getHierarchicalRefinement: function(facetName) { + // we send an array but we currently do not support multiple + // hierarchicalRefinements for a hierarchicalFacet + return this.hierarchicalFacetsRefinements[facetName] || []; + }, + /** + * Get the list of exclude refinements for a single facet + * @param {string} facetName name of the attribute used for faceting + * @return {string[]} list of refinements + */ + getExcludeRefinements: function(facetName) { + if (!this.isConjunctiveFacet(facetName)) { + return []; + } + return this.facetsExcludes[facetName] || []; + }, + + /** + * Remove all the numeric filter for a given (attribute, operator) + * @method + * @param {string} attribute attribute to set the filter on + * @param {string} [operator] operator of the filter (possible values: =, >, >=, <, <=, !=) + * @param {number} [number] the value to be removed + * @return {SearchParameters} + */ + removeNumericRefinement: function(attribute, operator, paramValue) { + if (paramValue !== undefined) { + if (!this.isNumericRefined(attribute, operator, paramValue)) { + return this; + } + return this.setQueryParameters({ + numericRefinements: this._clearNumericRefinements(function(value, key) { + return ( + key === attribute && + value.op === operator && + isEqualNumericRefinement(value.val, valToNumber(paramValue)) + ); + }) + }); + } else if (operator !== undefined) { + if (!this.isNumericRefined(attribute, operator)) return this; + return this.setQueryParameters({ + numericRefinements: this._clearNumericRefinements(function(value, key) { + return key === attribute && value.op === operator; + }) + }); + } + + if (!this.isNumericRefined(attribute)) return this; + return this.setQueryParameters({ + numericRefinements: this._clearNumericRefinements(function(value, key) { + return key === attribute; + }) + }); + }, + /** + * Get the list of numeric refinements for a single facet + * @param {string} facetName name of the attribute used for faceting + * @return {SearchParameters.OperatorList} list of refinements + */ + getNumericRefinements: function(facetName) { + return this.numericRefinements[facetName] || {}; + }, + /** + * Return the current refinement for the (attribute, operator) + * @param {string} attribute attribute in the record + * @param {string} operator operator applied on the refined values + * @return {Array.} refined values + */ + getNumericRefinement: function(attribute, operator) { + return this.numericRefinements[attribute] && this.numericRefinements[attribute][operator]; + }, + /** + * Clear numeric filters. + * @method + * @private + * @param {string|SearchParameters.clearCallback} [attribute] optional string or function + * - If not given, means to clear all the filters. + * - If `string`, means to clear all refinements for the `attribute` named filter. + * - If `function`, means to clear all the refinements that return truthy values. + * @return {Object.} + */ + _clearNumericRefinements: function _clearNumericRefinements(attribute) { + if (attribute === undefined) { + if (!objectHasKeys(this.numericRefinements)) { + return this.numericRefinements; + } + return {}; + } else if (typeof attribute === 'string') { + return omit(this.numericRefinements, [attribute]); + } else if (typeof attribute === 'function') { + var hasChanged = false; + var numericRefinements = this.numericRefinements; + var newNumericRefinements = Object.keys(numericRefinements).reduce(function(memo, key) { + var operators = numericRefinements[key]; + var operatorList = {}; + + operators = operators || {}; + Object.keys(operators).forEach(function(operator) { + var values = operators[operator] || []; + var outValues = []; + values.forEach(function(value) { + var predicateResult = attribute({val: value, op: operator}, key, 'numeric'); + if (!predicateResult) outValues.push(value); + }); + if (outValues.length !== values.length) { + hasChanged = true; + } + operatorList[operator] = outValues; + }); + + memo[key] = operatorList; + + return memo; + }, {}); + + if (hasChanged) return newNumericRefinements; + return this.numericRefinements; + } + }, + /** + * Add a facet to the facets attribute of the helper configuration, if it + * isn't already present. + * @method + * @param {string} facet facet name to add + * @return {SearchParameters} + */ + addFacet: function addFacet(facet) { + if (this.isConjunctiveFacet(facet)) { + return this; + } + + return this.setQueryParameters({ + facets: this.facets.concat([facet]) + }); + }, + /** + * Add a disjunctive facet to the disjunctiveFacets attribute of the helper + * configuration, if it isn't already present. + * @method + * @param {string} facet disjunctive facet name to add + * @return {SearchParameters} + */ + addDisjunctiveFacet: function addDisjunctiveFacet(facet) { + if (this.isDisjunctiveFacet(facet)) { + return this; + } + + return this.setQueryParameters({ + disjunctiveFacets: this.disjunctiveFacets.concat([facet]) + }); + }, + /** + * Add a hierarchical facet to the hierarchicalFacets attribute of the helper + * configuration. + * @method + * @param {object} hierarchicalFacet hierarchical facet to add + * @return {SearchParameters} + * @throws will throw an error if a hierarchical facet with the same name was already declared + */ + addHierarchicalFacet: function addHierarchicalFacet(hierarchicalFacet) { + if (this.isHierarchicalFacet(hierarchicalFacet.name)) { + throw new Error( + 'Cannot declare two hierarchical facets with the same name: `' + hierarchicalFacet.name + '`'); + } + + return this.setQueryParameters({ + hierarchicalFacets: this.hierarchicalFacets.concat([hierarchicalFacet]) + }); + }, + /** + * Add a refinement on a "normal" facet + * @method + * @param {string} facet attribute to apply the faceting on + * @param {string} value value of the attribute (will be converted to string) + * @return {SearchParameters} + */ + addFacetRefinement: function addFacetRefinement(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + throw new Error(facet + ' is not defined in the facets attribute of the helper configuration'); + } + if (RefinementList.isRefined(this.facetsRefinements, facet, value)) return this; + + return this.setQueryParameters({ + facetsRefinements: RefinementList.addRefinement(this.facetsRefinements, facet, value) + }); + }, + /** + * Exclude a value from a "normal" facet + * @method + * @param {string} facet attribute to apply the exclusion on + * @param {string} value value of the attribute (will be converted to string) + * @return {SearchParameters} + */ + addExcludeRefinement: function addExcludeRefinement(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + throw new Error(facet + ' is not defined in the facets attribute of the helper configuration'); + } + if (RefinementList.isRefined(this.facetsExcludes, facet, value)) return this; + + return this.setQueryParameters({ + facetsExcludes: RefinementList.addRefinement(this.facetsExcludes, facet, value) + }); + }, + /** + * Adds a refinement on a disjunctive facet. + * @method + * @param {string} facet attribute to apply the faceting on + * @param {string} value value of the attribute (will be converted to string) + * @return {SearchParameters} + */ + addDisjunctiveFacetRefinement: function addDisjunctiveFacetRefinement(facet, value) { + if (!this.isDisjunctiveFacet(facet)) { + throw new Error( + facet + ' is not defined in the disjunctiveFacets attribute of the helper configuration'); + } + + if (RefinementList.isRefined(this.disjunctiveFacetsRefinements, facet, value)) return this; + + return this.setQueryParameters({ + disjunctiveFacetsRefinements: RefinementList.addRefinement( + this.disjunctiveFacetsRefinements, facet, value) + }); + }, + /** + * addTagRefinement adds a tag to the list used to filter the results + * @param {string} tag tag to be added + * @return {SearchParameters} + */ + addTagRefinement: function addTagRefinement(tag) { + if (this.isTagRefined(tag)) return this; + + var modification = { + tagRefinements: this.tagRefinements.concat(tag) + }; + + return this.setQueryParameters(modification); + }, + /** + * Remove a facet from the facets attribute of the helper configuration, if it + * is present. + * @method + * @param {string} facet facet name to remove + * @return {SearchParameters} + */ + removeFacet: function removeFacet(facet) { + if (!this.isConjunctiveFacet(facet)) { + return this; + } + + return this.clearRefinements(facet).setQueryParameters({ + facets: this.facets.filter(function(f) { + return f !== facet; + }) + }); + }, + /** + * Remove a disjunctive facet from the disjunctiveFacets attribute of the + * helper configuration, if it is present. + * @method + * @param {string} facet disjunctive facet name to remove + * @return {SearchParameters} + */ + removeDisjunctiveFacet: function removeDisjunctiveFacet(facet) { + if (!this.isDisjunctiveFacet(facet)) { + return this; + } + + return this.clearRefinements(facet).setQueryParameters({ + disjunctiveFacets: this.disjunctiveFacets.filter(function(f) { + return f !== facet; + }) + }); + }, + /** + * Remove a hierarchical facet from the hierarchicalFacets attribute of the + * helper configuration, if it is present. + * @method + * @param {string} facet hierarchical facet name to remove + * @return {SearchParameters} + */ + removeHierarchicalFacet: function removeHierarchicalFacet(facet) { + if (!this.isHierarchicalFacet(facet)) { + return this; + } + + return this.clearRefinements(facet).setQueryParameters({ + hierarchicalFacets: this.hierarchicalFacets.filter(function(f) { + return f.name !== facet; + }) + }); + }, + /** + * Remove a refinement set on facet. If a value is provided, it will clear the + * refinement for the given value, otherwise it will clear all the refinement + * values for the faceted attribute. + * @method + * @param {string} facet name of the attribute used for faceting + * @param {string} [value] value used to filter + * @return {SearchParameters} + */ + removeFacetRefinement: function removeFacetRefinement(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + throw new Error(facet + ' is not defined in the facets attribute of the helper configuration'); + } + if (!RefinementList.isRefined(this.facetsRefinements, facet, value)) return this; + + return this.setQueryParameters({ + facetsRefinements: RefinementList.removeRefinement(this.facetsRefinements, facet, value) + }); + }, + /** + * Remove a negative refinement on a facet + * @method + * @param {string} facet name of the attribute used for faceting + * @param {string} value value used to filter + * @return {SearchParameters} + */ + removeExcludeRefinement: function removeExcludeRefinement(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + throw new Error(facet + ' is not defined in the facets attribute of the helper configuration'); + } + if (!RefinementList.isRefined(this.facetsExcludes, facet, value)) return this; + + return this.setQueryParameters({ + facetsExcludes: RefinementList.removeRefinement(this.facetsExcludes, facet, value) + }); + }, + /** + * Remove a refinement on a disjunctive facet + * @method + * @param {string} facet name of the attribute used for faceting + * @param {string} value value used to filter + * @return {SearchParameters} + */ + removeDisjunctiveFacetRefinement: function removeDisjunctiveFacetRefinement(facet, value) { + if (!this.isDisjunctiveFacet(facet)) { + throw new Error( + facet + ' is not defined in the disjunctiveFacets attribute of the helper configuration'); + } + if (!RefinementList.isRefined(this.disjunctiveFacetsRefinements, facet, value)) return this; + + return this.setQueryParameters({ + disjunctiveFacetsRefinements: RefinementList.removeRefinement( + this.disjunctiveFacetsRefinements, facet, value) + }); + }, + /** + * Remove a tag from the list of tag refinements + * @method + * @param {string} tag the tag to remove + * @return {SearchParameters} + */ + removeTagRefinement: function removeTagRefinement(tag) { + if (!this.isTagRefined(tag)) return this; + + var modification = { + tagRefinements: this.tagRefinements.filter(function(t) { + return t !== tag; + }) + }; + + return this.setQueryParameters(modification); + }, + /** + * Generic toggle refinement method to use with facet, disjunctive facets + * and hierarchical facets + * @param {string} facet the facet to refine + * @param {string} value the associated value + * @return {SearchParameters} + * @throws will throw an error if the facet is not declared in the settings of the helper + * @deprecated since version 2.19.0, see {@link SearchParameters#toggleFacetRefinement} + */ + toggleRefinement: function toggleRefinement(facet, value) { + return this.toggleFacetRefinement(facet, value); + }, + /** + * Generic toggle refinement method to use with facet, disjunctive facets + * and hierarchical facets + * @param {string} facet the facet to refine + * @param {string} value the associated value + * @return {SearchParameters} + * @throws will throw an error if the facet is not declared in the settings of the helper + */ + toggleFacetRefinement: function toggleFacetRefinement(facet, value) { + if (this.isHierarchicalFacet(facet)) { + return this.toggleHierarchicalFacetRefinement(facet, value); + } else if (this.isConjunctiveFacet(facet)) { + return this.toggleConjunctiveFacetRefinement(facet, value); + } else if (this.isDisjunctiveFacet(facet)) { + return this.toggleDisjunctiveFacetRefinement(facet, value); + } + + throw new Error('Cannot refine the undeclared facet ' + facet + + '; it should be added to the helper options facets, disjunctiveFacets or hierarchicalFacets'); + }, + /** + * Switch the refinement applied over a facet/value + * @method + * @param {string} facet name of the attribute used for faceting + * @param {value} value value used for filtering + * @return {SearchParameters} + */ + toggleConjunctiveFacetRefinement: function toggleConjunctiveFacetRefinement(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + throw new Error(facet + ' is not defined in the facets attribute of the helper configuration'); + } + + return this.setQueryParameters({ + facetsRefinements: RefinementList.toggleRefinement(this.facetsRefinements, facet, value) + }); + }, + /** + * Switch the refinement applied over a facet/value + * @method + * @param {string} facet name of the attribute used for faceting + * @param {value} value value used for filtering + * @return {SearchParameters} + */ + toggleExcludeFacetRefinement: function toggleExcludeFacetRefinement(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + throw new Error(facet + ' is not defined in the facets attribute of the helper configuration'); + } + + return this.setQueryParameters({ + facetsExcludes: RefinementList.toggleRefinement(this.facetsExcludes, facet, value) + }); + }, + /** + * Switch the refinement applied over a facet/value + * @method + * @param {string} facet name of the attribute used for faceting + * @param {value} value value used for filtering + * @return {SearchParameters} + */ + toggleDisjunctiveFacetRefinement: function toggleDisjunctiveFacetRefinement(facet, value) { + if (!this.isDisjunctiveFacet(facet)) { + throw new Error( + facet + ' is not defined in the disjunctiveFacets attribute of the helper configuration'); + } + + return this.setQueryParameters({ + disjunctiveFacetsRefinements: RefinementList.toggleRefinement( + this.disjunctiveFacetsRefinements, facet, value) + }); + }, + /** + * Switch the refinement applied over a facet/value + * @method + * @param {string} facet name of the attribute used for faceting + * @param {value} value value used for filtering + * @return {SearchParameters} + */ + toggleHierarchicalFacetRefinement: function toggleHierarchicalFacetRefinement(facet, value) { + if (!this.isHierarchicalFacet(facet)) { + throw new Error( + facet + ' is not defined in the hierarchicalFacets attribute of the helper configuration'); + } + + var separator = this._getHierarchicalFacetSeparator(this.getHierarchicalFacetByName(facet)); + + var mod = {}; + + var upOneOrMultipleLevel = this.hierarchicalFacetsRefinements[facet] !== undefined && + this.hierarchicalFacetsRefinements[facet].length > 0 && ( + // remove current refinement: + // refinement was 'beer > IPA', call is toggleRefine('beer > IPA'), refinement should be `beer` + this.hierarchicalFacetsRefinements[facet][0] === value || + // remove a parent refinement of the current refinement: + // - refinement was 'beer > IPA > Flying dog' + // - call is toggleRefine('beer > IPA') + // - refinement should be `beer` + this.hierarchicalFacetsRefinements[facet][0].indexOf(value + separator) === 0 + ); + + if (upOneOrMultipleLevel) { + if (value.indexOf(separator) === -1) { + // go back to root level + mod[facet] = []; + } else { + mod[facet] = [value.slice(0, value.lastIndexOf(separator))]; + } + } else { + mod[facet] = [value]; + } + + return this.setQueryParameters({ + hierarchicalFacetsRefinements: defaultsPure({}, mod, this.hierarchicalFacetsRefinements) + }); + }, + + /** + * Adds a refinement on a hierarchical facet. + * @param {string} facet the facet name + * @param {string} path the hierarchical facet path + * @return {SearchParameter} the new state + * @throws Error if the facet is not defined or if the facet is refined + */ + addHierarchicalFacetRefinement: function(facet, path) { + if (this.isHierarchicalFacetRefined(facet)) { + throw new Error(facet + ' is already refined.'); + } + if (!this.isHierarchicalFacet(facet)) { + throw new Error(facet + ' is not defined in the hierarchicalFacets attribute of the helper configuration.'); + } + var mod = {}; + mod[facet] = [path]; + return this.setQueryParameters({ + hierarchicalFacetsRefinements: defaultsPure({}, mod, this.hierarchicalFacetsRefinements) + }); + }, + + /** + * Removes the refinement set on a hierarchical facet. + * @param {string} facet the facet name + * @return {SearchParameter} the new state + * @throws Error if the facet is not defined or if the facet is not refined + */ + removeHierarchicalFacetRefinement: function(facet) { + if (!this.isHierarchicalFacetRefined(facet)) { + return this; + } + var mod = {}; + mod[facet] = []; + return this.setQueryParameters({ + hierarchicalFacetsRefinements: defaultsPure({}, mod, this.hierarchicalFacetsRefinements) + }); + }, + /** + * Switch the tag refinement + * @method + * @param {string} tag the tag to remove or add + * @return {SearchParameters} + */ + toggleTagRefinement: function toggleTagRefinement(tag) { + if (this.isTagRefined(tag)) { + return this.removeTagRefinement(tag); + } + + return this.addTagRefinement(tag); + }, + /** + * Test if the facet name is from one of the disjunctive facets + * @method + * @param {string} facet facet name to test + * @return {boolean} + */ + isDisjunctiveFacet: function(facet) { + return this.disjunctiveFacets.indexOf(facet) > -1; + }, + /** + * Test if the facet name is from one of the hierarchical facets + * @method + * @param {string} facetName facet name to test + * @return {boolean} + */ + isHierarchicalFacet: function(facetName) { + return this.getHierarchicalFacetByName(facetName) !== undefined; + }, + /** + * Test if the facet name is from one of the conjunctive/normal facets + * @method + * @param {string} facet facet name to test + * @return {boolean} + */ + isConjunctiveFacet: function(facet) { + return this.facets.indexOf(facet) > -1; + }, + /** + * Returns true if the facet is refined, either for a specific value or in + * general. + * @method + * @param {string} facet name of the attribute for used for faceting + * @param {string} value, optional value. If passed will test that this value + * is filtering the given facet. + * @return {boolean} returns true if refined + */ + isFacetRefined: function isFacetRefined(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + return false; + } + return RefinementList.isRefined(this.facetsRefinements, facet, value); + }, + /** + * Returns true if the facet contains exclusions or if a specific value is + * excluded. + * + * @method + * @param {string} facet name of the attribute for used for faceting + * @param {string} [value] optional value. If passed will test that this value + * is filtering the given facet. + * @return {boolean} returns true if refined + */ + isExcludeRefined: function isExcludeRefined(facet, value) { + if (!this.isConjunctiveFacet(facet)) { + return false; + } + return RefinementList.isRefined(this.facetsExcludes, facet, value); + }, + /** + * Returns true if the facet contains a refinement, or if a value passed is a + * refinement for the facet. + * @method + * @param {string} facet name of the attribute for used for faceting + * @param {string} value optional, will test if the value is used for refinement + * if there is one, otherwise will test if the facet contains any refinement + * @return {boolean} + */ + isDisjunctiveFacetRefined: function isDisjunctiveFacetRefined(facet, value) { + if (!this.isDisjunctiveFacet(facet)) { + return false; + } + return RefinementList.isRefined(this.disjunctiveFacetsRefinements, facet, value); + }, + /** + * Returns true if the facet contains a refinement, or if a value passed is a + * refinement for the facet. + * @method + * @param {string} facet name of the attribute for used for faceting + * @param {string} value optional, will test if the value is used for refinement + * if there is one, otherwise will test if the facet contains any refinement + * @return {boolean} + */ + isHierarchicalFacetRefined: function isHierarchicalFacetRefined(facet, value) { + if (!this.isHierarchicalFacet(facet)) { + return false; + } + + var refinements = this.getHierarchicalRefinement(facet); + + if (!value) { + return refinements.length > 0; + } + + return refinements.indexOf(value) !== -1; + }, + /** + * Test if the triple (attribute, operator, value) is already refined. + * If only the attribute and the operator are provided, it tests if the + * contains any refinement value. + * @method + * @param {string} attribute attribute for which the refinement is applied + * @param {string} [operator] operator of the refinement + * @param {string} [value] value of the refinement + * @return {boolean} true if it is refined + */ + isNumericRefined: function isNumericRefined(attribute, operator, value) { + if (value === undefined && operator === undefined) { + return !!this.numericRefinements[attribute]; + } + + var isOperatorDefined = + this.numericRefinements[attribute] && + this.numericRefinements[attribute][operator] !== undefined; + + if (value === undefined || !isOperatorDefined) { + return isOperatorDefined; + } + + var parsedValue = valToNumber(value); + var isAttributeValueDefined = + findArray(this.numericRefinements[attribute][operator], parsedValue) !== + undefined; + + return isOperatorDefined && isAttributeValueDefined; + }, + /** + * Returns true if the tag refined, false otherwise + * @method + * @param {string} tag the tag to check + * @return {boolean} + */ + isTagRefined: function isTagRefined(tag) { + return this.tagRefinements.indexOf(tag) !== -1; + }, + /** + * Returns the list of all disjunctive facets refined + * @method + * @param {string} facet name of the attribute used for faceting + * @param {value} value value used for filtering + * @return {string[]} + */ + getRefinedDisjunctiveFacets: function getRefinedDisjunctiveFacets() { + var self = this; + + // attributes used for numeric filter can also be disjunctive + var disjunctiveNumericRefinedFacets = intersection( + Object.keys(this.numericRefinements).filter(function(facet) { + return Object.keys(self.numericRefinements[facet]).length > 0; + }), + this.disjunctiveFacets + ); + + return Object.keys(this.disjunctiveFacetsRefinements).filter(function(facet) { + return self.disjunctiveFacetsRefinements[facet].length > 0; + }) + .concat(disjunctiveNumericRefinedFacets) + .concat(this.getRefinedHierarchicalFacets()); + }, + /** + * Returns the list of all disjunctive facets refined + * @method + * @param {string} facet name of the attribute used for faceting + * @param {value} value value used for filtering + * @return {string[]} + */ + getRefinedHierarchicalFacets: function getRefinedHierarchicalFacets() { + var self = this; + return intersection( + // enforce the order between the two arrays, + // so that refinement name index === hierarchical facet index + this.hierarchicalFacets.map(function(facet) { return facet.name; }), + Object.keys(this.hierarchicalFacetsRefinements).filter(function(facet) { + return self.hierarchicalFacetsRefinements[facet].length > 0; + }) + ); + }, + /** + * Returned the list of all disjunctive facets not refined + * @method + * @return {string[]} + */ + getUnrefinedDisjunctiveFacets: function() { + var refinedFacets = this.getRefinedDisjunctiveFacets(); + + return this.disjunctiveFacets.filter(function(f) { + return refinedFacets.indexOf(f) === -1; + }); + }, + + managedParameters: [ + 'index', + + 'facets', + 'disjunctiveFacets', + 'facetsRefinements', + 'hierarchicalFacets', + 'facetsExcludes', + + 'disjunctiveFacetsRefinements', + 'numericRefinements', + 'tagRefinements', + 'hierarchicalFacetsRefinements' + ], + getQueryParams: function getQueryParams() { + var managedParameters = this.managedParameters; + + var queryParams = {}; + + var self = this; + Object.keys(this).forEach(function(paramName) { + var paramValue = self[paramName]; + if (managedParameters.indexOf(paramName) === -1 && paramValue !== undefined) { + queryParams[paramName] = paramValue; + } + }); + + return queryParams; + }, + /** + * Let the user set a specific value for a given parameter. Will return the + * same instance if the parameter is invalid or if the value is the same as the + * previous one. + * @method + * @param {string} parameter the parameter name + * @param {any} value the value to be set, must be compliant with the definition + * of the attribute on the object + * @return {SearchParameters} the updated state + */ + setQueryParameter: function setParameter(parameter, value) { + if (this[parameter] === value) return this; + + var modification = {}; + + modification[parameter] = value; + + return this.setQueryParameters(modification); + }, + /** + * Let the user set any of the parameters with a plain object. + * @method + * @param {object} params all the keys and the values to be updated + * @return {SearchParameters} a new updated instance + */ + setQueryParameters: function setQueryParameters(params) { + if (!params) return this; + + var error = SearchParameters.validate(this, params); + + if (error) { + throw error; + } + + var self = this; + var nextWithNumbers = SearchParameters._parseNumbers(params); + var previousPlainObject = Object.keys(this).reduce(function(acc, key) { + acc[key] = self[key]; + return acc; + }, {}); + + var nextPlainObject = Object.keys(nextWithNumbers).reduce( + function(previous, key) { + var isPreviousValueDefined = previous[key] !== undefined; + var isNextValueDefined = nextWithNumbers[key] !== undefined; + + if (isPreviousValueDefined && !isNextValueDefined) { + return omit(previous, [key]); + } + + if (isNextValueDefined) { + previous[key] = nextWithNumbers[key]; + } + + return previous; + }, + previousPlainObject + ); + + return new this.constructor(nextPlainObject); + }, + + /** + * Returns a new instance with the page reset. Two scenarios possible: + * the page is omitted -> return the given instance + * the page is set -> return a new instance with a page of 0 + * @return {SearchParameters} a new updated instance + */ + resetPage: function() { + if (this.page === undefined) { + return this; + } + + return this.setPage(0); + }, + + /** + * Helper function to get the hierarchicalFacet separator or the default one (`>`) + * @param {object} hierarchicalFacet + * @return {string} returns the hierarchicalFacet.separator or `>` as default + */ + _getHierarchicalFacetSortBy: function(hierarchicalFacet) { + return hierarchicalFacet.sortBy || ['isRefined:desc', 'name:asc']; + }, + + /** + * Helper function to get the hierarchicalFacet separator or the default one (`>`) + * @private + * @param {object} hierarchicalFacet + * @return {string} returns the hierarchicalFacet.separator or `>` as default + */ + _getHierarchicalFacetSeparator: function(hierarchicalFacet) { + return hierarchicalFacet.separator || ' > '; + }, + + /** + * Helper function to get the hierarchicalFacet prefix path or null + * @private + * @param {object} hierarchicalFacet + * @return {string} returns the hierarchicalFacet.rootPath or null as default + */ + _getHierarchicalRootPath: function(hierarchicalFacet) { + return hierarchicalFacet.rootPath || null; + }, + + /** + * Helper function to check if we show the parent level of the hierarchicalFacet + * @private + * @param {object} hierarchicalFacet + * @return {string} returns the hierarchicalFacet.showParentLevel or true as default + */ + _getHierarchicalShowParentLevel: function(hierarchicalFacet) { + if (typeof hierarchicalFacet.showParentLevel === 'boolean') { + return hierarchicalFacet.showParentLevel; + } + return true; + }, + + /** + * Helper function to get the hierarchicalFacet by it's name + * @param {string} hierarchicalFacetName + * @return {object} a hierarchicalFacet + */ + getHierarchicalFacetByName: function(hierarchicalFacetName) { + return find( + this.hierarchicalFacets, + function(f) { + return f.name === hierarchicalFacetName; + } + ); + }, + + /** + * Get the current breadcrumb for a hierarchical facet, as an array + * @param {string} facetName Hierarchical facet name + * @return {array.} the path as an array of string + */ + getHierarchicalFacetBreadcrumb: function(facetName) { + if (!this.isHierarchicalFacet(facetName)) { + return []; + } + + var refinement = this.getHierarchicalRefinement(facetName)[0]; + if (!refinement) return []; + + var separator = this._getHierarchicalFacetSeparator( + this.getHierarchicalFacetByName(facetName) + ); + var path = refinement.split(separator); + return path.map(function(part) { + return part.trim(); + }); + }, + + toString: function() { + return JSON.stringify(this, null, 2); + } +}; + +/** + * Callback used for clearRefinement method + * @callback SearchParameters.clearCallback + * @param {OperatorList|FacetList} value the value of the filter + * @param {string} key the current attribute name + * @param {string} type `numeric`, `disjunctiveFacet`, `conjunctiveFacet`, `hierarchicalFacet` or `exclude` + * depending on the type of facet + * @return {boolean} `true` if the element should be removed. `false` otherwise. + */ +module.exports = SearchParameters; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/SearchResults/generate-hierarchical-tree.js": +/*!*******************************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/SearchResults/generate-hierarchical-tree.js ***! + \*******************************************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +module.exports = generateTrees; + +var orderBy = __webpack_require__(/*! ../functions/orderBy */ "./node_modules/algoliasearch-helper/src/functions/orderBy.js"); +var find = __webpack_require__(/*! ../functions/find */ "./node_modules/algoliasearch-helper/src/functions/find.js"); +var prepareHierarchicalFacetSortBy = __webpack_require__(/*! ../functions/formatSort */ "./node_modules/algoliasearch-helper/src/functions/formatSort.js"); +var fv = __webpack_require__(/*! ../functions/escapeFacetValue */ "./node_modules/algoliasearch-helper/src/functions/escapeFacetValue.js"); +var escapeFacetValue = fv.escapeFacetValue; +var unescapeFacetValue = fv.unescapeFacetValue; + +function generateTrees(state) { + return function generate(hierarchicalFacetResult, hierarchicalFacetIndex) { + var hierarchicalFacet = state.hierarchicalFacets[hierarchicalFacetIndex]; + var hierarchicalFacetRefinement = + (state.hierarchicalFacetsRefinements[hierarchicalFacet.name] && + state.hierarchicalFacetsRefinements[hierarchicalFacet.name][0]) || + ''; + var hierarchicalSeparator = state._getHierarchicalFacetSeparator( + hierarchicalFacet + ); + var hierarchicalRootPath = state._getHierarchicalRootPath( + hierarchicalFacet + ); + var hierarchicalShowParentLevel = state._getHierarchicalShowParentLevel( + hierarchicalFacet + ); + var sortBy = prepareHierarchicalFacetSortBy( + state._getHierarchicalFacetSortBy(hierarchicalFacet) + ); + + var rootExhaustive = hierarchicalFacetResult.every(function(facetResult) { + return facetResult.exhaustive; + }); + + var generateTreeFn = generateHierarchicalTree( + sortBy, + hierarchicalSeparator, + hierarchicalRootPath, + hierarchicalShowParentLevel, + hierarchicalFacetRefinement + ); + + var results = hierarchicalFacetResult; + + if (hierarchicalRootPath) { + results = hierarchicalFacetResult.slice( + hierarchicalRootPath.split(hierarchicalSeparator).length + ); + } + + return results.reduce(generateTreeFn, { + name: state.hierarchicalFacets[hierarchicalFacetIndex].name, + count: null, // root level, no count + isRefined: true, // root level, always refined + path: null, // root level, no path + escapedValue: null, + exhaustive: rootExhaustive, + data: null + }); + }; +} + +function generateHierarchicalTree( + sortBy, + hierarchicalSeparator, + hierarchicalRootPath, + hierarchicalShowParentLevel, + currentRefinement +) { + return function generateTree( + hierarchicalTree, + hierarchicalFacetResult, + currentHierarchicalLevel + ) { + var parent = hierarchicalTree; + + if (currentHierarchicalLevel > 0) { + var level = 0; + + parent = hierarchicalTree; + + while (level < currentHierarchicalLevel) { + /** + * @type {object[]]} hierarchical data + */ + var data = parent && Array.isArray(parent.data) ? parent.data : []; + parent = find(data, function(subtree) { + return subtree.isRefined; + }); + level++; + } + } + + // we found a refined parent, let's add current level data under it + if (parent) { + // filter values in case an object has multiple categories: + // { + // categories: { + // level0: ['beers', 'bières'], + // level1: ['beers > IPA', 'bières > Belges'] + // } + // } + // + // If parent refinement is `beers`, then we do not want to have `bières > Belges` + // showing up + + var picked = Object.keys(hierarchicalFacetResult.data) + .map(function(facetValue) { + return [facetValue, hierarchicalFacetResult.data[facetValue]]; + }) + .filter(function(tuple) { + var facetValue = tuple[0]; + return onlyMatchingTree( + facetValue, + parent.path || hierarchicalRootPath, + currentRefinement, + hierarchicalSeparator, + hierarchicalRootPath, + hierarchicalShowParentLevel + ); + }); + + parent.data = orderBy( + picked.map(function(tuple) { + var facetValue = tuple[0]; + var facetCount = tuple[1]; + + return format( + facetCount, + facetValue, + hierarchicalSeparator, + unescapeFacetValue(currentRefinement), + hierarchicalFacetResult.exhaustive + ); + }), + sortBy[0], + sortBy[1] + ); + } + + return hierarchicalTree; + }; +} + +function onlyMatchingTree( + facetValue, + parentPath, + currentRefinement, + hierarchicalSeparator, + hierarchicalRootPath, + hierarchicalShowParentLevel +) { + // we want the facetValue is a child of hierarchicalRootPath + if ( + hierarchicalRootPath && + (facetValue.indexOf(hierarchicalRootPath) !== 0 || + hierarchicalRootPath === facetValue) + ) { + return false; + } + + // we always want root levels (only when there is no prefix path) + return ( + (!hierarchicalRootPath && + facetValue.indexOf(hierarchicalSeparator) === -1) || + // if there is a rootPath, being root level mean 1 level under rootPath + (hierarchicalRootPath && + facetValue.split(hierarchicalSeparator).length - + hierarchicalRootPath.split(hierarchicalSeparator).length === + 1) || + // if current refinement is a root level and current facetValue is a root level, + // keep the facetValue + (facetValue.indexOf(hierarchicalSeparator) === -1 && + currentRefinement.indexOf(hierarchicalSeparator) === -1) || + // currentRefinement is a child of the facet value + currentRefinement.indexOf(facetValue) === 0 || + // facetValue is a child of the current parent, add it + (facetValue.indexOf(parentPath + hierarchicalSeparator) === 0 && + (hierarchicalShowParentLevel || + facetValue.indexOf(currentRefinement) === 0)) + ); +} + +function format( + facetCount, + facetValue, + hierarchicalSeparator, + currentRefinement, + exhaustive +) { + var parts = facetValue.split(hierarchicalSeparator); + return { + name: parts[parts.length - 1].trim(), + path: facetValue, + escapedValue: escapeFacetValue(facetValue), + count: facetCount, + isRefined: + currentRefinement === facetValue || + currentRefinement.indexOf(facetValue + hierarchicalSeparator) === 0, + exhaustive: exhaustive, + data: null + }; +} + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/SearchResults/index.js": +/*!**********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/SearchResults/index.js ***! + \**********************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var merge = __webpack_require__(/*! ../functions/merge */ "./node_modules/algoliasearch-helper/src/functions/merge.js"); +var defaultsPure = __webpack_require__(/*! ../functions/defaultsPure */ "./node_modules/algoliasearch-helper/src/functions/defaultsPure.js"); +var orderBy = __webpack_require__(/*! ../functions/orderBy */ "./node_modules/algoliasearch-helper/src/functions/orderBy.js"); +var compact = __webpack_require__(/*! ../functions/compact */ "./node_modules/algoliasearch-helper/src/functions/compact.js"); +var find = __webpack_require__(/*! ../functions/find */ "./node_modules/algoliasearch-helper/src/functions/find.js"); +var findIndex = __webpack_require__(/*! ../functions/findIndex */ "./node_modules/algoliasearch-helper/src/functions/findIndex.js"); +var formatSort = __webpack_require__(/*! ../functions/formatSort */ "./node_modules/algoliasearch-helper/src/functions/formatSort.js"); +var fv = __webpack_require__(/*! ../functions/escapeFacetValue */ "./node_modules/algoliasearch-helper/src/functions/escapeFacetValue.js"); +var escapeFacetValue = fv.escapeFacetValue; +var unescapeFacetValue = fv.unescapeFacetValue; + +var generateHierarchicalTree = __webpack_require__(/*! ./generate-hierarchical-tree */ "./node_modules/algoliasearch-helper/src/SearchResults/generate-hierarchical-tree.js"); + +/** + * @typedef SearchResults.Facet + * @type {object} + * @property {string} name name of the attribute in the record + * @property {object} data the faceting data: value, number of entries + * @property {object} stats undefined unless facet_stats is retrieved from algolia + */ + +/** + * @typedef SearchResults.HierarchicalFacet + * @type {object} + * @property {string} name name of the current value given the hierarchical level, trimmed. + * If root node, you get the facet name + * @property {number} count number of objects matching this hierarchical value + * @property {string} path the current hierarchical value full path + * @property {boolean} isRefined `true` if the current value was refined, `false` otherwise + * @property {HierarchicalFacet[]} data sub values for the current level + */ + +/** + * @typedef SearchResults.FacetValue + * @type {object} + * @property {string} name the facet value itself + * @property {number} count times this facet appears in the results + * @property {boolean} isRefined is the facet currently selected + * @property {boolean} isExcluded is the facet currently excluded (only for conjunctive facets) + */ + +/** + * @typedef Refinement + * @type {object} + * @property {string} type the type of filter used: + * `numeric`, `facet`, `exclude`, `disjunctive`, `hierarchical` + * @property {string} attributeName name of the attribute used for filtering + * @property {string} name the value of the filter + * @property {number} numericValue the value as a number. Only for numeric filters. + * @property {string} operator the operator used. Only for numeric filters. + * @property {number} count the number of computed hits for this filter. Only on facets. + * @property {boolean} exhaustive if the count is exhaustive + */ + +/** + * @param {string[]} attributes + */ +function getIndices(attributes) { + var indices = {}; + + attributes.forEach(function(val, idx) { + indices[val] = idx; + }); + + return indices; +} + +function assignFacetStats(dest, facetStats, key) { + if (facetStats && facetStats[key]) { + dest.stats = facetStats[key]; + } +} + +/** + * @typedef {Object} HierarchicalFacet + * @property {string} name + * @property {string[]} attributes + */ + +/** + * @param {HierarchicalFacet[]} hierarchicalFacets + * @param {string} hierarchicalAttributeName + */ +function findMatchingHierarchicalFacetFromAttributeName( + hierarchicalFacets, + hierarchicalAttributeName +) { + return find(hierarchicalFacets, function facetKeyMatchesAttribute( + hierarchicalFacet + ) { + var facetNames = hierarchicalFacet.attributes || []; + return facetNames.indexOf(hierarchicalAttributeName) > -1; + }); +} + +/*eslint-disable */ +/** + * Constructor for SearchResults + * @class + * @classdesc SearchResults contains the results of a query to Algolia using the + * {@link AlgoliaSearchHelper}. + * @param {SearchParameters} state state that led to the response + * @param {array.} results the results from algolia client + * @example SearchResults of the first query in + * the instant search demo +{ + "hitsPerPage": 10, + "processingTimeMS": 2, + "facets": [ + { + "name": "type", + "data": { + "HardGood": 6627, + "BlackTie": 550, + "Music": 665, + "Software": 131, + "Game": 456, + "Movie": 1571 + }, + "exhaustive": false + }, + { + "exhaustive": false, + "data": { + "Free shipping": 5507 + }, + "name": "shipping" + } + ], + "hits": [ + { + "thumbnailImage": "http://img.bbystatic.com/BestBuy_US/images/products/1688/1688832_54x108_s.gif", + "_highlightResult": { + "shortDescription": { + "matchLevel": "none", + "value": "Safeguard your PC, Mac, Android and iOS devices with comprehensive Internet protection", + "matchedWords": [] + }, + "category": { + "matchLevel": "none", + "value": "Computer Security Software", + "matchedWords": [] + }, + "manufacturer": { + "matchedWords": [], + "value": "Webroot", + "matchLevel": "none" + }, + "name": { + "value": "Webroot SecureAnywhere Internet Security (3-Device) (1-Year Subscription) - Mac/Windows", + "matchedWords": [], + "matchLevel": "none" + } + }, + "image": "http://img.bbystatic.com/BestBuy_US/images/products/1688/1688832_105x210_sc.jpg", + "shipping": "Free shipping", + "bestSellingRank": 4, + "shortDescription": "Safeguard your PC, Mac, Android and iOS devices with comprehensive Internet protection", + "url": "http://www.bestbuy.com/site/webroot-secureanywhere-internet-security-3-devi…d=1219060687969&skuId=1688832&cmp=RMX&ky=2d3GfEmNIzjA0vkzveHdZEBgpPCyMnLTJ", + "name": "Webroot SecureAnywhere Internet Security (3-Device) (1-Year Subscription) - Mac/Windows", + "category": "Computer Security Software", + "salePrice_range": "1 - 50", + "objectID": "1688832", + "type": "Software", + "customerReviewCount": 5980, + "salePrice": 49.99, + "manufacturer": "Webroot" + }, + .... + ], + "nbHits": 10000, + "disjunctiveFacets": [ + { + "exhaustive": false, + "data": { + "5": 183, + "12": 112, + "7": 149, + ... + }, + "name": "customerReviewCount", + "stats": { + "max": 7461, + "avg": 157.939, + "min": 1 + } + }, + { + "data": { + "Printer Ink": 142, + "Wireless Speakers": 60, + "Point & Shoot Cameras": 48, + ... + }, + "name": "category", + "exhaustive": false + }, + { + "exhaustive": false, + "data": { + "> 5000": 2, + "1 - 50": 6524, + "501 - 2000": 566, + "201 - 500": 1501, + "101 - 200": 1360, + "2001 - 5000": 47 + }, + "name": "salePrice_range" + }, + { + "data": { + "Dynex™": 202, + "Insignia™": 230, + "PNY": 72, + ... + }, + "name": "manufacturer", + "exhaustive": false + } + ], + "query": "", + "nbPages": 100, + "page": 0, + "index": "bestbuy" +} + **/ +/*eslint-enable */ +function SearchResults(state, results, options) { + var mainSubResponse = results[0]; + + this._rawResults = results; + + var self = this; + + // https://www.algolia.com/doc/api-reference/api-methods/search/#response + Object.keys(mainSubResponse).forEach(function(key) { + self[key] = mainSubResponse[key]; + }); + + // Make every key of the result options reachable from the instance + Object.keys(options || {}).forEach(function(key) { + self[key] = options[key]; + }); + + /** + * query used to generate the results + * @name query + * @member {string} + * @memberof SearchResults + * @instance + */ + /** + * The query as parsed by the engine given all the rules. + * @name parsedQuery + * @member {string} + * @memberof SearchResults + * @instance + */ + /** + * all the records that match the search parameters. Each record is + * augmented with a new attribute `_highlightResult` + * which is an object keyed by attribute and with the following properties: + * - `value` : the value of the facet highlighted (html) + * - `matchLevel`: full, partial or none depending on how the query terms match + * @name hits + * @member {object[]} + * @memberof SearchResults + * @instance + */ + /** + * index where the results come from + * @name index + * @member {string} + * @memberof SearchResults + * @instance + */ + /** + * number of hits per page requested + * @name hitsPerPage + * @member {number} + * @memberof SearchResults + * @instance + */ + /** + * total number of hits of this query on the index + * @name nbHits + * @member {number} + * @memberof SearchResults + * @instance + */ + /** + * total number of pages with respect to the number of hits per page and the total number of hits + * @name nbPages + * @member {number} + * @memberof SearchResults + * @instance + */ + /** + * current page + * @name page + * @member {number} + * @memberof SearchResults + * @instance + */ + /** + * The position if the position was guessed by IP. + * @name aroundLatLng + * @member {string} + * @memberof SearchResults + * @instance + * @example "48.8637,2.3615", + */ + /** + * The radius computed by Algolia. + * @name automaticRadius + * @member {string} + * @memberof SearchResults + * @instance + * @example "126792922", + */ + /** + * String identifying the server used to serve this request. + * + * getRankingInfo needs to be set to `true` for this to be returned + * + * @name serverUsed + * @member {string} + * @memberof SearchResults + * @instance + * @example "c7-use-2.algolia.net", + */ + /** + * Boolean that indicates if the computation of the counts did time out. + * @deprecated + * @name timeoutCounts + * @member {boolean} + * @memberof SearchResults + * @instance + */ + /** + * Boolean that indicates if the computation of the hits did time out. + * @deprecated + * @name timeoutHits + * @member {boolean} + * @memberof SearchResults + * @instance + */ + /** + * True if the counts of the facets is exhaustive + * @name exhaustiveFacetsCount + * @member {boolean} + * @memberof SearchResults + * @instance + */ + /** + * True if the number of hits is exhaustive + * @name exhaustiveNbHits + * @member {boolean} + * @memberof SearchResults + * @instance + */ + /** + * Contains the userData if they are set by a [query rule](https://www.algolia.com/doc/guides/query-rules/query-rules-overview/). + * @name userData + * @member {object[]} + * @memberof SearchResults + * @instance + */ + /** + * queryID is the unique identifier of the query used to generate the current search results. + * This value is only available if the `clickAnalytics` search parameter is set to `true`. + * @name queryID + * @member {string} + * @memberof SearchResults + * @instance + */ + + /** + * sum of the processing time of all the queries + * @member {number} + */ + this.processingTimeMS = results.reduce(function(sum, result) { + return result.processingTimeMS === undefined + ? sum + : sum + result.processingTimeMS; + }, 0); + + /** + * disjunctive facets results + * @member {SearchResults.Facet[]} + */ + this.disjunctiveFacets = []; + /** + * disjunctive facets results + * @member {SearchResults.HierarchicalFacet[]} + */ + this.hierarchicalFacets = state.hierarchicalFacets.map(function initFutureTree() { + return []; + }); + /** + * other facets results + * @member {SearchResults.Facet[]} + */ + this.facets = []; + + var disjunctiveFacets = state.getRefinedDisjunctiveFacets(); + + var facetsIndices = getIndices(state.facets); + var disjunctiveFacetsIndices = getIndices(state.disjunctiveFacets); + var nextDisjunctiveResult = 1; + + // Since we send request only for disjunctive facets that have been refined, + // we get the facets information from the first, general, response. + + var mainFacets = mainSubResponse.facets || {}; + + Object.keys(mainFacets).forEach(function(facetKey) { + var facetValueObject = mainFacets[facetKey]; + + var hierarchicalFacet = findMatchingHierarchicalFacetFromAttributeName( + state.hierarchicalFacets, + facetKey + ); + + if (hierarchicalFacet) { + // Place the hierarchicalFacet data at the correct index depending on + // the attributes order that was defined at the helper initialization + var facetIndex = hierarchicalFacet.attributes.indexOf(facetKey); + var idxAttributeName = findIndex(state.hierarchicalFacets, function(f) { + return f.name === hierarchicalFacet.name; + }); + self.hierarchicalFacets[idxAttributeName][facetIndex] = { + attribute: facetKey, + data: facetValueObject, + exhaustive: mainSubResponse.exhaustiveFacetsCount + }; + } else { + var isFacetDisjunctive = state.disjunctiveFacets.indexOf(facetKey) !== -1; + var isFacetConjunctive = state.facets.indexOf(facetKey) !== -1; + var position; + + if (isFacetDisjunctive) { + position = disjunctiveFacetsIndices[facetKey]; + self.disjunctiveFacets[position] = { + name: facetKey, + data: facetValueObject, + exhaustive: mainSubResponse.exhaustiveFacetsCount + }; + assignFacetStats(self.disjunctiveFacets[position], mainSubResponse.facets_stats, facetKey); + } + if (isFacetConjunctive) { + position = facetsIndices[facetKey]; + self.facets[position] = { + name: facetKey, + data: facetValueObject, + exhaustive: mainSubResponse.exhaustiveFacetsCount + }; + assignFacetStats(self.facets[position], mainSubResponse.facets_stats, facetKey); + } + } + }); + + // Make sure we do not keep holes within the hierarchical facets + this.hierarchicalFacets = compact(this.hierarchicalFacets); + + // aggregate the refined disjunctive facets + disjunctiveFacets.forEach(function(disjunctiveFacet) { + var result = results[nextDisjunctiveResult]; + var facets = result && result.facets ? result.facets : {}; + var hierarchicalFacet = state.getHierarchicalFacetByName(disjunctiveFacet); + + // There should be only item in facets. + Object.keys(facets).forEach(function(dfacet) { + var facetResults = facets[dfacet]; + + var position; + + if (hierarchicalFacet) { + position = findIndex(state.hierarchicalFacets, function(f) { + return f.name === hierarchicalFacet.name; + }); + var attributeIndex = findIndex(self.hierarchicalFacets[position], function(f) { + return f.attribute === dfacet; + }); + + // previous refinements and no results so not able to find it + if (attributeIndex === -1) { + return; + } + + self.hierarchicalFacets[position][attributeIndex].data = merge( + {}, + self.hierarchicalFacets[position][attributeIndex].data, + facetResults + ); + } else { + position = disjunctiveFacetsIndices[dfacet]; + + var dataFromMainRequest = mainSubResponse.facets && mainSubResponse.facets[dfacet] || {}; + + self.disjunctiveFacets[position] = { + name: dfacet, + data: defaultsPure({}, facetResults, dataFromMainRequest), + exhaustive: result.exhaustiveFacetsCount + }; + assignFacetStats(self.disjunctiveFacets[position], result.facets_stats, dfacet); + + if (state.disjunctiveFacetsRefinements[dfacet]) { + state.disjunctiveFacetsRefinements[dfacet].forEach(function(refinementValue) { + // add the disjunctive refinements if it is no more retrieved + if (!self.disjunctiveFacets[position].data[refinementValue] && + state.disjunctiveFacetsRefinements[dfacet].indexOf(unescapeFacetValue(refinementValue)) > -1) { + self.disjunctiveFacets[position].data[refinementValue] = 0; + } + }); + } + } + }); + nextDisjunctiveResult++; + }); + + // if we have some parent level values for hierarchical facets, merge them + state.getRefinedHierarchicalFacets().forEach(function(refinedFacet) { + var hierarchicalFacet = state.getHierarchicalFacetByName(refinedFacet); + var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet); + + var currentRefinement = state.getHierarchicalRefinement(refinedFacet); + // if we are already at a root refinement (or no refinement at all), there is no + // root level values request + if (currentRefinement.length === 0 || currentRefinement[0].split(separator).length < 2) { + return; + } + + results.slice(nextDisjunctiveResult).forEach(function(result) { + var facets = result && result.facets + ? result.facets + : {}; + + Object.keys(facets).forEach(function(dfacet) { + var facetResults = facets[dfacet]; + var position = findIndex(state.hierarchicalFacets, function(f) { + return f.name === hierarchicalFacet.name; + }); + var attributeIndex = findIndex(self.hierarchicalFacets[position], function(f) { + return f.attribute === dfacet; + }); + + // previous refinements and no results so not able to find it + if (attributeIndex === -1) { + return; + } + + // when we always get root levels, if the hits refinement is `beers > IPA` (count: 5), + // then the disjunctive values will be `beers` (count: 100), + // but we do not want to display + // | beers (100) + // > IPA (5) + // We want + // | beers (5) + // > IPA (5) + var defaultData = {}; + + if (currentRefinement.length > 0) { + var root = currentRefinement[0].split(separator)[0]; + defaultData[root] = self.hierarchicalFacets[position][attributeIndex].data[root]; + } + + self.hierarchicalFacets[position][attributeIndex].data = defaultsPure( + defaultData, + facetResults, + self.hierarchicalFacets[position][attributeIndex].data + ); + }); + + nextDisjunctiveResult++; + }); + }); + + // add the excludes + Object.keys(state.facetsExcludes).forEach(function(facetName) { + var excludes = state.facetsExcludes[facetName]; + var position = facetsIndices[facetName]; + + self.facets[position] = { + name: facetName, + data: mainSubResponse.facets[facetName], + exhaustive: mainSubResponse.exhaustiveFacetsCount + }; + excludes.forEach(function(facetValue) { + self.facets[position] = self.facets[position] || {name: facetName}; + self.facets[position].data = self.facets[position].data || {}; + self.facets[position].data[facetValue] = 0; + }); + }); + + /** + * @type {Array} + */ + this.hierarchicalFacets = this.hierarchicalFacets.map(generateHierarchicalTree(state)); + + /** + * @type {Array} + */ + this.facets = compact(this.facets); + /** + * @type {Array} + */ + this.disjunctiveFacets = compact(this.disjunctiveFacets); + + this._state = state; +} + +/** + * Get a facet object with its name + * @deprecated + * @param {string} name name of the faceted attribute + * @return {SearchResults.Facet} the facet object + */ +SearchResults.prototype.getFacetByName = function(name) { + function predicate(facet) { + return facet.name === name; + } + + return find(this.facets, predicate) || + find(this.disjunctiveFacets, predicate) || + find(this.hierarchicalFacets, predicate); +}; + +/** + * Get the facet values of a specified attribute from a SearchResults object. + * @private + * @param {SearchResults} results the search results to search in + * @param {string} attribute name of the faceted attribute to search for + * @return {array|object} facet values. For the hierarchical facets it is an object. + */ +function extractNormalizedFacetValues(results, attribute) { + function predicate(facet) { + return facet.name === attribute; + } + + if (results._state.isConjunctiveFacet(attribute)) { + var facet = find(results.facets, predicate); + if (!facet) return []; + + return Object.keys(facet.data).map(function(name) { + var value = escapeFacetValue(name); + return { + name: name, + escapedValue: value, + count: facet.data[name], + isRefined: results._state.isFacetRefined(attribute, value), + isExcluded: results._state.isExcludeRefined(attribute, name) + }; + }); + } else if (results._state.isDisjunctiveFacet(attribute)) { + var disjunctiveFacet = find(results.disjunctiveFacets, predicate); + if (!disjunctiveFacet) return []; + + return Object.keys(disjunctiveFacet.data).map(function(name) { + var value = escapeFacetValue(name); + return { + name: name, + escapedValue: value, + count: disjunctiveFacet.data[name], + isRefined: results._state.isDisjunctiveFacetRefined(attribute, value) + }; + }); + } else if (results._state.isHierarchicalFacet(attribute)) { + var hierarchicalFacetValues = find(results.hierarchicalFacets, predicate); + if (!hierarchicalFacetValues) return hierarchicalFacetValues; + + var hierarchicalFacet = results._state.getHierarchicalFacetByName(attribute); + var currentRefinementSplit = unescapeFacetValue( + results._state.getHierarchicalRefinement(attribute)[0] || '' + ).split(results._state._getHierarchicalFacetSeparator(hierarchicalFacet)); + currentRefinementSplit.unshift(attribute); + + setIsRefined(hierarchicalFacetValues, currentRefinementSplit, 0); + + return hierarchicalFacetValues; + } +} + +/** + * Set the isRefined of a hierarchical facet result based on the current state. + * @param {SearchResults.HierarchicalFacet} item Hierarchical facet to fix + * @param {string[]} currentRefinementSplit array of parts of the current hierarchical refinement + * @param {number} depth recursion depth in the currentRefinement + */ +function setIsRefined(item, currentRefinement, depth) { + item.isRefined = item.name === currentRefinement[depth]; + if (item.data) { + item.data.forEach(function(child) { + setIsRefined(child, currentRefinement, depth + 1); + }); + } +} + +/** + * Sort nodes of a hierarchical or disjunctive facet results + * @private + * @param {function} sortFn + * @param {HierarchicalFacet|Array} node node upon which we want to apply the sort + * @param {string[]} names attribute names + * @param {number} [level=0] current index in the names array + */ +function recSort(sortFn, node, names, level) { + level = level || 0; + + if (Array.isArray(node)) { + return sortFn(node, names[level]); + } + + if (!node.data || node.data.length === 0) { + return node; + } + + var children = node.data.map(function(childNode) { + return recSort(sortFn, childNode, names, level + 1); + }); + var sortedChildren = sortFn(children, names[level]); + var newNode = defaultsPure({data: sortedChildren}, node); + return newNode; +} + +SearchResults.DEFAULT_SORT = ['isRefined:desc', 'count:desc', 'name:asc']; + +function vanillaSortFn(order, data) { + return data.sort(order); +} + +/** + * @typedef FacetOrdering + * @type {Object} + * @property {string[]} [order] + * @property {'count' | 'alpha' | 'hidden'} [sortRemainingBy] + */ + +/** + * Sorts facet arrays via their facet ordering + * @param {Array} facetValues the values + * @param {FacetOrdering} facetOrdering the ordering + * @returns {Array} + */ +function sortViaFacetOrdering(facetValues, facetOrdering) { + var orderedFacets = []; + var remainingFacets = []; + + var order = facetOrdering.order || []; + /** + * an object with the keys being the values in order, the values their index: + * ['one', 'two'] -> { one: 0, two: 1 } + */ + var reverseOrder = order.reduce(function(acc, name, i) { + acc[name] = i; + return acc; + }, {}); + + facetValues.forEach(function(item) { + // hierarchical facets get sorted using their raw name + var name = item.path || item.name; + if (reverseOrder[name] !== undefined) { + orderedFacets[reverseOrder[name]] = item; + } else { + remainingFacets.push(item); + } + }); + + orderedFacets = orderedFacets.filter(function(facet) { + return facet; + }); + + var sortRemainingBy = facetOrdering.sortRemainingBy; + var ordering; + if (sortRemainingBy === 'hidden') { + return orderedFacets; + } else if (sortRemainingBy === 'alpha') { + ordering = [['path', 'name'], ['asc', 'asc']]; + } else { + ordering = [['count'], ['desc']]; + } + + return orderedFacets.concat( + orderBy(remainingFacets, ordering[0], ordering[1]) + ); +} + +/** + * @param {SearchResults} results the search results class + * @param {string} attribute the attribute to retrieve ordering of + * @returns {FacetOrdering=} + */ +function getFacetOrdering(results, attribute) { + return ( + results.renderingContent && + results.renderingContent.facetOrdering && + results.renderingContent.facetOrdering.values && + results.renderingContent.facetOrdering.values[attribute] + ); +} + +/** + * Get a the list of values for a given facet attribute. Those values are sorted + * refinement first, descending count (bigger value on top), and name ascending + * (alphabetical order). The sort formula can overridden using either string based + * predicates or a function. + * + * This method will return all the values returned by the Algolia engine plus all + * the values already refined. This means that it can happen that the + * `maxValuesPerFacet` [configuration](https://www.algolia.com/doc/rest-api/search#param-maxValuesPerFacet) + * might not be respected if you have facet values that are already refined. + * @param {string} attribute attribute name + * @param {object} opts configuration options. + * @param {boolean} [opts.facetOrdering] + * Force the use of facetOrdering from the result if a sortBy is present. If + * sortBy isn't present, facetOrdering will be used automatically. + * @param {Array. | function} opts.sortBy + * When using strings, it consists of + * the name of the [FacetValue](#SearchResults.FacetValue) or the + * [HierarchicalFacet](#SearchResults.HierarchicalFacet) attributes with the + * order (`asc` or `desc`). For example to order the value by count, the + * argument would be `['count:asc']`. + * + * If only the attribute name is specified, the ordering defaults to the one + * specified in the default value for this attribute. + * + * When not specified, the order is + * ascending. This parameter can also be a function which takes two facet + * values and should return a number, 0 if equal, 1 if the first argument is + * bigger or -1 otherwise. + * + * The default value for this attribute `['isRefined:desc', 'count:desc', 'name:asc']` + * @return {FacetValue[]|HierarchicalFacet|undefined} depending on the type of facet of + * the attribute requested (hierarchical, disjunctive or conjunctive) + * @example + * helper.on('result', function(event){ + * //get values ordered only by name ascending using the string predicate + * event.results.getFacetValues('city', {sortBy: ['name:asc']}); + * //get values ordered only by count ascending using a function + * event.results.getFacetValues('city', { + * // this is equivalent to ['count:asc'] + * sortBy: function(a, b) { + * if (a.count === b.count) return 0; + * if (a.count > b.count) return 1; + * if (b.count > a.count) return -1; + * } + * }); + * }); + */ +SearchResults.prototype.getFacetValues = function(attribute, opts) { + var facetValues = extractNormalizedFacetValues(this, attribute); + if (!facetValues) { + return undefined; + } + + var options = defaultsPure({}, opts, { + sortBy: SearchResults.DEFAULT_SORT, + // if no sortBy is given, attempt to sort based on facetOrdering + // if it is given, we still allow to sort via facet ordering first + facetOrdering: !(opts && opts.sortBy) + }); + + var results = this; + var attributes; + if (Array.isArray(facetValues)) { + attributes = [attribute]; + } else { + var config = results._state.getHierarchicalFacetByName(facetValues.name); + attributes = config.attributes; + } + + return recSort(function(data, facetName) { + if (options.facetOrdering) { + var facetOrdering = getFacetOrdering(results, facetName); + if (Boolean(facetOrdering)) { + return sortViaFacetOrdering(data, facetOrdering); + } + } + + if (Array.isArray(options.sortBy)) { + var order = formatSort(options.sortBy, SearchResults.DEFAULT_SORT); + return orderBy(data, order[0], order[1]); + } else if (typeof options.sortBy === 'function') { + return vanillaSortFn(options.sortBy, data); + } + throw new Error( + 'options.sortBy is optional but if defined it must be ' + + 'either an array of string (predicates) or a sorting function' + ); + }, facetValues, attributes); +}; + +/** + * Returns the facet stats if attribute is defined and the facet contains some. + * Otherwise returns undefined. + * @param {string} attribute name of the faceted attribute + * @return {object} The stats of the facet + */ +SearchResults.prototype.getFacetStats = function(attribute) { + if (this._state.isConjunctiveFacet(attribute)) { + return getFacetStatsIfAvailable(this.facets, attribute); + } else if (this._state.isDisjunctiveFacet(attribute)) { + return getFacetStatsIfAvailable(this.disjunctiveFacets, attribute); + } + + return undefined; +}; + +/** + * @typedef {Object} FacetListItem + * @property {string} name + */ + +/** + * @param {FacetListItem[]} facetList (has more items, but enough for here) + * @param {string} facetName + */ +function getFacetStatsIfAvailable(facetList, facetName) { + var data = find(facetList, function(facet) { + return facet.name === facetName; + }); + return data && data.stats; +} + +/** + * Returns all refinements for all filters + tags. It also provides + * additional information: count and exhaustiveness for each filter. + * + * See the [refinement type](#Refinement) for an exhaustive view of the available + * data. + * + * Note that for a numeric refinement, results are grouped per operator, this + * means that it will return responses for operators which are empty. + * + * @return {Array.} all the refinements + */ +SearchResults.prototype.getRefinements = function() { + var state = this._state; + var results = this; + var res = []; + + Object.keys(state.facetsRefinements).forEach(function(attributeName) { + state.facetsRefinements[attributeName].forEach(function(name) { + res.push(getRefinement(state, 'facet', attributeName, name, results.facets)); + }); + }); + + Object.keys(state.facetsExcludes).forEach(function(attributeName) { + state.facetsExcludes[attributeName].forEach(function(name) { + res.push(getRefinement(state, 'exclude', attributeName, name, results.facets)); + }); + }); + + Object.keys(state.disjunctiveFacetsRefinements).forEach(function(attributeName) { + state.disjunctiveFacetsRefinements[attributeName].forEach(function(name) { + res.push(getRefinement(state, 'disjunctive', attributeName, name, results.disjunctiveFacets)); + }); + }); + + Object.keys(state.hierarchicalFacetsRefinements).forEach(function(attributeName) { + state.hierarchicalFacetsRefinements[attributeName].forEach(function(name) { + res.push(getHierarchicalRefinement(state, attributeName, name, results.hierarchicalFacets)); + }); + }); + + + Object.keys(state.numericRefinements).forEach(function(attributeName) { + var operators = state.numericRefinements[attributeName]; + Object.keys(operators).forEach(function(operator) { + operators[operator].forEach(function(value) { + res.push({ + type: 'numeric', + attributeName: attributeName, + name: value, + numericValue: value, + operator: operator + }); + }); + }); + }); + + state.tagRefinements.forEach(function(name) { + res.push({type: 'tag', attributeName: '_tags', name: name}); + }); + + return res; +}; + +/** + * @typedef {Object} Facet + * @property {string} name + * @property {Object} data + * @property {boolean} exhaustive + */ + +/** + * @param {*} state + * @param {*} type + * @param {string} attributeName + * @param {*} name + * @param {Facet[]} resultsFacets + */ +function getRefinement(state, type, attributeName, name, resultsFacets) { + var facet = find(resultsFacets, function(f) { + return f.name === attributeName; + }); + var count = facet && facet.data && facet.data[name] ? facet.data[name] : 0; + var exhaustive = (facet && facet.exhaustive) || false; + + return { + type: type, + attributeName: attributeName, + name: name, + count: count, + exhaustive: exhaustive + }; +} + +/** + * @param {*} state + * @param {string} attributeName + * @param {*} name + * @param {Facet[]} resultsFacets + */ +function getHierarchicalRefinement(state, attributeName, name, resultsFacets) { + var facetDeclaration = state.getHierarchicalFacetByName(attributeName); + var separator = state._getHierarchicalFacetSeparator(facetDeclaration); + var split = name.split(separator); + var rootFacet = find(resultsFacets, function(facet) { + return facet.name === attributeName; + }); + + var facet = split.reduce(function(intermediateFacet, part) { + var newFacet = + intermediateFacet && find(intermediateFacet.data, function(f) { + return f.name === part; + }); + return newFacet !== undefined ? newFacet : intermediateFacet; + }, rootFacet); + + var count = (facet && facet.count) || 0; + var exhaustive = (facet && facet.exhaustive) || false; + var path = (facet && facet.path) || ''; + + return { + type: 'hierarchical', + attributeName: attributeName, + name: path, + count: count, + exhaustive: exhaustive + }; +} + +module.exports = SearchResults; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/algoliasearch.helper.js": +/*!***********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/algoliasearch.helper.js ***! + \***********************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var SearchParameters = __webpack_require__(/*! ./SearchParameters */ "./node_modules/algoliasearch-helper/src/SearchParameters/index.js"); +var SearchResults = __webpack_require__(/*! ./SearchResults */ "./node_modules/algoliasearch-helper/src/SearchResults/index.js"); +var DerivedHelper = __webpack_require__(/*! ./DerivedHelper */ "./node_modules/algoliasearch-helper/src/DerivedHelper/index.js"); +var requestBuilder = __webpack_require__(/*! ./requestBuilder */ "./node_modules/algoliasearch-helper/src/requestBuilder.js"); + +var EventEmitter = __webpack_require__(/*! @algolia/events */ "./node_modules/@algolia/events/events.js"); +var inherits = __webpack_require__(/*! ./functions/inherits */ "./node_modules/algoliasearch-helper/src/functions/inherits.js"); +var objectHasKeys = __webpack_require__(/*! ./functions/objectHasKeys */ "./node_modules/algoliasearch-helper/src/functions/objectHasKeys.js"); +var omit = __webpack_require__(/*! ./functions/omit */ "./node_modules/algoliasearch-helper/src/functions/omit.js"); +var merge = __webpack_require__(/*! ./functions/merge */ "./node_modules/algoliasearch-helper/src/functions/merge.js"); + +var version = __webpack_require__(/*! ./version */ "./node_modules/algoliasearch-helper/src/version.js"); +var escapeFacetValue = (__webpack_require__(/*! ./functions/escapeFacetValue */ "./node_modules/algoliasearch-helper/src/functions/escapeFacetValue.js").escapeFacetValue); + +/** + * Event triggered when a parameter is set or updated + * @event AlgoliaSearchHelper#event:change + * @property {object} event + * @property {SearchParameters} event.state the current parameters with the latest changes applied + * @property {SearchResults} event.results the previous results received from Algolia. `null` before the first request + * @example + * helper.on('change', function(event) { + * console.log('The parameters have changed'); + * }); + */ + +/** + * Event triggered when a main search is sent to Algolia + * @event AlgoliaSearchHelper#event:search + * @property {object} event + * @property {SearchParameters} event.state the parameters used for this search + * @property {SearchResults} event.results the results from the previous search. `null` if it is the first search. + * @example + * helper.on('search', function(event) { + * console.log('Search sent'); + * }); + */ + +/** + * Event triggered when a search using `searchForFacetValues` is sent to Algolia + * @event AlgoliaSearchHelper#event:searchForFacetValues + * @property {object} event + * @property {SearchParameters} event.state the parameters used for this search it is the first search. + * @property {string} event.facet the facet searched into + * @property {string} event.query the query used to search in the facets + * @example + * helper.on('searchForFacetValues', function(event) { + * console.log('searchForFacetValues sent'); + * }); + */ + +/** + * Event triggered when a search using `searchOnce` is sent to Algolia + * @event AlgoliaSearchHelper#event:searchOnce + * @property {object} event + * @property {SearchParameters} event.state the parameters used for this search it is the first search. + * @example + * helper.on('searchOnce', function(event) { + * console.log('searchOnce sent'); + * }); + */ + +/** + * Event triggered when the results are retrieved from Algolia + * @event AlgoliaSearchHelper#event:result + * @property {object} event + * @property {SearchResults} event.results the results received from Algolia + * @property {SearchParameters} event.state the parameters used to query Algolia. Those might be different from the one in the helper instance (for example if the network is unreliable). + * @example + * helper.on('result', function(event) { + * console.log('Search results received'); + * }); + */ + +/** + * Event triggered when Algolia sends back an error. For example, if an unknown parameter is + * used, the error can be caught using this event. + * @event AlgoliaSearchHelper#event:error + * @property {object} event + * @property {Error} event.error the error returned by the Algolia. + * @example + * helper.on('error', function(event) { + * console.log('Houston we got a problem.'); + * }); + */ + +/** + * Event triggered when the queue of queries have been depleted (with any result or outdated queries) + * @event AlgoliaSearchHelper#event:searchQueueEmpty + * @example + * helper.on('searchQueueEmpty', function() { + * console.log('No more search pending'); + * // This is received before the result event if we're not expecting new results + * }); + * + * helper.search(); + */ + +/** + * Initialize a new AlgoliaSearchHelper + * @class + * @classdesc The AlgoliaSearchHelper is a class that ease the management of the + * search. It provides an event based interface for search callbacks: + * - change: when the internal search state is changed. + * This event contains a {@link SearchParameters} object and the + * {@link SearchResults} of the last result if any. + * - search: when a search is triggered using the `search()` method. + * - result: when the response is retrieved from Algolia and is processed. + * This event contains a {@link SearchResults} object and the + * {@link SearchParameters} corresponding to this answer. + * - error: when the response is an error. This event contains the error returned by the server. + * @param {AlgoliaSearch} client an AlgoliaSearch client + * @param {string} index the index name to query + * @param {SearchParameters | object} options an object defining the initial + * config of the search. It doesn't have to be a {SearchParameters}, + * just an object containing the properties you need from it. + */ +function AlgoliaSearchHelper(client, index, options) { + if (typeof client.addAlgoliaAgent === 'function') { + client.addAlgoliaAgent('JS Helper (' + version + ')'); + } + + this.setClient(client); + var opts = options || {}; + opts.index = index; + this.state = SearchParameters.make(opts); + this.lastResults = null; + this._queryId = 0; + this._lastQueryIdReceived = -1; + this.derivedHelpers = []; + this._currentNbQueries = 0; +} + +inherits(AlgoliaSearchHelper, EventEmitter); + +/** + * Start the search with the parameters set in the state. When the + * method is called, it triggers a `search` event. The results will + * be available through the `result` event. If an error occurs, an + * `error` will be fired instead. + * @return {AlgoliaSearchHelper} + * @fires search + * @fires result + * @fires error + * @chainable + */ +AlgoliaSearchHelper.prototype.search = function() { + this._search({onlyWithDerivedHelpers: false}); + return this; +}; + +AlgoliaSearchHelper.prototype.searchOnlyWithDerivedHelpers = function() { + this._search({onlyWithDerivedHelpers: true}); + return this; +}; + +/** + * Gets the search query parameters that would be sent to the Algolia Client + * for the hits + * @return {object} Query Parameters + */ +AlgoliaSearchHelper.prototype.getQuery = function() { + var state = this.state; + return requestBuilder._getHitsSearchParams(state); +}; + +/** + * Start a search using a modified version of the current state. This method does + * not trigger the helper lifecycle and does not modify the state kept internally + * by the helper. This second aspect means that the next search call will be the + * same as a search call before calling searchOnce. + * @param {object} options can contain all the parameters that can be set to SearchParameters + * plus the index + * @param {function} [callback] optional callback executed when the response from the + * server is back. + * @return {promise|undefined} if a callback is passed the method returns undefined + * otherwise it returns a promise containing an object with two keys : + * - content with a SearchResults + * - state with the state used for the query as a SearchParameters + * @example + * // Changing the number of records returned per page to 1 + * // This example uses the callback API + * var state = helper.searchOnce({hitsPerPage: 1}, + * function(error, content, state) { + * // if an error occurred it will be passed in error, otherwise its value is null + * // content contains the results formatted as a SearchResults + * // state is the instance of SearchParameters used for this search + * }); + * @example + * // Changing the number of records returned per page to 1 + * // This example uses the promise API + * var state1 = helper.searchOnce({hitsPerPage: 1}) + * .then(promiseHandler); + * + * function promiseHandler(res) { + * // res contains + * // { + * // content : SearchResults + * // state : SearchParameters (the one used for this specific search) + * // } + * } + */ +AlgoliaSearchHelper.prototype.searchOnce = function(options, cb) { + var tempState = !options ? this.state : this.state.setQueryParameters(options); + var queries = requestBuilder._getQueries(tempState.index, tempState); + var self = this; + + this._currentNbQueries++; + + this.emit('searchOnce', { + state: tempState + }); + + if (cb) { + this.client + .search(queries) + .then(function(content) { + self._currentNbQueries--; + if (self._currentNbQueries === 0) { + self.emit('searchQueueEmpty'); + } + + cb(null, new SearchResults(tempState, content.results), tempState); + }) + .catch(function(err) { + self._currentNbQueries--; + if (self._currentNbQueries === 0) { + self.emit('searchQueueEmpty'); + } + + cb(err, null, tempState); + }); + + return undefined; + } + + return this.client.search(queries).then(function(content) { + self._currentNbQueries--; + if (self._currentNbQueries === 0) self.emit('searchQueueEmpty'); + return { + content: new SearchResults(tempState, content.results), + state: tempState, + _originalResponse: content + }; + }, function(e) { + self._currentNbQueries--; + if (self._currentNbQueries === 0) self.emit('searchQueueEmpty'); + throw e; + }); +}; + + /** + * Start the search for answers with the parameters set in the state. + * This method returns a promise. + * @param {Object} options - the options for answers API call + * @param {string[]} options.attributesForPrediction - Attributes to use for predictions. If empty, `searchableAttributes` is used instead. + * @param {string[]} options.queryLanguages - The languages in the query. Currently only supports ['en']. + * @param {number} options.nbHits - Maximum number of answers to retrieve from the Answers Engine. Cannot be greater than 1000. + * + * @return {promise} the answer results + * @deprecated answers is deprecated and will be replaced with new initiatives + */ +AlgoliaSearchHelper.prototype.findAnswers = function(options) { + console.warn('[algoliasearch-helper] answers is no longer supported'); + var state = this.state; + var derivedHelper = this.derivedHelpers[0]; + if (!derivedHelper) { + return Promise.resolve([]); + } + var derivedState = derivedHelper.getModifiedState(state); + var data = merge( + { + attributesForPrediction: options.attributesForPrediction, + nbHits: options.nbHits + }, + { + params: omit(requestBuilder._getHitsSearchParams(derivedState), [ + 'attributesToSnippet', + 'hitsPerPage', + 'restrictSearchableAttributes', + 'snippetEllipsisText' // FIXME remove this line once the engine is fixed. + ]) + } + ); + + var errorMessage = 'search for answers was called, but this client does not have a function client.initIndex(index).findAnswers'; + if (typeof this.client.initIndex !== 'function') { + throw new Error(errorMessage); + } + var index = this.client.initIndex(derivedState.index); + if (typeof index.findAnswers !== 'function') { + throw new Error(errorMessage); + } + return index.findAnswers(derivedState.query, options.queryLanguages, data); +}; + +/** + * Structure of each result when using + * [`searchForFacetValues()`](reference.html#AlgoliaSearchHelper#searchForFacetValues) + * @typedef FacetSearchHit + * @type {object} + * @property {string} value the facet value + * @property {string} highlighted the facet value highlighted with the query string + * @property {number} count number of occurrence of this facet value + * @property {boolean} isRefined true if the value is already refined + */ + +/** + * Structure of the data resolved by the + * [`searchForFacetValues()`](reference.html#AlgoliaSearchHelper#searchForFacetValues) + * promise. + * @typedef FacetSearchResult + * @type {object} + * @property {FacetSearchHit} facetHits the results for this search for facet values + * @property {number} processingTimeMS time taken by the query inside the engine + */ + +/** + * Search for facet values based on an query and the name of a faceted attribute. This + * triggers a search and will return a promise. On top of using the query, it also sends + * the parameters from the state so that the search is narrowed down to only the possible values. + * + * See the description of [FacetSearchResult](reference.html#FacetSearchResult) + * @param {string} facet the name of the faceted attribute + * @param {string} query the string query for the search + * @param {number} [maxFacetHits] the maximum number values returned. Should be > 0 and <= 100 + * @param {object} [userState] the set of custom parameters to use on top of the current state. Setting a property to `undefined` removes + * it in the generated query. + * @return {promise.} the results of the search + */ +AlgoliaSearchHelper.prototype.searchForFacetValues = function(facet, query, maxFacetHits, userState) { + var clientHasSFFV = typeof this.client.searchForFacetValues === 'function'; + var clientHasInitIndex = typeof this.client.initIndex === 'function'; + if ( + !clientHasSFFV && + !clientHasInitIndex && + typeof this.client.search !== 'function' + ) { + throw new Error( + 'search for facet values (searchable) was called, but this client does not have a function client.searchForFacetValues or client.initIndex(index).searchForFacetValues' + ); + } + + var state = this.state.setQueryParameters(userState || {}); + var isDisjunctive = state.isDisjunctiveFacet(facet); + var algoliaQuery = requestBuilder.getSearchForFacetQuery(facet, query, maxFacetHits, state); + + this._currentNbQueries++; + var self = this; + var searchForFacetValuesPromise; + // newer algoliasearch ^3.27.1 - ~4.0.0 + if (clientHasSFFV) { + searchForFacetValuesPromise = this.client.searchForFacetValues([ + {indexName: state.index, params: algoliaQuery} + ]); + // algoliasearch < 3.27.1 + } else if (clientHasInitIndex) { + searchForFacetValuesPromise = this.client + .initIndex(state.index) + .searchForFacetValues(algoliaQuery); + // algoliasearch ~5.0.0 + } else { + // @MAJOR only use client.search + delete algoliaQuery.facetName; + searchForFacetValuesPromise = this.client + .search([ + { + type: 'facet', + facet: facet, + indexName: state.index, + params: algoliaQuery + } + ]) + .then(function processResponse(response) { + return response.results[0]; + }); + } + + this.emit('searchForFacetValues', { + state: state, + facet: facet, + query: query + }); + + return searchForFacetValuesPromise.then(function addIsRefined(content) { + self._currentNbQueries--; + if (self._currentNbQueries === 0) self.emit('searchQueueEmpty'); + + content = Array.isArray(content) ? content[0] : content; + + content.facetHits.forEach(function(f) { + f.escapedValue = escapeFacetValue(f.value); + f.isRefined = isDisjunctive + ? state.isDisjunctiveFacetRefined(facet, f.escapedValue) + : state.isFacetRefined(facet, f.escapedValue); + }); + + return content; + }, function(e) { + self._currentNbQueries--; + if (self._currentNbQueries === 0) self.emit('searchQueueEmpty'); + throw e; + }); +}; + +/** + * Sets the text query used for the search. + * + * This method resets the current page to 0. + * @param {string} q the user query + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.setQuery = function(q) { + this._change({ + state: this.state.resetPage().setQuery(q), + isPageReset: true + }); + + return this; +}; + +/** + * Remove all the types of refinements except tags. A string can be provided to remove + * only the refinements of a specific attribute. For more advanced use case, you can + * provide a function instead. This function should follow the + * [clearCallback definition](#SearchParameters.clearCallback). + * + * This method resets the current page to 0. + * @param {string} [name] optional name of the facet / attribute on which we want to remove all refinements + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + * @example + * // Removing all the refinements + * helper.clearRefinements().search(); + * @example + * // Removing all the filters on a the category attribute. + * helper.clearRefinements('category').search(); + * @example + * // Removing only the exclude filters on the category facet. + * helper.clearRefinements(function(value, attribute, type) { + * return type === 'exclude' && attribute === 'category'; + * }).search(); + */ +AlgoliaSearchHelper.prototype.clearRefinements = function(name) { + this._change({ + state: this.state.resetPage().clearRefinements(name), + isPageReset: true + }); + + return this; +}; + +/** + * Remove all the tag filters. + * + * This method resets the current page to 0. + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.clearTags = function() { + this._change({ + state: this.state.resetPage().clearTags(), + isPageReset: true + }); + + return this; +}; + +/** + * Adds a disjunctive filter to a faceted attribute with the `value` provided. If the + * filter is already set, it doesn't change the filters. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} value the associated value (will be converted to string) + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.addDisjunctiveFacetRefinement = function(facet, value) { + this._change({ + state: this.state.resetPage().addDisjunctiveFacetRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#addDisjunctiveFacetRefinement} + */ +AlgoliaSearchHelper.prototype.addDisjunctiveRefine = function() { + return this.addDisjunctiveFacetRefinement.apply(this, arguments); +}; + +/** + * Adds a refinement on a hierarchical facet. It will throw + * an exception if the facet is not defined or if the facet + * is already refined. + * + * This method resets the current page to 0. + * @param {string} facet the facet name + * @param {string} path the hierarchical facet path + * @return {AlgoliaSearchHelper} + * @throws Error if the facet is not defined or if the facet is refined + * @chainable + * @fires change + */ +AlgoliaSearchHelper.prototype.addHierarchicalFacetRefinement = function(facet, value) { + this._change({ + state: this.state.resetPage().addHierarchicalFacetRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * Adds a an numeric filter to an attribute with the `operator` and `value` provided. If the + * filter is already set, it doesn't change the filters. + * + * This method resets the current page to 0. + * @param {string} attribute the attribute on which the numeric filter applies + * @param {string} operator the operator of the filter + * @param {number} value the value of the filter + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.addNumericRefinement = function(attribute, operator, value) { + this._change({ + state: this.state.resetPage().addNumericRefinement(attribute, operator, value), + isPageReset: true + }); + + return this; +}; + +/** + * Adds a filter to a faceted attribute with the `value` provided. If the + * filter is already set, it doesn't change the filters. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} value the associated value (will be converted to string) + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.addFacetRefinement = function(facet, value) { + this._change({ + state: this.state.resetPage().addFacetRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#addFacetRefinement} + */ +AlgoliaSearchHelper.prototype.addRefine = function() { + return this.addFacetRefinement.apply(this, arguments); +}; + + +/** + * Adds a an exclusion filter to a faceted attribute with the `value` provided. If the + * filter is already set, it doesn't change the filters. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} value the associated value (will be converted to string) + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.addFacetExclusion = function(facet, value) { + this._change({ + state: this.state.resetPage().addExcludeRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#addFacetExclusion} + */ +AlgoliaSearchHelper.prototype.addExclude = function() { + return this.addFacetExclusion.apply(this, arguments); +}; + +/** + * Adds a tag filter with the `tag` provided. If the + * filter is already set, it doesn't change the filters. + * + * This method resets the current page to 0. + * @param {string} tag the tag to add to the filter + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.addTag = function(tag) { + this._change({ + state: this.state.resetPage().addTagRefinement(tag), + isPageReset: true + }); + + return this; +}; + +/** + * Removes an numeric filter to an attribute with the `operator` and `value` provided. If the + * filter is not set, it doesn't change the filters. + * + * Some parameters are optional, triggering different behavior: + * - if the value is not provided, then all the numeric value will be removed for the + * specified attribute/operator couple. + * - if the operator is not provided either, then all the numeric filter on this attribute + * will be removed. + * + * This method resets the current page to 0. + * @param {string} attribute the attribute on which the numeric filter applies + * @param {string} [operator] the operator of the filter + * @param {number} [value] the value of the filter + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.removeNumericRefinement = function(attribute, operator, value) { + this._change({ + state: this.state.resetPage().removeNumericRefinement(attribute, operator, value), + isPageReset: true + }); + + return this; +}; + +/** + * Removes a disjunctive filter to a faceted attribute with the `value` provided. If the + * filter is not set, it doesn't change the filters. + * + * If the value is omitted, then this method will remove all the filters for the + * attribute. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} [value] the associated value + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.removeDisjunctiveFacetRefinement = function(facet, value) { + this._change({ + state: this.state.resetPage().removeDisjunctiveFacetRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#removeDisjunctiveFacetRefinement} + */ +AlgoliaSearchHelper.prototype.removeDisjunctiveRefine = function() { + return this.removeDisjunctiveFacetRefinement.apply(this, arguments); +}; + +/** + * Removes the refinement set on a hierarchical facet. + * @param {string} facet the facet name + * @return {AlgoliaSearchHelper} + * @throws Error if the facet is not defined or if the facet is not refined + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.removeHierarchicalFacetRefinement = function(facet) { + this._change({ + state: this.state.resetPage().removeHierarchicalFacetRefinement(facet), + isPageReset: true + }); + + return this; +}; + +/** + * Removes a filter to a faceted attribute with the `value` provided. If the + * filter is not set, it doesn't change the filters. + * + * If the value is omitted, then this method will remove all the filters for the + * attribute. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} [value] the associated value + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.removeFacetRefinement = function(facet, value) { + this._change({ + state: this.state.resetPage().removeFacetRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#removeFacetRefinement} + */ +AlgoliaSearchHelper.prototype.removeRefine = function() { + return this.removeFacetRefinement.apply(this, arguments); +}; + +/** + * Removes an exclusion filter to a faceted attribute with the `value` provided. If the + * filter is not set, it doesn't change the filters. + * + * If the value is omitted, then this method will remove all the filters for the + * attribute. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} [value] the associated value + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.removeFacetExclusion = function(facet, value) { + this._change({ + state: this.state.resetPage().removeExcludeRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#removeFacetExclusion} + */ +AlgoliaSearchHelper.prototype.removeExclude = function() { + return this.removeFacetExclusion.apply(this, arguments); +}; + +/** + * Removes a tag filter with the `tag` provided. If the + * filter is not set, it doesn't change the filters. + * + * This method resets the current page to 0. + * @param {string} tag tag to remove from the filter + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.removeTag = function(tag) { + this._change({ + state: this.state.resetPage().removeTagRefinement(tag), + isPageReset: true + }); + + return this; +}; + +/** + * Adds or removes an exclusion filter to a faceted attribute with the `value` provided. If + * the value is set then it removes it, otherwise it adds the filter. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} value the associated value + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.toggleFacetExclusion = function(facet, value) { + this._change({ + state: this.state.resetPage().toggleExcludeFacetRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#toggleFacetExclusion} + */ +AlgoliaSearchHelper.prototype.toggleExclude = function() { + return this.toggleFacetExclusion.apply(this, arguments); +}; + +/** + * Adds or removes a filter to a faceted attribute with the `value` provided. If + * the value is set then it removes it, otherwise it adds the filter. + * + * This method can be used for conjunctive, disjunctive and hierarchical filters. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} value the associated value + * @return {AlgoliaSearchHelper} + * @throws Error will throw an error if the facet is not declared in the settings of the helper + * @fires change + * @chainable + * @deprecated since version 2.19.0, see {@link AlgoliaSearchHelper#toggleFacetRefinement} + */ +AlgoliaSearchHelper.prototype.toggleRefinement = function(facet, value) { + return this.toggleFacetRefinement(facet, value); +}; + +/** + * Adds or removes a filter to a faceted attribute with the `value` provided. If + * the value is set then it removes it, otherwise it adds the filter. + * + * This method can be used for conjunctive, disjunctive and hierarchical filters. + * + * This method resets the current page to 0. + * @param {string} facet the facet to refine + * @param {string} value the associated value + * @return {AlgoliaSearchHelper} + * @throws Error will throw an error if the facet is not declared in the settings of the helper + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.toggleFacetRefinement = function(facet, value) { + this._change({ + state: this.state.resetPage().toggleFacetRefinement(facet, value), + isPageReset: true + }); + + return this; +}; + +/** + * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#toggleFacetRefinement} + */ +AlgoliaSearchHelper.prototype.toggleRefine = function() { + return this.toggleFacetRefinement.apply(this, arguments); +}; + +/** + * Adds or removes a tag filter with the `value` provided. If + * the value is set then it removes it, otherwise it adds the filter. + * + * This method resets the current page to 0. + * @param {string} tag tag to remove or add + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.toggleTag = function(tag) { + this._change({ + state: this.state.resetPage().toggleTagRefinement(tag), + isPageReset: true + }); + + return this; +}; + +/** + * Increments the page number by one. + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + * @example + * helper.setPage(0).nextPage().getPage(); + * // returns 1 + */ +AlgoliaSearchHelper.prototype.nextPage = function() { + var page = this.state.page || 0; + return this.setPage(page + 1); +}; + +/** + * Decrements the page number by one. + * @fires change + * @return {AlgoliaSearchHelper} + * @chainable + * @example + * helper.setPage(1).previousPage().getPage(); + * // returns 0 + */ +AlgoliaSearchHelper.prototype.previousPage = function() { + var page = this.state.page || 0; + return this.setPage(page - 1); +}; + +/** + * @private + */ +function setCurrentPage(page) { + if (page < 0) throw new Error('Page requested below 0.'); + + this._change({ + state: this.state.setPage(page), + isPageReset: false + }); + + return this; +} + +/** + * Change the current page + * @deprecated + * @param {number} page The page number + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.setCurrentPage = setCurrentPage; + +/** + * Updates the current page. + * @function + * @param {number} page The page number + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.setPage = setCurrentPage; + +/** + * Updates the name of the index that will be targeted by the query. + * + * This method resets the current page to 0. + * @param {string} name the index name + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.setIndex = function(name) { + this._change({ + state: this.state.resetPage().setIndex(name), + isPageReset: true + }); + + return this; +}; + +/** + * Update a parameter of the search. This method reset the page + * + * The complete list of parameters is available on the + * [Algolia website](https://www.algolia.com/doc/rest#query-an-index). + * The most commonly used parameters have their own [shortcuts](#query-parameters-shortcuts) + * or benefit from higher-level APIs (all the kind of filters and facets have their own API) + * + * This method resets the current page to 0. + * @param {string} parameter name of the parameter to update + * @param {any} value new value of the parameter + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + * @example + * helper.setQueryParameter('hitsPerPage', 20).search(); + */ +AlgoliaSearchHelper.prototype.setQueryParameter = function(parameter, value) { + this._change({ + state: this.state.resetPage().setQueryParameter(parameter, value), + isPageReset: true + }); + + return this; +}; + +/** + * Set the whole state (warning: will erase previous state) + * @param {SearchParameters} newState the whole new state + * @return {AlgoliaSearchHelper} + * @fires change + * @chainable + */ +AlgoliaSearchHelper.prototype.setState = function(newState) { + this._change({ + state: SearchParameters.make(newState), + isPageReset: false + }); + + return this; +}; + +/** + * Override the current state without triggering a change event. + * Do not use this method unless you know what you are doing. (see the example + * for a legit use case) + * @param {SearchParameters} newState the whole new state + * @return {AlgoliaSearchHelper} + * @example + * helper.on('change', function(state){ + * // In this function you might want to find a way to store the state in the url/history + * updateYourURL(state) + * }) + * window.onpopstate = function(event){ + * // This is naive though as you should check if the state is really defined etc. + * helper.overrideStateWithoutTriggeringChangeEvent(event.state).search() + * } + * @chainable + */ +AlgoliaSearchHelper.prototype.overrideStateWithoutTriggeringChangeEvent = function(newState) { + this.state = new SearchParameters(newState); + return this; +}; + +/** + * Check if an attribute has any numeric, conjunctive, disjunctive or hierarchical filters. + * @param {string} attribute the name of the attribute + * @return {boolean} true if the attribute is filtered by at least one value + * @example + * // hasRefinements works with numeric, conjunctive, disjunctive and hierarchical filters + * helper.hasRefinements('price'); // false + * helper.addNumericRefinement('price', '>', 100); + * helper.hasRefinements('price'); // true + * + * helper.hasRefinements('color'); // false + * helper.addFacetRefinement('color', 'blue'); + * helper.hasRefinements('color'); // true + * + * helper.hasRefinements('material'); // false + * helper.addDisjunctiveFacetRefinement('material', 'plastic'); + * helper.hasRefinements('material'); // true + * + * helper.hasRefinements('categories'); // false + * helper.toggleFacetRefinement('categories', 'kitchen > knife'); + * helper.hasRefinements('categories'); // true + * + */ +AlgoliaSearchHelper.prototype.hasRefinements = function(attribute) { + if (objectHasKeys(this.state.getNumericRefinements(attribute))) { + return true; + } else if (this.state.isConjunctiveFacet(attribute)) { + return this.state.isFacetRefined(attribute); + } else if (this.state.isDisjunctiveFacet(attribute)) { + return this.state.isDisjunctiveFacetRefined(attribute); + } else if (this.state.isHierarchicalFacet(attribute)) { + return this.state.isHierarchicalFacetRefined(attribute); + } + + // there's currently no way to know that the user did call `addNumericRefinement` at some point + // thus we cannot distinguish if there once was a numeric refinement that was cleared + // so we will return false in every other situations to be consistent + // while what we should do here is throw because we did not find the attribute in any type + // of refinement + return false; +}; + +/** + * Check if a value is excluded for a specific faceted attribute. If the value + * is omitted then the function checks if there is any excluding refinements. + * + * @param {string} facet name of the attribute for used for faceting + * @param {string} [value] optional value. If passed will test that this value + * is filtering the given facet. + * @return {boolean} true if refined + * @example + * helper.isExcludeRefined('color'); // false + * helper.isExcludeRefined('color', 'blue') // false + * helper.isExcludeRefined('color', 'red') // false + * + * helper.addFacetExclusion('color', 'red'); + * + * helper.isExcludeRefined('color'); // true + * helper.isExcludeRefined('color', 'blue') // false + * helper.isExcludeRefined('color', 'red') // true + */ +AlgoliaSearchHelper.prototype.isExcluded = function(facet, value) { + return this.state.isExcludeRefined(facet, value); +}; + +/** + * @deprecated since 2.4.0, see {@link AlgoliaSearchHelper#hasRefinements} + */ +AlgoliaSearchHelper.prototype.isDisjunctiveRefined = function(facet, value) { + return this.state.isDisjunctiveFacetRefined(facet, value); +}; + +/** + * Check if the string is a currently filtering tag. + * @param {string} tag tag to check + * @return {boolean} + */ +AlgoliaSearchHelper.prototype.hasTag = function(tag) { + return this.state.isTagRefined(tag); +}; + +/** + * @deprecated since 2.4.0, see {@link AlgoliaSearchHelper#hasTag} + */ +AlgoliaSearchHelper.prototype.isTagRefined = function() { + return this.hasTagRefinements.apply(this, arguments); +}; + + +/** + * Get the name of the currently used index. + * @return {string} + * @example + * helper.setIndex('highestPrice_products').getIndex(); + * // returns 'highestPrice_products' + */ +AlgoliaSearchHelper.prototype.getIndex = function() { + return this.state.index; +}; + +function getCurrentPage() { + return this.state.page; +} + +/** + * Get the currently selected page + * @deprecated + * @return {number} the current page + */ +AlgoliaSearchHelper.prototype.getCurrentPage = getCurrentPage; +/** + * Get the currently selected page + * @function + * @return {number} the current page + */ +AlgoliaSearchHelper.prototype.getPage = getCurrentPage; + +/** + * Get all the tags currently set to filters the results. + * + * @return {string[]} The list of tags currently set. + */ +AlgoliaSearchHelper.prototype.getTags = function() { + return this.state.tagRefinements; +}; + +/** + * Get the list of refinements for a given attribute. This method works with + * conjunctive, disjunctive, excluding and numerical filters. + * + * See also SearchResults#getRefinements + * + * @param {string} facetName attribute name used for faceting + * @return {Array.} All Refinement are objects that contain a value, and + * a type. Numeric also contains an operator. + * @example + * helper.addNumericRefinement('price', '>', 100); + * helper.getRefinements('price'); + * // [ + * // { + * // "value": [ + * // 100 + * // ], + * // "operator": ">", + * // "type": "numeric" + * // } + * // ] + * @example + * helper.addFacetRefinement('color', 'blue'); + * helper.addFacetExclusion('color', 'red'); + * helper.getRefinements('color'); + * // [ + * // { + * // "value": "blue", + * // "type": "conjunctive" + * // }, + * // { + * // "value": "red", + * // "type": "exclude" + * // } + * // ] + * @example + * helper.addDisjunctiveFacetRefinement('material', 'plastic'); + * // [ + * // { + * // "value": "plastic", + * // "type": "disjunctive" + * // } + * // ] + */ +AlgoliaSearchHelper.prototype.getRefinements = function(facetName) { + var refinements = []; + + if (this.state.isConjunctiveFacet(facetName)) { + var conjRefinements = this.state.getConjunctiveRefinements(facetName); + + conjRefinements.forEach(function(r) { + refinements.push({ + value: r, + type: 'conjunctive' + }); + }); + + var excludeRefinements = this.state.getExcludeRefinements(facetName); + + excludeRefinements.forEach(function(r) { + refinements.push({ + value: r, + type: 'exclude' + }); + }); + } else if (this.state.isDisjunctiveFacet(facetName)) { + var disjRefinements = this.state.getDisjunctiveRefinements(facetName); + + disjRefinements.forEach(function(r) { + refinements.push({ + value: r, + type: 'disjunctive' + }); + }); + } + + var numericRefinements = this.state.getNumericRefinements(facetName); + + Object.keys(numericRefinements).forEach(function(operator) { + var value = numericRefinements[operator]; + + refinements.push({ + value: value, + operator: operator, + type: 'numeric' + }); + }); + + return refinements; +}; + +/** + * Return the current refinement for the (attribute, operator) + * @param {string} attribute attribute in the record + * @param {string} operator operator applied on the refined values + * @return {Array.} refined values + */ +AlgoliaSearchHelper.prototype.getNumericRefinement = function(attribute, operator) { + return this.state.getNumericRefinement(attribute, operator); +}; + +/** + * Get the current breadcrumb for a hierarchical facet, as an array + * @param {string} facetName Hierarchical facet name + * @return {array.} the path as an array of string + */ +AlgoliaSearchHelper.prototype.getHierarchicalFacetBreadcrumb = function(facetName) { + return this.state.getHierarchicalFacetBreadcrumb(facetName); +}; + +// /////////// PRIVATE + +/** + * Perform the underlying queries + * @private + * @return {undefined} + * @fires search + * @fires result + * @fires error + */ +AlgoliaSearchHelper.prototype._search = function(options) { + var state = this.state; + var states = []; + var mainQueries = []; + + if (!options.onlyWithDerivedHelpers) { + mainQueries = requestBuilder._getQueries(state.index, state); + + states.push({ + state: state, + queriesCount: mainQueries.length, + helper: this + }); + + this.emit('search', { + state: state, + results: this.lastResults + }); + } + + var derivedQueries = this.derivedHelpers.map(function(derivedHelper) { + var derivedState = derivedHelper.getModifiedState(state); + var derivedStateQueries = requestBuilder._getQueries(derivedState.index, derivedState); + + states.push({ + state: derivedState, + queriesCount: derivedStateQueries.length, + helper: derivedHelper + }); + + derivedHelper.emit('search', { + state: derivedState, + results: derivedHelper.lastResults + }); + + return derivedStateQueries; + }); + + var queries = Array.prototype.concat.apply(mainQueries, derivedQueries); + var queryId = this._queryId++; + + this._currentNbQueries++; + + try { + this.client.search(queries) + .then(this._dispatchAlgoliaResponse.bind(this, states, queryId)) + .catch(this._dispatchAlgoliaError.bind(this, queryId)); + } catch (error) { + // If we reach this part, we're in an internal error state + this.emit('error', { + error: error + }); + } +}; + +/** + * Transform the responses as sent by the server and transform them into a user + * usable object that merge the results of all the batch requests. It will dispatch + * over the different helper + derived helpers (when there are some). + * @private + * @param {array.<{SearchParameters, AlgoliaQueries, AlgoliaSearchHelper}>} + * state state used for to generate the request + * @param {number} queryId id of the current request + * @param {object} content content of the response + * @return {undefined} + */ +AlgoliaSearchHelper.prototype._dispatchAlgoliaResponse = function(states, queryId, content) { + // FIXME remove the number of outdated queries discarded instead of just one + + if (queryId < this._lastQueryIdReceived) { + // Outdated answer + return; + } + + this._currentNbQueries -= (queryId - this._lastQueryIdReceived); + this._lastQueryIdReceived = queryId; + + if (this._currentNbQueries === 0) this.emit('searchQueueEmpty'); + + var results = content.results.slice(); + + states.forEach(function(s) { + var state = s.state; + var queriesCount = s.queriesCount; + var helper = s.helper; + var specificResults = results.splice(0, queriesCount); + + var formattedResponse = helper.lastResults = new SearchResults(state, specificResults); + + helper.emit('result', { + results: formattedResponse, + state: state + }); + }); +}; + +AlgoliaSearchHelper.prototype._dispatchAlgoliaError = function(queryId, error) { + if (queryId < this._lastQueryIdReceived) { + // Outdated answer + return; + } + + this._currentNbQueries -= queryId - this._lastQueryIdReceived; + this._lastQueryIdReceived = queryId; + + this.emit('error', { + error: error + }); + + if (this._currentNbQueries === 0) this.emit('searchQueueEmpty'); +}; + +AlgoliaSearchHelper.prototype.containsRefinement = function(query, facetFilters, numericFilters, tagFilters) { + return query || + facetFilters.length !== 0 || + numericFilters.length !== 0 || + tagFilters.length !== 0; +}; + +/** + * Test if there are some disjunctive refinements on the facet + * @private + * @param {string} facet the attribute to test + * @return {boolean} + */ +AlgoliaSearchHelper.prototype._hasDisjunctiveRefinements = function(facet) { + return this.state.disjunctiveRefinements[facet] && + this.state.disjunctiveRefinements[facet].length > 0; +}; + +AlgoliaSearchHelper.prototype._change = function(event) { + var state = event.state; + var isPageReset = event.isPageReset; + + if (state !== this.state) { + this.state = state; + + this.emit('change', { + state: this.state, + results: this.lastResults, + isPageReset: isPageReset + }); + } +}; + +/** + * Clears the cache of the underlying Algolia client. + * @return {AlgoliaSearchHelper} + */ +AlgoliaSearchHelper.prototype.clearCache = function() { + this.client.clearCache && this.client.clearCache(); + return this; +}; + +/** + * Updates the internal client instance. If the reference of the clients + * are equal then no update is actually done. + * @param {AlgoliaSearch} newClient an AlgoliaSearch client + * @return {AlgoliaSearchHelper} + */ +AlgoliaSearchHelper.prototype.setClient = function(newClient) { + if (this.client === newClient) return this; + + if (typeof newClient.addAlgoliaAgent === 'function') { + newClient.addAlgoliaAgent('JS Helper (' + version + ')'); + } + this.client = newClient; + + return this; +}; + +/** + * Gets the instance of the currently used client. + * @return {AlgoliaSearch} + */ +AlgoliaSearchHelper.prototype.getClient = function() { + return this.client; +}; + +/** + * Creates an derived instance of the Helper. A derived helper + * is a way to request other indices synchronised with the lifecycle + * of the main Helper. This mechanism uses the multiqueries feature + * of Algolia to aggregate all the requests in a single network call. + * + * This method takes a function that is used to create a new SearchParameter + * that will be used to create requests to Algolia. Those new requests + * are created just before the `search` event. The signature of the function + * is `SearchParameters -> SearchParameters`. + * + * This method returns a new DerivedHelper which is an EventEmitter + * that fires the same `search`, `result` and `error` events. Those + * events, however, will receive data specific to this DerivedHelper + * and the SearchParameters that is returned by the call of the + * parameter function. + * @param {function} fn SearchParameters -> SearchParameters + * @return {DerivedHelper} + */ +AlgoliaSearchHelper.prototype.derive = function(fn) { + var derivedHelper = new DerivedHelper(this, fn); + this.derivedHelpers.push(derivedHelper); + return derivedHelper; +}; + +/** + * This method detaches a derived Helper from the main one. Prefer using the one from the + * derived helper itself, to remove the event listeners too. + * @private + * @return {undefined} + * @throws Error + */ +AlgoliaSearchHelper.prototype.detachDerivedHelper = function(derivedHelper) { + var pos = this.derivedHelpers.indexOf(derivedHelper); + if (pos === -1) throw new Error('Derived helper already detached'); + this.derivedHelpers.splice(pos, 1); +}; + +/** + * This method returns true if there is currently at least one on-going search. + * @return {boolean} true if there is a search pending + */ +AlgoliaSearchHelper.prototype.hasPendingRequests = function() { + return this._currentNbQueries > 0; +}; + +/** + * @typedef AlgoliaSearchHelper.NumericRefinement + * @type {object} + * @property {number[]} value the numbers that are used for filtering this attribute with + * the operator specified. + * @property {string} operator the faceting data: value, number of entries + * @property {string} type will be 'numeric' + */ + +/** + * @typedef AlgoliaSearchHelper.FacetRefinement + * @type {object} + * @property {string} value the string use to filter the attribute + * @property {string} type the type of filter: 'conjunctive', 'disjunctive', 'exclude' + */ + +module.exports = AlgoliaSearchHelper; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/compact.js": +/*!********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/compact.js ***! + \********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +module.exports = function compact(array) { + if (!Array.isArray(array)) { + return []; + } + + return array.filter(Boolean); +}; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/defaultsPure.js": +/*!*************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/defaultsPure.js ***! + \*************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +// NOTE: this behaves like lodash/defaults, but doesn't mutate the target +// it also preserve keys order +module.exports = function defaultsPure() { + var sources = Array.prototype.slice.call(arguments); + + return sources.reduceRight(function(acc, source) { + Object.keys(Object(source)).forEach(function(key) { + if (source[key] === undefined) { + return; + } + if (acc[key] !== undefined) { + // remove if already added, so that we can add it in correct order + delete acc[key]; + } + acc[key] = source[key]; + }); + return acc; + }, {}); +}; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/escapeFacetValue.js": +/*!*****************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/escapeFacetValue.js ***! + \*****************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +/** + * Replaces a leading - with \- + * @private + * @param {any} value the facet value to replace + * @returns any + */ +function escapeFacetValue(value) { + if (typeof value !== 'string') return value; + + return String(value).replace(/^-/, '\\-'); +} + +/** + * Replaces a leading \- with - + * @private + * @param {any} value the escaped facet value + * @returns any + */ +function unescapeFacetValue(value) { + if (typeof value !== 'string') return value; + + return value.replace(/^\\-/, '-'); +} + +module.exports = { + escapeFacetValue: escapeFacetValue, + unescapeFacetValue: unescapeFacetValue +}; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/find.js": +/*!*****************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/find.js ***! + \*****************************************************************/ +/***/ ((module) => { + +"use strict"; + + +// @MAJOR can be replaced by native Array#find when we change support +module.exports = function find(array, comparator) { + if (!Array.isArray(array)) { + return undefined; + } + + for (var i = 0; i < array.length; i++) { + if (comparator(array[i])) { + return array[i]; + } + } +}; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/findIndex.js": +/*!**********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/findIndex.js ***! + \**********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +// @MAJOR can be replaced by native Array#findIndex when we change support +module.exports = function find(array, comparator) { + if (!Array.isArray(array)) { + return -1; + } + + for (var i = 0; i < array.length; i++) { + if (comparator(array[i])) { + return i; + } + } + return -1; +}; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/formatSort.js": +/*!***********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/formatSort.js ***! + \***********************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var find = __webpack_require__(/*! ./find */ "./node_modules/algoliasearch-helper/src/functions/find.js"); + +/** + * Transform sort format from user friendly notation to lodash format + * @param {string[]} sortBy array of predicate of the form "attribute:order" + * @param {string[]} [defaults] array of predicate of the form "attribute:order" + * @return {array.} array containing 2 elements : attributes, orders + */ +module.exports = function formatSort(sortBy, defaults) { + var defaultInstructions = (defaults || []).map(function(sort) { + return sort.split(':'); + }); + + return sortBy.reduce( + function preparePredicate(out, sort) { + var sortInstruction = sort.split(':'); + + var matchingDefault = find(defaultInstructions, function( + defaultInstruction + ) { + return defaultInstruction[0] === sortInstruction[0]; + }); + + if (sortInstruction.length > 1 || !matchingDefault) { + out[0].push(sortInstruction[0]); + out[1].push(sortInstruction[1]); + return out; + } + + out[0].push(matchingDefault[0]); + out[1].push(matchingDefault[1]); + return out; + }, + [[], []] + ); +}; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/inherits.js": +/*!*********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/inherits.js ***! + \*********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +function inherits(ctor, superCtor) { + ctor.prototype = Object.create(superCtor.prototype, { + constructor: { + value: ctor, + enumerable: false, + writable: true, + configurable: true + } + }); +} + +module.exports = inherits; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/intersection.js": +/*!*************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/intersection.js ***! + \*************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +function intersection(arr1, arr2) { + return arr1.filter(function(value, index) { + return ( + arr2.indexOf(value) > -1 && + arr1.indexOf(value) === index /* skips duplicates */ + ); + }); +} + +module.exports = intersection; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/merge.js": +/*!******************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/merge.js ***! + \******************************************************************/ +/***/ ((module) => { + +"use strict"; + + +function clone(value) { + if (typeof value === 'object' && value !== null) { + return _merge(Array.isArray(value) ? [] : {}, value); + } + return value; +} + +function isObjectOrArrayOrFunction(value) { + return ( + typeof value === 'function' || + Array.isArray(value) || + Object.prototype.toString.call(value) === '[object Object]' + ); +} + +function _merge(target, source) { + if (target === source) { + return target; + } + + for (var key in source) { + if ( + !Object.prototype.hasOwnProperty.call(source, key) || + key === '__proto__' || + key === 'constructor' + ) { + continue; + } + + var sourceVal = source[key]; + var targetVal = target[key]; + + if (typeof targetVal !== 'undefined' && typeof sourceVal === 'undefined') { + continue; + } + + if ( + isObjectOrArrayOrFunction(targetVal) && + isObjectOrArrayOrFunction(sourceVal) + ) { + target[key] = _merge(targetVal, sourceVal); + } else { + target[key] = clone(sourceVal); + } + } + return target; +} + +/** + * This method is like Object.assign, but recursively merges own and inherited + * enumerable keyed properties of source objects into the destination object. + * + * NOTE: this behaves like lodash/merge, but: + * - does mutate functions if they are a source + * - treats non-plain objects as plain + * - does not work for circular objects + * - treats sparse arrays as sparse + * - does not convert Array-like objects (Arguments, NodeLists, etc.) to arrays + * + * @param {Object} object The destination object. + * @param {...Object} [sources] The source objects. + * @returns {Object} Returns `object`. + */ + +function merge(target) { + if (!isObjectOrArrayOrFunction(target)) { + target = {}; + } + + for (var i = 1, l = arguments.length; i < l; i++) { + var source = arguments[i]; + + if (isObjectOrArrayOrFunction(source)) { + _merge(target, source); + } + } + return target; +} + +module.exports = merge; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/objectHasKeys.js": +/*!**************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/objectHasKeys.js ***! + \**************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +function objectHasKeys(obj) { + return obj && Object.keys(obj).length > 0; +} + +module.exports = objectHasKeys; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/omit.js": +/*!*****************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/omit.js ***! + \*****************************************************************/ +/***/ ((module) => { + +"use strict"; + + +// https://github.com/babel/babel/blob/3aaafae053fa75febb3aa45d45b6f00646e30ba4/packages/babel-helpers/src/helpers.js#L604-L620 +function _objectWithoutPropertiesLoose(source, excluded) { + if (source === null) return {}; + var target = {}; + var sourceKeys = Object.keys(source); + var key; + var i; + for (i = 0; i < sourceKeys.length; i++) { + key = sourceKeys[i]; + if (excluded.indexOf(key) >= 0) continue; + target[key] = source[key]; + } + return target; +} + +module.exports = _objectWithoutPropertiesLoose; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/orderBy.js": +/*!********************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/orderBy.js ***! + \********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +function compareAscending(value, other) { + if (value !== other) { + var valIsDefined = value !== undefined; + var valIsNull = value === null; + + var othIsDefined = other !== undefined; + var othIsNull = other === null; + + if ( + (!othIsNull && value > other) || + (valIsNull && othIsDefined) || + !valIsDefined + ) { + return 1; + } + if ( + (!valIsNull && value < other) || + (othIsNull && valIsDefined) || + !othIsDefined + ) { + return -1; + } + } + return 0; +} + +/** + * @param {Array} collection object with keys in attributes + * @param {Array} iteratees attributes + * @param {Array} orders asc | desc + */ +function orderBy(collection, iteratees, orders) { + if (!Array.isArray(collection)) { + return []; + } + + if (!Array.isArray(orders)) { + orders = []; + } + + var result = collection.map(function(value, index) { + return { + criteria: iteratees.map(function(iteratee) { + return value[iteratee]; + }), + index: index, + value: value + }; + }); + + result.sort(function comparer(object, other) { + var index = -1; + + while (++index < object.criteria.length) { + var res = compareAscending(object.criteria[index], other.criteria[index]); + if (res) { + if (index >= orders.length) { + return res; + } + if (orders[index] === 'desc') { + return -res; + } + return res; + } + } + + // This ensures a stable sort in V8 and other engines. + // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details. + return object.index - other.index; + }); + + return result.map(function(res) { + return res.value; + }); +} + +module.exports = orderBy; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/functions/valToNumber.js": +/*!************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/functions/valToNumber.js ***! + \************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +function valToNumber(v) { + if (typeof v === 'number') { + return v; + } else if (typeof v === 'string') { + return parseFloat(v); + } else if (Array.isArray(v)) { + return v.map(valToNumber); + } + + throw new Error('The value should be a number, a parsable string or an array of those.'); +} + +module.exports = valToNumber; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/requestBuilder.js": +/*!*****************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/requestBuilder.js ***! + \*****************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var merge = __webpack_require__(/*! ./functions/merge */ "./node_modules/algoliasearch-helper/src/functions/merge.js"); + +function sortObject(obj) { + return Object.keys(obj) + .sort(function(a, b) { + return a.localeCompare(b); + }) + .reduce(function(acc, curr) { + acc[curr] = obj[curr]; + return acc; + }, {}); +} + +var requestBuilder = { + /** + * Get all the queries to send to the client, those queries can used directly + * with the Algolia client. + * @private + * @return {object[]} The queries + */ + _getQueries: function getQueries(index, state) { + var queries = []; + + // One query for the hits + queries.push({ + indexName: index, + params: requestBuilder._getHitsSearchParams(state) + }); + + // One for each disjunctive facets + state.getRefinedDisjunctiveFacets().forEach(function(refinedFacet) { + queries.push({ + indexName: index, + params: requestBuilder._getDisjunctiveFacetSearchParams(state, refinedFacet) + }); + }); + + // More to get the parent levels of the hierarchical facets when refined + state.getRefinedHierarchicalFacets().forEach(function(refinedFacet) { + var hierarchicalFacet = state.getHierarchicalFacetByName(refinedFacet); + var currentRefinement = state.getHierarchicalRefinement(refinedFacet); + var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet); + + // If we are deeper than level 0 (starting from `beer > IPA`) + // we want to get all parent values + if (currentRefinement.length > 0 && currentRefinement[0].split(separator).length > 1) { + // We generate a map of the filters we will use for our facet values queries + var filtersMap = currentRefinement[0].split(separator).slice(0, -1).reduce( + function createFiltersMap(map, segment, level) { + return map.concat({ + attribute: hierarchicalFacet.attributes[level], + value: level === 0 + ? segment + : [map[map.length - 1].value, segment].join(separator) + }); + } + , []); + + filtersMap.forEach(function(filter, level) { + var params = requestBuilder._getDisjunctiveFacetSearchParams( + state, + filter.attribute, + level === 0 + ); + + // Keep facet filters unrelated to current hierarchical attributes + function hasHierarchicalFacetFilter(value) { + return hierarchicalFacet.attributes.some(function(attribute) { + return attribute === value.split(':')[0]; + }); + } + + var filteredFacetFilters = (params.facetFilters || []).reduce(function(acc, facetFilter) { + if (Array.isArray(facetFilter)) { + var filtered = facetFilter.filter(function(filterValue) { + return !hasHierarchicalFacetFilter(filterValue); + }); + + if (filtered.length > 0) { + acc.push(filtered); + } + } + + if (typeof facetFilter === 'string' && !hasHierarchicalFacetFilter(facetFilter)) { + acc.push(facetFilter); + } + + return acc; + }, []); + + var parent = filtersMap[level - 1]; + if (level > 0) { + params.facetFilters = filteredFacetFilters.concat(parent.attribute + ':' + parent.value); + } else { + params.facetFilters = filteredFacetFilters.length > 0 ? filteredFacetFilters : undefined; + } + + queries.push({indexName: index, params: params}); + }); + } + }); + + return queries; + }, + + /** + * Build search parameters used to fetch hits + * @private + * @return {object.} + */ + _getHitsSearchParams: function(state) { + var facets = state.facets + .concat(state.disjunctiveFacets) + .concat(requestBuilder._getHitsHierarchicalFacetsAttributes(state)); + + + var facetFilters = requestBuilder._getFacetFilters(state); + var numericFilters = requestBuilder._getNumericFilters(state); + var tagFilters = requestBuilder._getTagFilters(state); + var additionalParams = { + facets: facets.indexOf('*') > -1 ? ['*'] : facets, + tagFilters: tagFilters + }; + + if (facetFilters.length > 0) { + additionalParams.facetFilters = facetFilters; + } + + if (numericFilters.length > 0) { + additionalParams.numericFilters = numericFilters; + } + + return sortObject(merge({}, state.getQueryParams(), additionalParams)); + }, + + /** + * Build search parameters used to fetch a disjunctive facet + * @private + * @param {string} facet the associated facet name + * @param {boolean} hierarchicalRootLevel ?? FIXME + * @return {object} + */ + _getDisjunctiveFacetSearchParams: function(state, facet, hierarchicalRootLevel) { + var facetFilters = requestBuilder._getFacetFilters(state, facet, hierarchicalRootLevel); + var numericFilters = requestBuilder._getNumericFilters(state, facet); + var tagFilters = requestBuilder._getTagFilters(state); + var additionalParams = { + hitsPerPage: 0, + page: 0, + analytics: false, + clickAnalytics: false + }; + + if (tagFilters.length > 0) { + additionalParams.tagFilters = tagFilters; + } + + var hierarchicalFacet = state.getHierarchicalFacetByName(facet); + + if (hierarchicalFacet) { + additionalParams.facets = requestBuilder._getDisjunctiveHierarchicalFacetAttribute( + state, + hierarchicalFacet, + hierarchicalRootLevel + ); + } else { + additionalParams.facets = facet; + } + + if (numericFilters.length > 0) { + additionalParams.numericFilters = numericFilters; + } + + if (facetFilters.length > 0) { + additionalParams.facetFilters = facetFilters; + } + + return sortObject(merge({}, state.getQueryParams(), additionalParams)); + }, + + /** + * Return the numeric filters in an algolia request fashion + * @private + * @param {string} [facetName] the name of the attribute for which the filters should be excluded + * @return {string[]} the numeric filters in the algolia format + */ + _getNumericFilters: function(state, facetName) { + if (state.numericFilters) { + return state.numericFilters; + } + + var numericFilters = []; + + Object.keys(state.numericRefinements).forEach(function(attribute) { + var operators = state.numericRefinements[attribute] || {}; + Object.keys(operators).forEach(function(operator) { + var values = operators[operator] || []; + if (facetName !== attribute) { + values.forEach(function(value) { + if (Array.isArray(value)) { + var vs = value.map(function(v) { + return attribute + operator + v; + }); + numericFilters.push(vs); + } else { + numericFilters.push(attribute + operator + value); + } + }); + } + }); + }); + + return numericFilters; + }, + + /** + * Return the tags filters depending + * @private + * @return {string} + */ + _getTagFilters: function(state) { + if (state.tagFilters) { + return state.tagFilters; + } + + return state.tagRefinements.join(','); + }, + + + /** + * Build facetFilters parameter based on current refinements. The array returned + * contains strings representing the facet filters in the algolia format. + * @private + * @param {string} [facet] if set, the current disjunctive facet + * @return {array.} + */ + _getFacetFilters: function(state, facet, hierarchicalRootLevel) { + var facetFilters = []; + + var facetsRefinements = state.facetsRefinements || {}; + Object.keys(facetsRefinements).forEach(function(facetName) { + var facetValues = facetsRefinements[facetName] || []; + facetValues.forEach(function(facetValue) { + facetFilters.push(facetName + ':' + facetValue); + }); + }); + + var facetsExcludes = state.facetsExcludes || {}; + Object.keys(facetsExcludes).forEach(function(facetName) { + var facetValues = facetsExcludes[facetName] || []; + facetValues.forEach(function(facetValue) { + facetFilters.push(facetName + ':-' + facetValue); + }); + }); + + var disjunctiveFacetsRefinements = state.disjunctiveFacetsRefinements || {}; + Object.keys(disjunctiveFacetsRefinements).forEach(function(facetName) { + var facetValues = disjunctiveFacetsRefinements[facetName] || []; + if (facetName === facet || !facetValues || facetValues.length === 0) { + return; + } + var orFilters = []; + + facetValues.forEach(function(facetValue) { + orFilters.push(facetName + ':' + facetValue); + }); + + facetFilters.push(orFilters); + }); + + var hierarchicalFacetsRefinements = state.hierarchicalFacetsRefinements || {}; + Object.keys(hierarchicalFacetsRefinements).forEach(function(facetName) { + var facetValues = hierarchicalFacetsRefinements[facetName] || []; + var facetValue = facetValues[0]; + + if (facetValue === undefined) { + return; + } + + var hierarchicalFacet = state.getHierarchicalFacetByName(facetName); + var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet); + var rootPath = state._getHierarchicalRootPath(hierarchicalFacet); + var attributeToRefine; + var attributesIndex; + + // we ask for parent facet values only when the `facet` is the current hierarchical facet + if (facet === facetName) { + // if we are at the root level already, no need to ask for facet values, we get them from + // the hits query + if (facetValue.indexOf(separator) === -1 || (!rootPath && hierarchicalRootLevel === true) || + (rootPath && rootPath.split(separator).length === facetValue.split(separator).length)) { + return; + } + + if (!rootPath) { + attributesIndex = facetValue.split(separator).length - 2; + facetValue = facetValue.slice(0, facetValue.lastIndexOf(separator)); + } else { + attributesIndex = rootPath.split(separator).length - 1; + facetValue = rootPath; + } + + attributeToRefine = hierarchicalFacet.attributes[attributesIndex]; + } else { + attributesIndex = facetValue.split(separator).length - 1; + + attributeToRefine = hierarchicalFacet.attributes[attributesIndex]; + } + + if (attributeToRefine) { + facetFilters.push([attributeToRefine + ':' + facetValue]); + } + }); + + return facetFilters; + }, + + _getHitsHierarchicalFacetsAttributes: function(state) { + var out = []; + + return state.hierarchicalFacets.reduce( + // ask for as much levels as there's hierarchical refinements + function getHitsAttributesForHierarchicalFacet(allAttributes, hierarchicalFacet) { + var hierarchicalRefinement = state.getHierarchicalRefinement(hierarchicalFacet.name)[0]; + + // if no refinement, ask for root level + if (!hierarchicalRefinement) { + allAttributes.push(hierarchicalFacet.attributes[0]); + return allAttributes; + } + + var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet); + var level = hierarchicalRefinement.split(separator).length; + var newAttributes = hierarchicalFacet.attributes.slice(0, level + 1); + + return allAttributes.concat(newAttributes); + }, out); + }, + + _getDisjunctiveHierarchicalFacetAttribute: function(state, hierarchicalFacet, rootLevel) { + var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet); + if (rootLevel === true) { + var rootPath = state._getHierarchicalRootPath(hierarchicalFacet); + var attributeIndex = 0; + + if (rootPath) { + attributeIndex = rootPath.split(separator).length; + } + return [hierarchicalFacet.attributes[attributeIndex]]; + } + + var hierarchicalRefinement = state.getHierarchicalRefinement(hierarchicalFacet.name)[0] || ''; + // if refinement is 'beers > IPA > Flying dog', + // then we want `facets: ['beers > IPA']` as disjunctive facet (parent level values) + + var parentLevel = hierarchicalRefinement.split(separator).length - 1; + return hierarchicalFacet.attributes.slice(0, parentLevel + 1); + }, + + getSearchForFacetQuery: function(facetName, query, maxFacetHits, state) { + var stateForSearchForFacetValues = state.isDisjunctiveFacet(facetName) ? + state.clearRefinements(facetName) : + state; + var searchForFacetSearchParameters = { + facetQuery: query, + facetName: facetName + }; + if (typeof maxFacetHits === 'number') { + searchForFacetSearchParameters.maxFacetHits = maxFacetHits; + } + return sortObject(merge( + {}, + requestBuilder._getHitsSearchParams(stateForSearchForFacetValues), + searchForFacetSearchParameters + )); + } +}; + +module.exports = requestBuilder; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/utils/isValidUserToken.js": +/*!*************************************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/utils/isValidUserToken.js ***! + \*************************************************************************/ +/***/ ((module) => { + +"use strict"; + + +module.exports = function isValidUserToken(userToken) { + if (userToken === null) { + return false; + } + return /^[a-zA-Z0-9_-]{1,64}$/.test(userToken); +}; + + +/***/ }), + +/***/ "./node_modules/algoliasearch-helper/src/version.js": +/*!**********************************************************!*\ + !*** ./node_modules/algoliasearch-helper/src/version.js ***! + \**********************************************************/ +/***/ ((module) => { + +"use strict"; + + +module.exports = '3.12.0'; + + +/***/ }), + +/***/ "./node_modules/algoliasearch/dist/algoliasearch.umd.js": +/*!**************************************************************!*\ + !*** ./node_modules/algoliasearch/dist/algoliasearch.umd.js ***! + \**************************************************************/ +/***/ (function(module) { + +/*! algoliasearch.umd.js | 4.17.0 | © Algolia, inc. | https://github.com/algolia/algoliasearch-client-javascript */ +!function(t,e){ true?module.exports=e():0}(this,(function(){"use strict";function t(t,e,r){return e in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function e(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),r.push.apply(r,n)}return r}function r(r){for(var n=1;n=0||(a[r]=t[r]);return a}(t,e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(t);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(t,r)&&(a[r]=t[r])}return a}function a(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){if(!(Symbol.iterator in Object(t)||"[object Arguments]"===Object.prototype.toString.call(t)))return;var r=[],n=!0,a=!1,o=void 0;try{for(var i,u=t[Symbol.iterator]();!(n=(i=u.next()).done)&&(r.push(i.value),!e||r.length!==e);n=!0);}catch(t){a=!0,o=t}finally{try{n||null==u.return||u.return()}finally{if(a)throw o}}return r}(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance")}()}function o(t){return function(t){if(Array.isArray(t)){for(var e=0,r=new Array(t.length);e2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}};return Promise.resolve().then((function(){var r=JSON.stringify(t),n=o()[r];return Promise.all([n||e(),void 0!==n])})).then((function(t){var e=a(t,2),n=e[0],o=e[1];return Promise.all([n,o||r.miss(n)])})).then((function(t){return a(t,1)[0]}))},set:function(t,e){return Promise.resolve().then((function(){var a=o();return a[JSON.stringify(t)]=e,n().setItem(r,JSON.stringify(a)),e}))},delete:function(t){return Promise.resolve().then((function(){var e=o();delete e[JSON.stringify(t)],n().setItem(r,JSON.stringify(e))}))},clear:function(){return Promise.resolve().then((function(){n().removeItem(r)}))}}}function u(t){var e=o(t.caches),r=e.shift();return void 0===r?{get:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}},n=e();return n.then((function(t){return Promise.all([t,r.miss(t)])})).then((function(t){return a(t,1)[0]}))},set:function(t,e){return Promise.resolve(e)},delete:function(t){return Promise.resolve()},clear:function(){return Promise.resolve()}}:{get:function(t,n){var a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}};return r.get(t,n,a).catch((function(){return u({caches:e}).get(t,n,a)}))},set:function(t,n){return r.set(t,n).catch((function(){return u({caches:e}).set(t,n)}))},delete:function(t){return r.delete(t).catch((function(){return u({caches:e}).delete(t)}))},clear:function(){return r.clear().catch((function(){return u({caches:e}).clear()}))}}}function s(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{serializable:!0},e={};return{get:function(r,n){var a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}},o=JSON.stringify(r);if(o in e)return Promise.resolve(t.serializable?JSON.parse(e[o]):e[o]);var i=n(),u=a&&a.miss||function(){return Promise.resolve()};return i.then((function(t){return u(t)})).then((function(){return i}))},set:function(r,n){return e[JSON.stringify(r)]=t.serializable?JSON.stringify(n):n,Promise.resolve(n)},delete:function(t){return delete e[JSON.stringify(t)],Promise.resolve()},clear:function(){return e={},Promise.resolve()}}}function c(t,e,r){var n={"x-algolia-api-key":r,"x-algolia-application-id":e};return{headers:function(){return t===m.WithinHeaders?n:{}},queryParameters:function(){return t===m.WithinQueryParameters?n:{}}}}function f(t){var e=0;return t((function r(){return e++,new Promise((function(n){setTimeout((function(){n(t(r))}),Math.min(100*e,1e3))}))}))}function d(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:function(t,e){return Promise.resolve()};return Object.assign(t,{wait:function(r){return d(t.then((function(t){return Promise.all([e(t,r),t])})).then((function(t){return t[1]})))}})}function l(t){for(var e=t.length-1;e>0;e--){var r=Math.floor(Math.random()*(e+1)),n=t[e];t[e]=t[r],t[r]=n}return t}function p(t,e){return e?(Object.keys(e).forEach((function(r){t[r]=e[r](t)})),t):t}function h(t){for(var e=arguments.length,r=new Array(e>1?e-1:0),n=1;n0?n:void 0,timeout:r.timeout||e,headers:r.headers||{},queryParameters:r.queryParameters||{},cacheable:r.cacheable}}var g={Read:1,Write:2,Any:3},v=1,b=2,P=3;function w(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:v;return r(r({},t),{},{status:e,lastUpdate:Date.now()})}function O(t){return"string"==typeof t?{protocol:"https",url:t,accept:g.Any}:{protocol:t.protocol||"https",url:t.url,accept:t.accept||g.Any}}var I="DELETE",x="GET",j="POST",D="PUT";function q(t,e){return Promise.all(e.map((function(e){return t.get(e,(function(){return Promise.resolve(w(e))}))}))).then((function(t){var r=t.filter((function(t){return function(t){return t.status===v||Date.now()-t.lastUpdate>12e4}(t)})),n=t.filter((function(t){return function(t){return t.status===P&&Date.now()-t.lastUpdate<=12e4}(t)})),a=[].concat(o(r),o(n));return{getTimeout:function(t,e){return(0===n.length&&0===t?1:n.length+3+t)*e},statelessHosts:a.length>0?a.map((function(t){return O(t)})):e}}))}function S(t,e,n,a){var i=[],u=function(t,e){if(t.method===x||void 0===t.data&&void 0===e.data)return;var n=Array.isArray(t.data)?t.data:r(r({},t.data),e.data);return JSON.stringify(n)}(n,a),s=function(t,e){var n=r(r({},t.headers),e.headers),a={};return Object.keys(n).forEach((function(t){var e=n[t];a[t.toLowerCase()]=e})),a}(t,a),c=n.method,f=n.method!==x?{}:r(r({},n.data),a.data),d=r(r(r({"x-algolia-agent":t.userAgent.value},t.queryParameters),f),a.queryParameters),l=0,p=function e(r,o){var f=r.pop();if(void 0===f)throw{name:"RetryError",message:"Unreachable hosts - your application id may be incorrect. If the error persists, contact support@algolia.com.",transporterStackTrace:R(i)};var p={data:u,headers:s,method:c,url:N(f,n.path,d),connectTimeout:o(l,t.timeouts.connect),responseTimeout:o(l,a.timeout)},h=function(t){var e={request:p,response:t,host:f,triesLeft:r.length};return i.push(e),e},m={onSuccess:function(t){return function(t){try{return JSON.parse(t.content)}catch(e){throw function(t,e){return{name:"DeserializationError",message:t,response:e}}(e.message,t)}}(t)},onRetry:function(n){var a=h(n);return n.isTimedOut&&l++,Promise.all([t.logger.info("Retryable failure",A(a)),t.hostsCache.set(f,w(f,n.isTimedOut?P:b))]).then((function(){return e(r,o)}))},onFail:function(t){throw h(t),function(t,e){var r=t.content,n=t.status,a=r;try{a=JSON.parse(r).message}catch(t){}return function(t,e,r){return{name:"ApiError",message:t,status:e,transporterStackTrace:r}}(a,n,e)}(t,R(i))}};return t.requester.send(p).then((function(t){return function(t,e){return function(t){var e=t.status;return t.isTimedOut||function(t){var e=t.isTimedOut,r=t.status;return!e&&0==~~r}(t)||2!=~~(e/100)&&4!=~~(e/100)}(t)?e.onRetry(t):2==~~(t.status/100)?e.onSuccess(t):e.onFail(t)}(t,m)}))};return q(t.hostsCache,e).then((function(t){return p(o(t.statelessHosts).reverse(),t.getTimeout)}))}function k(t){var e=t.hostsCache,r=t.logger,n=t.requester,o=t.requestsCache,i=t.responsesCache,u=t.timeouts,s=t.userAgent,c=t.hosts,f=t.queryParameters,d={hostsCache:e,logger:r,requester:n,requestsCache:o,responsesCache:i,timeouts:u,userAgent:s,headers:t.headers,queryParameters:f,hosts:c.map((function(t){return O(t)})),read:function(t,e){var r=y(e,d.timeouts.read),n=function(){return S(d,d.hosts.filter((function(t){return 0!=(t.accept&g.Read)})),t,r)};if(!0!==(void 0!==r.cacheable?r.cacheable:t.cacheable))return n();var o={request:t,mappedRequestOptions:r,transporter:{queryParameters:d.queryParameters,headers:d.headers}};return d.responsesCache.get(o,(function(){return d.requestsCache.get(o,(function(){return d.requestsCache.set(o,n()).then((function(t){return Promise.all([d.requestsCache.delete(o),t])}),(function(t){return Promise.all([d.requestsCache.delete(o),Promise.reject(t)])})).then((function(t){var e=a(t,2);e[0];return e[1]}))}))}),{miss:function(t){return d.responsesCache.set(o,t)}})},write:function(t,e){return S(d,d.hosts.filter((function(t){return 0!=(t.accept&g.Write)})),t,y(e,d.timeouts.write))}};return d}function T(t){var e={value:"Algolia for JavaScript (".concat(t,")"),add:function(t){var r="; ".concat(t.segment).concat(void 0!==t.version?" (".concat(t.version,")"):"");return-1===e.value.indexOf(r)&&(e.value="".concat(e.value).concat(r)),e}};return e}function N(t,e,r){var n=E(r),a="".concat(t.protocol,"://").concat(t.url,"/").concat("/"===e.charAt(0)?e.substr(1):e);return n.length&&(a+="?".concat(n)),a}function E(t){return Object.keys(t).map((function(e){return h("%s=%s",e,(r=t[e],"[object Object]"===Object.prototype.toString.call(r)||"[object Array]"===Object.prototype.toString.call(r)?JSON.stringify(t[e]):t[e]));var r})).join("&")}function R(t){return t.map((function(t){return A(t)}))}function A(t){var e=t.request.headers["x-algolia-api-key"]?{"x-algolia-api-key":"*****"}:{};return r(r({},t),{},{request:r(r({},t.request),{},{headers:r(r({},t.request.headers),e)})})}var C=function(t){return function(e,r){return t.transporter.write({method:j,path:"2/abtests",data:e},r)}},U=function(t){return function(e,r){return t.transporter.write({method:I,path:h("2/abtests/%s",e)},r)}},z=function(t){return function(e,r){return t.transporter.read({method:x,path:h("2/abtests/%s",e)},r)}},J=function(t){return function(e){return t.transporter.read({method:x,path:"2/abtests"},e)}},F=function(t){return function(e,r){return t.transporter.write({method:j,path:h("2/abtests/%s/stop",e)},r)}},H=function(t){return function(e){return t.transporter.read({method:x,path:"1/strategies/personalization"},e)}},M=function(t){return function(e,r){return t.transporter.write({method:j,path:"1/strategies/personalization",data:e},r)}};function K(t){return function e(r){return t.request(r).then((function(n){if(void 0!==t.batch&&t.batch(n.hits),!t.shouldStop(n))return n.cursor?e({cursor:n.cursor}):e({page:(r.page||0)+1})}))}({})}var W=function(t){return function(e,a){var o=a||{},i=o.queryParameters,u=n(o,["queryParameters"]),s=r({acl:e},void 0!==i?{queryParameters:i}:{});return d(t.transporter.write({method:j,path:"1/keys",data:s},u),(function(e,r){return f((function(n){return tt(t)(e.key,r).catch((function(t){if(404!==t.status)throw t;return n()}))}))}))}},B=function(t){return function(e,r,n){var a=y(n);return a.queryParameters["X-Algolia-User-ID"]=e,t.transporter.write({method:j,path:"1/clusters/mapping",data:{cluster:r}},a)}},Q=function(t){return function(e,r,n){return t.transporter.write({method:j,path:"1/clusters/mapping/batch",data:{users:e,cluster:r}},n)}},G=function(t){return function(e,r){return d(t.transporter.write({method:j,path:h("/1/dictionaries/%s/batch",e),data:{clearExistingDictionaryEntries:!0,requests:{action:"addEntry",body:[]}}},r),(function(e,r){return jt(t)(e.taskID,r)}))}},L=function(t){return function(e,r,n){return d(t.transporter.write({method:j,path:h("1/indexes/%s/operation",e),data:{operation:"copy",destination:r}},n),(function(r,n){return ut(t)(e,{methods:{waitTask:de}}).waitTask(r.taskID,n)}))}},V=function(t){return function(e,n,a){return L(t)(e,n,r(r({},a),{},{scope:[pe.Rules]}))}},_=function(t){return function(e,n,a){return L(t)(e,n,r(r({},a),{},{scope:[pe.Settings]}))}},X=function(t){return function(e,n,a){return L(t)(e,n,r(r({},a),{},{scope:[pe.Synonyms]}))}},Y=function(t){return function(e,r){return e.method===x?t.transporter.read(e,r):t.transporter.write(e,r)}},Z=function(t){return function(e,r){return d(t.transporter.write({method:I,path:h("1/keys/%s",e)},r),(function(r,n){return f((function(r){return tt(t)(e,n).then(r).catch((function(t){if(404!==t.status)throw t}))}))}))}},$=function(t){return function(e,r,n){var a=r.map((function(t){return{action:"deleteEntry",body:{objectID:t}}}));return d(t.transporter.write({method:j,path:h("/1/dictionaries/%s/batch",e),data:{clearExistingDictionaryEntries:!1,requests:a}},n),(function(e,r){return jt(t)(e.taskID,r)}))}},tt=function(t){return function(e,r){return t.transporter.read({method:x,path:h("1/keys/%s",e)},r)}},et=function(t){return function(e,r){return t.transporter.read({method:x,path:h("1/task/%s",e.toString())},r)}},rt=function(t){return function(e){return t.transporter.read({method:x,path:"/1/dictionaries/*/settings"},e)}},nt=function(t){return function(e){return t.transporter.read({method:x,path:"1/logs"},e)}},at=function(t){return function(e){return t.transporter.read({method:x,path:"1/clusters/mapping/top"},e)}},ot=function(t){return function(e,r){return t.transporter.read({method:x,path:h("1/clusters/mapping/%s",e)},r)}},it=function(t){return function(e){var r=e||{},a=r.retrieveMappings,o=n(r,["retrieveMappings"]);return!0===a&&(o.getClusters=!0),t.transporter.read({method:x,path:"1/clusters/mapping/pending"},o)}},ut=function(t){return function(e){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n={transporter:t.transporter,appId:t.appId,indexName:e};return p(n,r.methods)}},st=function(t){return function(e){return t.transporter.read({method:x,path:"1/keys"},e)}},ct=function(t){return function(e){return t.transporter.read({method:x,path:"1/clusters"},e)}},ft=function(t){return function(e){return t.transporter.read({method:x,path:"1/indexes"},e)}},dt=function(t){return function(e){return t.transporter.read({method:x,path:"1/clusters/mapping"},e)}},lt=function(t){return function(e,r,n){return d(t.transporter.write({method:j,path:h("1/indexes/%s/operation",e),data:{operation:"move",destination:r}},n),(function(r,n){return ut(t)(e,{methods:{waitTask:de}}).waitTask(r.taskID,n)}))}},pt=function(t){return function(e,r){return d(t.transporter.write({method:j,path:"1/indexes/*/batch",data:{requests:e}},r),(function(e,r){return Promise.all(Object.keys(e.taskID).map((function(n){return ut(t)(n,{methods:{waitTask:de}}).waitTask(e.taskID[n],r)})))}))}},ht=function(t){return function(e,r){return t.transporter.read({method:j,path:"1/indexes/*/objects",data:{requests:e}},r)}},mt=function(t){return function(e,n){var a=e.map((function(t){return r(r({},t),{},{params:E(t.params||{})})}));return t.transporter.read({method:j,path:"1/indexes/*/queries",data:{requests:a},cacheable:!0},n)}},yt=function(t){return function(e,a){return Promise.all(e.map((function(e){var o=e.params,i=o.facetName,u=o.facetQuery,s=n(o,["facetName","facetQuery"]);return ut(t)(e.indexName,{methods:{searchForFacetValues:ue}}).searchForFacetValues(i,u,r(r({},a),s))})))}},gt=function(t){return function(e,r){var n=y(r);return n.queryParameters["X-Algolia-User-ID"]=e,t.transporter.write({method:I,path:"1/clusters/mapping"},n)}},vt=function(t){return function(e,r,n){var a=r.map((function(t){return{action:"addEntry",body:t}}));return d(t.transporter.write({method:j,path:h("/1/dictionaries/%s/batch",e),data:{clearExistingDictionaryEntries:!0,requests:a}},n),(function(e,r){return jt(t)(e.taskID,r)}))}},bt=function(t){return function(e,r){return d(t.transporter.write({method:j,path:h("1/keys/%s/restore",e)},r),(function(r,n){return f((function(r){return tt(t)(e,n).catch((function(t){if(404!==t.status)throw t;return r()}))}))}))}},Pt=function(t){return function(e,r,n){var a=r.map((function(t){return{action:"addEntry",body:t}}));return d(t.transporter.write({method:j,path:h("/1/dictionaries/%s/batch",e),data:{clearExistingDictionaryEntries:!1,requests:a}},n),(function(e,r){return jt(t)(e.taskID,r)}))}},wt=function(t){return function(e,r,n){return t.transporter.read({method:j,path:h("/1/dictionaries/%s/search",e),data:{query:r},cacheable:!0},n)}},Ot=function(t){return function(e,r){return t.transporter.read({method:j,path:"1/clusters/mapping/search",data:{query:e}},r)}},It=function(t){return function(e,r){return d(t.transporter.write({method:D,path:"/1/dictionaries/*/settings",data:e},r),(function(e,r){return jt(t)(e.taskID,r)}))}},xt=function(t){return function(e,r){var a=Object.assign({},r),o=r||{},i=o.queryParameters,u=n(o,["queryParameters"]),s=i?{queryParameters:i}:{},c=["acl","indexes","referers","restrictSources","queryParameters","description","maxQueriesPerIPPerHour","maxHitsPerQuery"];return d(t.transporter.write({method:D,path:h("1/keys/%s",e),data:s},u),(function(r,n){return f((function(r){return tt(t)(e,n).then((function(t){return function(t){return Object.keys(a).filter((function(t){return-1!==c.indexOf(t)})).every((function(e){return t[e]===a[e]}))}(t)?Promise.resolve():r()}))}))}))}},jt=function(t){return function(e,r){return f((function(n){return et(t)(e,r).then((function(t){return"published"!==t.status?n():void 0}))}))}},Dt=function(t){return function(e,r){return d(t.transporter.write({method:j,path:h("1/indexes/%s/batch",t.indexName),data:{requests:e}},r),(function(e,r){return de(t)(e.taskID,r)}))}},qt=function(t){return function(e){return K(r(r({shouldStop:function(t){return void 0===t.cursor}},e),{},{request:function(r){return t.transporter.read({method:j,path:h("1/indexes/%s/browse",t.indexName),data:r},e)}}))}},St=function(t){return function(e){var n=r({hitsPerPage:1e3},e);return K(r(r({shouldStop:function(t){return t.hits.length0&&void 0!==arguments[0]?arguments[0]:0,c=[];for(a=o;a=t.nbPages)throw{name:"ObjectNotFoundError",message:"Object not found."};return n()}))}()}},Wt=function(t){return function(e,r){return t.transporter.read({method:x,path:h("1/indexes/%s/%s",t.indexName,e)},r)}},Bt=function(){return function(t,e){for(var r=0,n=Object.entries(t.hits);rr.OPENED&&void 0===n&&(clearTimeout(o),n=a(t.responseTimeout,"Socket timeout"))},r.onerror=function(){0===r.status&&(clearTimeout(o),clearTimeout(n),e({content:r.responseText||"Network request failed",status:r.status,isTimedOut:!1}))},r.onload=function(){clearTimeout(o),clearTimeout(n),e({content:r.responseText,status:r.status,isTimedOut:!1})},r.send(t.data)}))}},logger:(a=ye,{debug:function(t,e){return he>=a&&console.debug(t,e),Promise.resolve()},info:function(t,e){return me>=a&&console.info(t,e),Promise.resolve()},error:function(t,e){return console.error(t,e),Promise.resolve()}}),responsesCache:s(),requestsCache:s({serializable:!1}),hostsCache:u({caches:[i({key:"".concat("4.17.0","-").concat(t)}),s()]}),userAgent:T("4.17.0").add({segment:"Browser"})},f=r(r({},o),n),d=function(){return function(t){return function(t){var e=t.region||"us",n=c(m.WithinHeaders,t.appId,t.apiKey),a=k(r(r({hosts:[{url:"personalization.".concat(e,".algolia.com")}]},t),{},{headers:r(r(r({},n.headers()),{"content-type":"application/json"}),t.headers),queryParameters:r(r({},n.queryParameters()),t.queryParameters)}));return p({appId:t.appId,transporter:a},t.methods)}(r(r(r({},o),t),{},{methods:{getPersonalizationStrategy:H,setPersonalizationStrategy:M}}))}};return function(t){var e=t.appId,n=c(void 0!==t.authMode?t.authMode:m.WithinHeaders,e,t.apiKey),a=k(r(r({hosts:[{url:"".concat(e,"-dsn.algolia.net"),accept:g.Read},{url:"".concat(e,".algolia.net"),accept:g.Write}].concat(l([{url:"".concat(e,"-1.algolianet.com")},{url:"".concat(e,"-2.algolianet.com")},{url:"".concat(e,"-3.algolianet.com")}]))},t),{},{headers:r(r(r({},n.headers()),{"content-type":"application/x-www-form-urlencoded"}),t.headers),queryParameters:r(r({},n.queryParameters()),t.queryParameters)}));return p({transporter:a,appId:e,addAlgoliaAgent:function(t,e){a.userAgent.add({segment:t,version:e})},clearCache:function(){return Promise.all([a.requestsCache.clear(),a.responsesCache.clear()]).then((function(){}))}},t.methods)}(r(r({},f),{},{methods:{search:mt,searchForFacetValues:yt,multipleBatch:pt,multipleGetObjects:ht,multipleQueries:mt,copyIndex:L,copySettings:_,copySynonyms:X,copyRules:V,moveIndex:lt,listIndices:ft,getLogs:nt,listClusters:ct,multipleSearchForFacetValues:yt,getApiKey:tt,addApiKey:W,listApiKeys:st,updateApiKey:xt,deleteApiKey:Z,restoreApiKey:bt,assignUserID:B,assignUserIDs:Q,getUserID:ot,searchUserIDs:Ot,listUserIDs:dt,getTopUserIDs:at,removeUserID:gt,hasPendingMappings:it,clearDictionaryEntries:G,deleteDictionaryEntries:$,getDictionarySettings:rt,getAppTask:et,replaceDictionaryEntries:vt,saveDictionaryEntries:Pt,searchDictionaryEntries:wt,setDictionarySettings:It,waitAppTask:jt,customRequest:Y,initIndex:function(t){return function(e){return ut(t)(e,{methods:{batch:Dt,delete:Ct,findAnswers:Mt,getObject:Wt,getObjects:Qt,saveObject:te,saveObjects:ee,search:ie,searchForFacetValues:ue,waitTask:de,setSettings:fe,getSettings:Lt,partialUpdateObject:_t,partialUpdateObjects:Xt,deleteObject:Ut,deleteObjects:zt,deleteBy:At,clearObjects:Nt,browseObjects:qt,getObjectPosition:Bt,findObject:Kt,exists:Ht,saveSynonym:ae,saveSynonyms:oe,getSynonym:Vt,searchSynonyms:ce,browseSynonyms:kt,deleteSynonym:Ft,clearSynonyms:Rt,replaceAllObjects:Yt,replaceAllSynonyms:$t,searchRules:se,getRule:Gt,deleteRule:Jt,saveRule:re,saveRules:ne,replaceAllRules:Zt,browseRules:St,clearRules:Et}})}},initAnalytics:function(){return function(t){return function(t){var e=t.region||"us",n=c(m.WithinHeaders,t.appId,t.apiKey),a=k(r(r({hosts:[{url:"analytics.".concat(e,".algolia.com")}]},t),{},{headers:r(r(r({},n.headers()),{"content-type":"application/json"}),t.headers),queryParameters:r(r({},n.queryParameters()),t.queryParameters)}));return p({appId:t.appId,transporter:a},t.methods)}(r(r(r({},o),t),{},{methods:{addABTest:C,getABTest:z,getABTests:J,stopABTest:F,deleteABTest:U}}))}},initPersonalization:d,initRecommendation:function(){return function(t){return f.logger.info("The `initRecommendation` method is deprecated. Use `initPersonalization` instead."),d()(t)}}}}))}return ge.version="4.17.0",ge})); + + +/***/ }), + +/***/ "./src/components/AlgoliaResult.js": +/*!*****************************************!*\ + !*** ./src/components/AlgoliaResult.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "AlgoliaResult": () => (/* binding */ AlgoliaResult) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _icons_go_svg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../icons/go.svg */ "./src/icons/go.svg"); + + +const AlgoliaResult = _ref => { + let { + searchTitle, + onGo + } = _ref; + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "algoliaResult", + onClick: onGo + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, searchTitle), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "svg" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_go_svg__WEBPACK_IMPORTED_MODULE_1__.ReactComponent, null)))); +}; + +/***/ }), + +/***/ "./src/components/Feedback.js": +/*!************************************!*\ + !*** ./src/components/Feedback.js ***! + \************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "@wordpress/i18n"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../utils */ "./src/utils.js"); + + + +// + +const Feedback = _ref => { + let { + postId + } = _ref; + const [status, setStatus] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(""); + const yesButtonRef = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)(null); + const noButtonRef = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useRef)(null); + const postFeedback = async () => { + if (status === "helpful" || status === "notHelpful") { + _utils__WEBPACK_IMPORTED_MODULE_2__.InteractionAPIs.postFeedback(postId, status); + _utils__WEBPACK_IMPORTED_MODULE_2__.Analytics.sendEvent('feedback', 'status'); + } + }; + (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => { + setStatus(""); + noButtonRef.current.className = "feedback-button no"; + yesButtonRef.current.className = "feedback-button yes"; + }, [postId]); + (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => { + postFeedback(); + if (status === "helpful") { + yesButtonRef.current.className = "feedback-button yes selected-yes"; + noButtonRef.current.className = "feedback-button no"; + } + if (status === "notHelpful") { + noButtonRef.current.className = "feedback-button no selected-no"; + yesButtonRef.current.className = "feedback-button yes"; + } + }, [status]); + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "feedback-container" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("b", null, (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Did this result help you ?', 'wp-module-help-center')))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + class: "icon" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", { + ref: yesButtonRef, + onClick: () => { + setStatus("helpful"); + }, + class: "feedback-button yes" + }, status === "helpful" && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, "\uD83E\uDD73"), " Yes"), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", { + onClick: () => { + setStatus("notHelpful"); + }, + ref: noButtonRef, + class: "feedback-button no" + }, status === "notHelpful" && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, "\uD83D\uDE2D"), " No"))); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Feedback); + +/***/ }), + +/***/ "./src/components/HelpCenter.js": +/*!**************************************!*\ + !*** ./src/components/HelpCenter.js ***! + \**************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _SearchResults__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./SearchResults */ "./src/components/SearchResults.js"); +/* harmony import */ var algoliasearch__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! algoliasearch */ "./node_modules/algoliasearch/dist/algoliasearch.umd.js"); +/* harmony import */ var algoliasearch__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(algoliasearch__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! react-instantsearch-hooks-web */ "./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearch.js"); +/* harmony import */ var react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! react-instantsearch-hooks-web */ "./node_modules/react-instantsearch-hooks/dist/es/components/Index.js"); +/* harmony import */ var react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! react-instantsearch-hooks-web */ "./node_modules/react-instantsearch-hooks/dist/es/components/Configure.js"); + + + + +const HelpCenter = props => { + // Set up the instant search results + const searchClient = algoliasearch__WEBPACK_IMPORTED_MODULE_2___default()("AVE0JWZU92", "eef54890add97ea2583ff1e417ff86ea"); + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "nfd-help-center" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_3__.InstantSearch, { + searchClient: searchClient, + indexName: "nfd_help_searchable_posts" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_4__.Index, { + indexName: "nfd_help_searchable_posts" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_5__.Configure, { + hitsPerPage: 3, + getRankingInfo: true + }), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_SearchResults__WEBPACK_IMPORTED_MODULE_1__["default"], null)))); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (HelpCenter); + +/***/ }), + +/***/ "./src/components/Loader.js": +/*!**********************************!*\ + !*** ./src/components/Loader.js ***! + \**********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _icons_loader_svg__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../icons/loader.svg */ "./src/icons/loader.svg"); + + +const Loader = () => { + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_loader_svg__WEBPACK_IMPORTED_MODULE_1__.ReactComponent, null), " ", (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_loader_svg__WEBPACK_IMPORTED_MODULE_1__.ReactComponent, null), " ", (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_loader_svg__WEBPACK_IMPORTED_MODULE_1__.ReactComponent, null)); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Loader); + +/***/ }), + +/***/ "./src/components/Modal.js": +/*!*********************************!*\ + !*** ./src/components/Modal.js ***! + \*********************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "@wordpress/i18n"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _icons_close_svg__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../icons/close.svg */ "./src/icons/close.svg"); +/* harmony import */ var _icons_help_svg__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../icons/help.svg */ "./src/icons/help.svg"); +/* harmony import */ var _HelpCenter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./HelpCenter */ "./src/components/HelpCenter.js"); +/* harmony import */ var ___WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! .. */ "./src/index.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils */ "./src/utils.js"); + + + +// + + + + + +const Modal = _ref => { + let { + onClose + } = _ref; + (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => { + const helpVisible = _utils__WEBPACK_IMPORTED_MODULE_6__.LocalStorageUtils.getHelpVisible(); + (0,___WEBPACK_IMPORTED_MODULE_5__.toggleHelp)(helpVisible); + }, []); + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "modal" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "modal-header" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("h3", { + className: "heading" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", { + className: "icon" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_help_svg__WEBPACK_IMPORTED_MODULE_3__.ReactComponent, null)), (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Help Center', 'wp-module-help-center')), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", { + className: "close-button", + onClick: onClose + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "icon-button" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_close_svg__WEBPACK_IMPORTED_MODULE_2__.ReactComponent, null)))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_HelpCenter__WEBPACK_IMPORTED_MODULE_4__["default"], { + closeHelp: onClose + })); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Modal); + +/***/ }), + +/***/ "./src/components/NoResults.js": +/*!*************************************!*\ + !*** ./src/components/NoResults.js ***! + \*************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "@wordpress/i18n"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _icons_no_result_svg__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../icons/no-result.svg */ "./src/icons/no-result.svg"); + + + +const NoResults = () => { + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)("Result based on your search:", "wp-module-help-center")), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("h4", null, (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)("Sorry, we don't have any content for that yet.", "wp-module-help-center")), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("hr", null), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_no_result_svg__WEBPACK_IMPORTED_MODULE_2__.ReactComponent, null), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)("This tool is being built and doesn't always have a match.", "wp-module-help-center")), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)("In the meantime, try searching our", "wp-module-help-center"), " ", (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("a", { + href: "https://www.bluehost.com/help" + }, (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)("Resource center.", "wp-module-help-center"))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("hr", null)); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (NoResults); + +/***/ }), + +/***/ "./src/components/ResultContent.js": +/*!*****************************************!*\ + !*** ./src/components/ResultContent.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ResultContent": () => (/* binding */ ResultContent) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/i18n */ "@wordpress/i18n"); +/* harmony import */ var _wordpress_i18n__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Feedback__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Feedback */ "./src/components/Feedback.js"); +/* harmony import */ var _NoResults__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./NoResults */ "./src/components/NoResults.js"); + + +// + + +const ResultContent = _ref => { + let { + content, + noResult, + postId + } = _ref; + if (noResult) { + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_NoResults__WEBPACK_IMPORTED_MODULE_3__["default"], null); + } + if (content && content.length > 0) { + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("h4", null, (0,_wordpress_i18n__WEBPACK_IMPORTED_MODULE_1__.__)('Follow these steps:', 'wp-module-help-center')), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", { + dangerouslySetInnerHTML: { + __html: content + } + }), content && content.length > 0 && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_Feedback__WEBPACK_IMPORTED_MODULE_2__["default"], { + postId: postId + })); + } + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null); +}; + +/***/ }), + +/***/ "./src/components/SearchResults.js": +/*!*****************************************!*\ + !*** ./src/components/SearchResults.js ***! + \*****************************************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! lodash */ "lodash"); +/* harmony import */ var lodash__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(lodash__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! react-instantsearch-hooks-web */ "./node_modules/react-instantsearch-hooks/dist/es/connectors/useSearchBox.js"); +/* harmony import */ var react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! react-instantsearch-hooks-web */ "./node_modules/react-instantsearch-hooks/dist/es/hooks/useInstantSearch.js"); +/* harmony import */ var _newfold_labs_wp_module_ai__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @newfold-labs/wp-module-ai */ "./node_modules/@newfold-labs/wp-module-ai/index.js"); +/* harmony import */ var _icons_search_svg__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../icons/search.svg */ "./src/icons/search.svg"); +/* harmony import */ var _AlgoliaResult__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./AlgoliaResult */ "./src/components/AlgoliaResult.js"); +/* harmony import */ var _ResultContent__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./ResultContent */ "./src/components/ResultContent.js"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../utils */ "./src/utils.js"); +/* harmony import */ var _Loader__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./Loader */ "./src/components/Loader.js"); + + + + + +// + +// + + + + +const SearchResults = () => { + const [isLoading, setIsLoading] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(false); + const [noResult, setNoResult] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(false); + const [searchInput, setSearchInput] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(""); + const [resultContent, setResultContent] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(""); + const [postId, setPostId] = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useState)(); + const { + query, + refine, + clear + } = (0,react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_8__.useSearchBox)(); + const { + results + } = (0,react_instantsearch_hooks_web__WEBPACK_IMPORTED_MODULE_9__.useInstantSearch)(); + const populateSearchResult = (resultContent, postId, searchInput) => { + const resultContentFormatted = resultContent.replace(/\n/g, "

"); + setResultContent(resultContentFormatted); + setPostId(postId); + _utils__WEBPACK_IMPORTED_MODULE_6__.LocalStorageUtils.persistResult(resultContentFormatted, postId); + _utils__WEBPACK_IMPORTED_MODULE_6__.LocalStorageUtils.persistSearchInput(searchInput); + _utils__WEBPACK_IMPORTED_MODULE_6__.Analytics.sendEvent('search', postId); + }; + (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => { + // Populate the results from local storage if they exist + const { + content: currentResultContent, + postId: currentResultPostId + } = _utils__WEBPACK_IMPORTED_MODULE_6__.LocalStorageUtils.getResultInfo(); + if (currentResultContent) { + setResultContent(currentResultContent); + } + if (currentResultPostId) { + setPostId(currentResultPostId); + } + const input = _utils__WEBPACK_IMPORTED_MODULE_6__.LocalStorageUtils.getSearchInput(); + if (input) { + setSearchInput(input); + refine(input); + } + }, []); + const getResultMatches = (proximity, words) => { + return proximity / words >= 0.75; + }; + const getAIResult = async () => { + setIsLoading(true); + try { + // Check if the algolia results are close enough + const hits = results.hits; + const resultMatches = hits.length > 0 ? getResultMatches(hits[0]._rankingInfo.proximityDistance, hits[0]._rankingInfo.words) : false; + if (resultMatches) { + populateSearchResult(hits[0].content, hits[0].post_id, searchInput); + return; + } + const result = await _newfold_labs_wp_module_ai__WEBPACK_IMPORTED_MODULE_2__["default"].search.getSearchResult(query, "helpcenter"); + populateSearchResult(result["result"], result["post_id"], searchInput); + } catch (exception) { + console.log(exception); + setNoResult(true); + } finally { + setIsLoading(false); + } + }; + const debouncedResults = (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useMemo)(() => { + return (0,lodash__WEBPACK_IMPORTED_MODULE_1__.debounce)(function (query) { + if (query && query.length === 0) { + clear(); + } + refine(query); + }, 300); + }, []); + + // Clear any debounce problems + (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.useEffect)(() => { + debouncedResults.cancel(); + }, []); + if (isLoading) { + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_Loader__WEBPACK_IMPORTED_MODULE_7__["default"], null)); + } + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "search-container" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("button", { + onClick: () => { + document.getElementById("search-input-box").focus(); + } + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_search_svg__WEBPACK_IMPORTED_MODULE_3__.ReactComponent, null)), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("input", { + type: "text", + id: "search-input-box", + style: { + flexGrow: 2 + }, + value: searchInput, + maxLength: "144", + placeholder: "Ask me anything...", + onChange: e => { + setSearchInput(e.target.value); + populateSearchResult("", undefined, e.target.value); + setNoResult(false); + debouncedResults(e.target.value); + }, + onKeyDown: async e => { + if (e.key === "Enter") { + await getAIResult(); + } + } + })), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("div", { + className: "attribute" + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("span", null, searchInput ? searchInput.length : 0, "/144"))), (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_ResultContent__WEBPACK_IMPORTED_MODULE_5__.ResultContent, { + content: resultContent, + noResult: noResult, + postId: postId + }), results.hits.length > 0 && (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("p", null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)("b", null, resultContent.length > 0 ? "Other Resources" : "Search Suggestions")), results.hits.map(result => { + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_AlgoliaResult__WEBPACK_IMPORTED_MODULE_4__.AlgoliaResult, { + searchTitle: result.post_title, + onGo: () => { + setSearchInput(result.post_title); + populateSearchResult(result.content, result.post_id, result.post_title); + } + })); + })); +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (SearchResults); + +/***/ }), + +/***/ "./src/index.js": +/*!**********************!*\ + !*** ./src/index.js ***! + \**********************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "toggleHelp": () => (/* binding */ toggleHelp) +/* harmony export */ }); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @wordpress/element */ "@wordpress/element"); +/* harmony import */ var _wordpress_element__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_wordpress_element__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _wordpress_edit_post__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/edit-post */ "@wordpress/edit-post"); +/* harmony import */ var _wordpress_edit_post__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_edit_post__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _wordpress_plugins__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @wordpress/plugins */ "@wordpress/plugins"); +/* harmony import */ var _wordpress_plugins__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_wordpress_plugins__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var _newfold_labs_js_utility_ui_analytics__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! @newfold-labs/js-utility-ui-analytics */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/index.js"); +/* harmony import */ var _styles_scss__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../styles.scss */ "./styles.scss"); +/* harmony import */ var _components_HelpCenter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./components/HelpCenter */ "./src/components/HelpCenter.js"); +/* harmony import */ var _components_Modal__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./components/Modal */ "./src/components/Modal.js"); +/* harmony import */ var _icons_help_svg__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./icons/help.svg */ "./src/icons/help.svg"); +/* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./utils */ "./src/utils.js"); + + + + + + + + + + +_newfold_labs_js_utility_ui_analytics__WEBPACK_IMPORTED_MODULE_3__.HiiveAnalytics.initialize({ + urls: { + single: window.nfdHelpCenter.restUrl + "/newfold-data/v1/events" + } +}); +const wpContentContainer = document.getElementById("wpcontent"); +const toggleHelp = visible => { + wpContentContainer.classList.toggle("wpcontent-container", visible); + let nfdHelpContainer = document.getElementById("nfd-help-center"); + nfdHelpContainer.classList.toggle("help-container", visible); + _utils__WEBPACK_IMPORTED_MODULE_8__.LocalStorageUtils.updateHelpVisible(visible); +}; +window.newfoldEmbeddedHelp = {}; +window.newfoldEmbeddedHelp.toggleNFDLaunchedEmbeddedHelp = () => { + const helpVisible = _utils__WEBPACK_IMPORTED_MODULE_8__.LocalStorageUtils.getHelpVisible(); + if (Object.is(helpVisible, undefined)) { + toggleHelp(true); + _utils__WEBPACK_IMPORTED_MODULE_8__.Analytics.sendEvent("page", "opened"); + return; + } + toggleHelp(!helpVisible); + _utils__WEBPACK_IMPORTED_MODULE_8__.Analytics.sendEvent("page", "closed"); +}; +window.newfoldEmbeddedHelp.toggleNFDUnlaunchedEmbeddedHelp = function toggleNFDUnlaunchedEmbeddedHelp() { + let helpContainer = document.getElementById("nfd-help-center"); + wpContentContainer.removeChild(helpContainer); + newfoldEmbeddedHelp.renderEmbeddedHelp(); +}; + +//For rendering embedded help in Add, edit and View Pages +const HelpCenterPluginSidebar = () => { + return (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_wordpress_edit_post__WEBPACK_IMPORTED_MODULE_1__.PluginSidebar, { + name: "nfd-help-sidebar", + title: "Help Center", + icon: (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_icons_help_svg__WEBPACK_IMPORTED_MODULE_7__.ReactComponent, null) + }, (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_components_HelpCenter__WEBPACK_IMPORTED_MODULE_5__["default"], null)); +}; +(0,_wordpress_plugins__WEBPACK_IMPORTED_MODULE_2__.registerPlugin)("nfd-help-panel", { + render: HelpCenterPluginSidebar +}); + +//For rendering embedded help in Admin Pages +window.newfoldEmbeddedHelp.renderEmbeddedHelp = function renderEmbeddedHelp() { + let helpContainer = document.createElement("div"); + helpContainer.id = "nfd-help-center"; + helpContainer.style.display = "none"; + wpContentContainer.appendChild(helpContainer); + const DOM_TARGET = document.getElementById("nfd-help-center"); + (0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.render)((0,_wordpress_element__WEBPACK_IMPORTED_MODULE_0__.createElement)(_components_Modal__WEBPACK_IMPORTED_MODULE_6__["default"], { + onClose: () => { + toggleHelp(false); + } + }), DOM_TARGET); +}; +newfoldEmbeddedHelp.renderEmbeddedHelp(); + +/***/ }), + +/***/ "./src/utils.js": +/*!**********************!*\ + !*** ./src/utils.js ***! + \**********************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "Analytics": () => (/* binding */ Analytics), +/* harmony export */ "InteractionAPIs": () => (/* binding */ InteractionAPIs), +/* harmony export */ "LocalStorageUtils": () => (/* binding */ LocalStorageUtils) +/* harmony export */ }); +/* harmony import */ var _newfold_labs_js_utility_ui_analytics__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @newfold-labs/js-utility-ui-analytics */ "./node_modules/@newfold-labs/js-utility-ui-analytics/src/index.js"); +/* harmony import */ var _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @wordpress/api-fetch */ "@wordpress/api-fetch"); +/* harmony import */ var _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_1__); + + +const base = "nfd-help-center/v1"; +const InteractionAPIs = { + postFeedback: (postId, status) => _wordpress_api_fetch__WEBPACK_IMPORTED_MODULE_1___default()({ + path: base + "/feedback", + method: "POST", + data: { + post_id: postId, + status: status + } + }) +}; + +// A wrapper to get and set things more easily +const LocalStorageUtils = { + updateHelpVisible: visible => { + localStorage.setItem("helpVisible", visible ? "true" : "false"); + }, + getHelpVisible: () => { + return localStorage.getItem("helpVisible") === "true"; + }, + persistResult: (resultContent, postId) => { + localStorage.setItem("helpResultContent", resultContent); + localStorage.setItem("helpPostId", postId); + }, + persistSearchInput: searchInput => { + localStorage.setItem("searchInput", searchInput); + }, + getResultInfo: () => { + return { + content: localStorage.getItem("helpResultContent"), + postId: localStorage.getItem("helpPostId") + }; + }, + getSearchInput: () => { + return localStorage.getItem("searchInput"); + } +}; +const Analytics = { + sendEvent: (event, data) => { + const hiiveEvent = new _newfold_labs_js_utility_ui_analytics__WEBPACK_IMPORTED_MODULE_0__.HiiveEvent('nfd-help-center', event, { + value: data, + time: new Date() + }); + _newfold_labs_js_utility_ui_analytics__WEBPACK_IMPORTED_MODULE_0__.HiiveAnalytics.send(hiiveEvent); + } +}; + +/***/ }), + +/***/ "./node_modules/instantsearch.js/node_modules/qs/lib/formats.js": +/*!**********************************************************************!*\ + !*** ./node_modules/instantsearch.js/node_modules/qs/lib/formats.js ***! + \**********************************************************************/ +/***/ ((module) => { + +"use strict"; + + +var replace = String.prototype.replace; +var percentTwenties = /%20/g; + +var Format = { + RFC1738: 'RFC1738', + RFC3986: 'RFC3986' +}; + +module.exports = { + 'default': Format.RFC3986, + formatters: { + RFC1738: function (value) { + return replace.call(value, percentTwenties, '+'); + }, + RFC3986: function (value) { + return String(value); + } + }, + RFC1738: Format.RFC1738, + RFC3986: Format.RFC3986 +}; + + +/***/ }), + +/***/ "./node_modules/instantsearch.js/node_modules/qs/lib/index.js": +/*!********************************************************************!*\ + !*** ./node_modules/instantsearch.js/node_modules/qs/lib/index.js ***! + \********************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var stringify = __webpack_require__(/*! ./stringify */ "./node_modules/instantsearch.js/node_modules/qs/lib/stringify.js"); +var parse = __webpack_require__(/*! ./parse */ "./node_modules/instantsearch.js/node_modules/qs/lib/parse.js"); +var formats = __webpack_require__(/*! ./formats */ "./node_modules/instantsearch.js/node_modules/qs/lib/formats.js"); + +module.exports = { + formats: formats, + parse: parse, + stringify: stringify +}; + + +/***/ }), + +/***/ "./node_modules/instantsearch.js/node_modules/qs/lib/parse.js": +/*!********************************************************************!*\ + !*** ./node_modules/instantsearch.js/node_modules/qs/lib/parse.js ***! + \********************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var utils = __webpack_require__(/*! ./utils */ "./node_modules/instantsearch.js/node_modules/qs/lib/utils.js"); + +var has = Object.prototype.hasOwnProperty; +var isArray = Array.isArray; + +var defaults = { + allowDots: false, + allowPrototypes: false, + arrayLimit: 20, + charset: 'utf-8', + charsetSentinel: false, + comma: false, + decoder: utils.decode, + delimiter: '&', + depth: 5, + ignoreQueryPrefix: false, + interpretNumericEntities: false, + parameterLimit: 1000, + parseArrays: true, + plainObjects: false, + strictNullHandling: false +}; + +var interpretNumericEntities = function (str) { + return str.replace(/&#(\d+);/g, function ($0, numberStr) { + return String.fromCharCode(parseInt(numberStr, 10)); + }); +}; + +var parseArrayValue = function (val, options) { + if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) { + return val.split(','); + } + + return val; +}; + +// This is what browsers will submit when the ✓ character occurs in an +// application/x-www-form-urlencoded body and the encoding of the page containing +// the form is iso-8859-1, or when the submitted form has an accept-charset +// attribute of iso-8859-1. Presumably also with other charsets that do not contain +// the ✓ character, such as us-ascii. +var isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓') + +// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded. +var charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓') + +var parseValues = function parseQueryStringValues(str, options) { + var obj = {}; + var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\?/, '') : str; + var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit; + var parts = cleanStr.split(options.delimiter, limit); + var skipIndex = -1; // Keep track of where the utf8 sentinel was found + var i; + + var charset = options.charset; + if (options.charsetSentinel) { + for (i = 0; i < parts.length; ++i) { + if (parts[i].indexOf('utf8=') === 0) { + if (parts[i] === charsetSentinel) { + charset = 'utf-8'; + } else if (parts[i] === isoSentinel) { + charset = 'iso-8859-1'; + } + skipIndex = i; + i = parts.length; // The eslint settings do not allow break; + } + } + } + + for (i = 0; i < parts.length; ++i) { + if (i === skipIndex) { + continue; + } + var part = parts[i]; + + var bracketEqualsPos = part.indexOf(']='); + var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1; + + var key, val; + if (pos === -1) { + key = options.decoder(part, defaults.decoder, charset, 'key'); + val = options.strictNullHandling ? null : ''; + } else { + key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key'); + val = utils.maybeMap( + parseArrayValue(part.slice(pos + 1), options), + function (encodedVal) { + return options.decoder(encodedVal, defaults.decoder, charset, 'value'); + } + ); + } + + if (val && options.interpretNumericEntities && charset === 'iso-8859-1') { + val = interpretNumericEntities(val); + } + + if (part.indexOf('[]=') > -1) { + val = isArray(val) ? [val] : val; + } + + if (has.call(obj, key)) { + obj[key] = utils.combine(obj[key], val); + } else { + obj[key] = val; + } + } + + return obj; +}; + +var parseObject = function (chain, val, options, valuesParsed) { + var leaf = valuesParsed ? val : parseArrayValue(val, options); + + for (var i = chain.length - 1; i >= 0; --i) { + var obj; + var root = chain[i]; + + if (root === '[]' && options.parseArrays) { + obj = [].concat(leaf); + } else { + obj = options.plainObjects ? Object.create(null) : {}; + var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root; + var index = parseInt(cleanRoot, 10); + if (!options.parseArrays && cleanRoot === '') { + obj = { 0: leaf }; + } else if ( + !isNaN(index) + && root !== cleanRoot + && String(index) === cleanRoot + && index >= 0 + && (options.parseArrays && index <= options.arrayLimit) + ) { + obj = []; + obj[index] = leaf; + } else if (cleanRoot !== '__proto__') { + obj[cleanRoot] = leaf; + } + } + + leaf = obj; + } + + return leaf; +}; + +var parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) { + if (!givenKey) { + return; + } + + // Transform dot notation to bracket notation + var key = options.allowDots ? givenKey.replace(/\.([^.[]+)/g, '[$1]') : givenKey; + + // The regex chunks + + var brackets = /(\[[^[\]]*])/; + var child = /(\[[^[\]]*])/g; + + // Get the parent + + var segment = options.depth > 0 && brackets.exec(key); + var parent = segment ? key.slice(0, segment.index) : key; + + // Stash the parent if it exists + + var keys = []; + if (parent) { + // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties + if (!options.plainObjects && has.call(Object.prototype, parent)) { + if (!options.allowPrototypes) { + return; + } + } + + keys.push(parent); + } + + // Loop through children appending to the array until we hit depth + + var i = 0; + while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) { + i += 1; + if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) { + if (!options.allowPrototypes) { + return; + } + } + keys.push(segment[1]); + } + + // If there's a remainder, just add whatever is left + + if (segment) { + keys.push('[' + key.slice(segment.index) + ']'); + } + + return parseObject(keys, val, options, valuesParsed); +}; + +var normalizeParseOptions = function normalizeParseOptions(opts) { + if (!opts) { + return defaults; + } + + if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') { + throw new TypeError('Decoder has to be a function.'); + } + + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset; + + return { + allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots, + allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes, + arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel, + comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma, + decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder, + delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter, + // eslint-disable-next-line no-implicit-coercion, no-extra-parens + depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth, + ignoreQueryPrefix: opts.ignoreQueryPrefix === true, + interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities, + parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit, + parseArrays: opts.parseArrays !== false, + plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling + }; +}; + +module.exports = function (str, opts) { + var options = normalizeParseOptions(opts); + + if (str === '' || str === null || typeof str === 'undefined') { + return options.plainObjects ? Object.create(null) : {}; + } + + var tempObj = typeof str === 'string' ? parseValues(str, options) : str; + var obj = options.plainObjects ? Object.create(null) : {}; + + // Iterate over the keys and setup the new object + + var keys = Object.keys(tempObj); + for (var i = 0; i < keys.length; ++i) { + var key = keys[i]; + var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string'); + obj = utils.merge(obj, newObj, options); + } + + return utils.compact(obj); +}; + + +/***/ }), + +/***/ "./node_modules/instantsearch.js/node_modules/qs/lib/stringify.js": +/*!************************************************************************!*\ + !*** ./node_modules/instantsearch.js/node_modules/qs/lib/stringify.js ***! + \************************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var utils = __webpack_require__(/*! ./utils */ "./node_modules/instantsearch.js/node_modules/qs/lib/utils.js"); +var formats = __webpack_require__(/*! ./formats */ "./node_modules/instantsearch.js/node_modules/qs/lib/formats.js"); +var has = Object.prototype.hasOwnProperty; + +var arrayPrefixGenerators = { + brackets: function brackets(prefix) { + return prefix + '[]'; + }, + comma: 'comma', + indices: function indices(prefix, key) { + return prefix + '[' + key + ']'; + }, + repeat: function repeat(prefix) { + return prefix; + } +}; + +var isArray = Array.isArray; +var split = String.prototype.split; +var push = Array.prototype.push; +var pushToArray = function (arr, valueOrArray) { + push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]); +}; + +var toISO = Date.prototype.toISOString; + +var defaultFormat = formats['default']; +var defaults = { + addQueryPrefix: false, + allowDots: false, + charset: 'utf-8', + charsetSentinel: false, + delimiter: '&', + encode: true, + encoder: utils.encode, + encodeValuesOnly: false, + format: defaultFormat, + formatter: formats.formatters[defaultFormat], + // deprecated + indices: false, + serializeDate: function serializeDate(date) { + return toISO.call(date); + }, + skipNulls: false, + strictNullHandling: false +}; + +var isNonNullishPrimitive = function isNonNullishPrimitive(v) { + return typeof v === 'string' + || typeof v === 'number' + || typeof v === 'boolean' + || typeof v === 'symbol' + || typeof v === 'bigint'; +}; + +var stringify = function stringify( + object, + prefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + format, + formatter, + encodeValuesOnly, + charset +) { + var obj = object; + if (typeof filter === 'function') { + obj = filter(prefix, obj); + } else if (obj instanceof Date) { + obj = serializeDate(obj); + } else if (generateArrayPrefix === 'comma' && isArray(obj)) { + obj = utils.maybeMap(obj, function (value) { + if (value instanceof Date) { + return serializeDate(value); + } + return value; + }); + } + + if (obj === null) { + if (strictNullHandling) { + return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key', format) : prefix; + } + + obj = ''; + } + + if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) { + if (encoder) { + var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key', format); + if (generateArrayPrefix === 'comma' && encodeValuesOnly) { + var valuesArray = split.call(String(obj), ','); + var valuesJoined = ''; + for (var i = 0; i < valuesArray.length; ++i) { + valuesJoined += (i === 0 ? '' : ',') + formatter(encoder(valuesArray[i], defaults.encoder, charset, 'value', format)); + } + return [formatter(keyValue) + '=' + valuesJoined]; + } + return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value', format))]; + } + return [formatter(prefix) + '=' + formatter(String(obj))]; + } + + var values = []; + + if (typeof obj === 'undefined') { + return values; + } + + var objKeys; + if (generateArrayPrefix === 'comma' && isArray(obj)) { + // we need to join elements in + objKeys = [{ value: obj.length > 0 ? obj.join(',') || null : void undefined }]; + } else if (isArray(filter)) { + objKeys = filter; + } else { + var keys = Object.keys(obj); + objKeys = sort ? keys.sort(sort) : keys; + } + + for (var j = 0; j < objKeys.length; ++j) { + var key = objKeys[j]; + var value = typeof key === 'object' && typeof key.value !== 'undefined' ? key.value : obj[key]; + + if (skipNulls && value === null) { + continue; + } + + var keyPrefix = isArray(obj) + ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix + : prefix + (allowDots ? '.' + key : '[' + key + ']'); + + pushToArray(values, stringify( + value, + keyPrefix, + generateArrayPrefix, + strictNullHandling, + skipNulls, + encoder, + filter, + sort, + allowDots, + serializeDate, + format, + formatter, + encodeValuesOnly, + charset + )); + } + + return values; +}; + +var normalizeStringifyOptions = function normalizeStringifyOptions(opts) { + if (!opts) { + return defaults; + } + + if (opts.encoder !== null && typeof opts.encoder !== 'undefined' && typeof opts.encoder !== 'function') { + throw new TypeError('Encoder has to be a function.'); + } + + var charset = opts.charset || defaults.charset; + if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') { + throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'); + } + + var format = formats['default']; + if (typeof opts.format !== 'undefined') { + if (!has.call(formats.formatters, opts.format)) { + throw new TypeError('Unknown format option provided.'); + } + format = opts.format; + } + var formatter = formats.formatters[format]; + + var filter = defaults.filter; + if (typeof opts.filter === 'function' || isArray(opts.filter)) { + filter = opts.filter; + } + + return { + addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix, + allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots, + charset: charset, + charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel, + delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter, + encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode, + encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder, + encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly, + filter: filter, + format: format, + formatter: formatter, + serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate, + skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls, + sort: typeof opts.sort === 'function' ? opts.sort : null, + strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling + }; +}; + +module.exports = function (object, opts) { + var obj = object; + var options = normalizeStringifyOptions(opts); + + var objKeys; + var filter; + + if (typeof options.filter === 'function') { + filter = options.filter; + obj = filter('', obj); + } else if (isArray(options.filter)) { + filter = options.filter; + objKeys = filter; + } + + var keys = []; + + if (typeof obj !== 'object' || obj === null) { + return ''; + } + + var arrayFormat; + if (opts && opts.arrayFormat in arrayPrefixGenerators) { + arrayFormat = opts.arrayFormat; + } else if (opts && 'indices' in opts) { + arrayFormat = opts.indices ? 'indices' : 'repeat'; + } else { + arrayFormat = 'indices'; + } + + var generateArrayPrefix = arrayPrefixGenerators[arrayFormat]; + + if (!objKeys) { + objKeys = Object.keys(obj); + } + + if (options.sort) { + objKeys.sort(options.sort); + } + + for (var i = 0; i < objKeys.length; ++i) { + var key = objKeys[i]; + + if (options.skipNulls && obj[key] === null) { + continue; + } + pushToArray(keys, stringify( + obj[key], + key, + generateArrayPrefix, + options.strictNullHandling, + options.skipNulls, + options.encode ? options.encoder : null, + options.filter, + options.sort, + options.allowDots, + options.serializeDate, + options.format, + options.formatter, + options.encodeValuesOnly, + options.charset + )); + } + + var joined = keys.join(options.delimiter); + var prefix = options.addQueryPrefix === true ? '?' : ''; + + if (options.charsetSentinel) { + if (options.charset === 'iso-8859-1') { + // encodeURIComponent('✓'), the "numeric entity" representation of a checkmark + prefix += 'utf8=%26%2310003%3B&'; + } else { + // encodeURIComponent('✓') + prefix += 'utf8=%E2%9C%93&'; + } + } + + return joined.length > 0 ? prefix + joined : ''; +}; + + +/***/ }), + +/***/ "./node_modules/instantsearch.js/node_modules/qs/lib/utils.js": +/*!********************************************************************!*\ + !*** ./node_modules/instantsearch.js/node_modules/qs/lib/utils.js ***! + \********************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +var formats = __webpack_require__(/*! ./formats */ "./node_modules/instantsearch.js/node_modules/qs/lib/formats.js"); + +var has = Object.prototype.hasOwnProperty; +var isArray = Array.isArray; + +var hexTable = (function () { + var array = []; + for (var i = 0; i < 256; ++i) { + array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase()); + } + + return array; +}()); + +var compactQueue = function compactQueue(queue) { + while (queue.length > 1) { + var item = queue.pop(); + var obj = item.obj[item.prop]; + + if (isArray(obj)) { + var compacted = []; + + for (var j = 0; j < obj.length; ++j) { + if (typeof obj[j] !== 'undefined') { + compacted.push(obj[j]); + } + } + + item.obj[item.prop] = compacted; + } + } +}; + +var arrayToObject = function arrayToObject(source, options) { + var obj = options && options.plainObjects ? Object.create(null) : {}; + for (var i = 0; i < source.length; ++i) { + if (typeof source[i] !== 'undefined') { + obj[i] = source[i]; + } + } + + return obj; +}; + +var merge = function merge(target, source, options) { + /* eslint no-param-reassign: 0 */ + if (!source) { + return target; + } + + if (typeof source !== 'object') { + if (isArray(target)) { + target.push(source); + } else if (target && typeof target === 'object') { + if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) { + target[source] = true; + } + } else { + return [target, source]; + } + + return target; + } + + if (!target || typeof target !== 'object') { + return [target].concat(source); + } + + var mergeTarget = target; + if (isArray(target) && !isArray(source)) { + mergeTarget = arrayToObject(target, options); + } + + if (isArray(target) && isArray(source)) { + source.forEach(function (item, i) { + if (has.call(target, i)) { + var targetItem = target[i]; + if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') { + target[i] = merge(targetItem, item, options); + } else { + target.push(item); + } + } else { + target[i] = item; + } + }); + return target; + } + + return Object.keys(source).reduce(function (acc, key) { + var value = source[key]; + + if (has.call(acc, key)) { + acc[key] = merge(acc[key], value, options); + } else { + acc[key] = value; + } + return acc; + }, mergeTarget); +}; + +var assign = function assignSingleSource(target, source) { + return Object.keys(source).reduce(function (acc, key) { + acc[key] = source[key]; + return acc; + }, target); +}; + +var decode = function (str, decoder, charset) { + var strWithoutPlus = str.replace(/\+/g, ' '); + if (charset === 'iso-8859-1') { + // unescape never throws, no try...catch needed: + return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape); + } + // utf-8 + try { + return decodeURIComponent(strWithoutPlus); + } catch (e) { + return strWithoutPlus; + } +}; + +var encode = function encode(str, defaultEncoder, charset, kind, format) { + // This code was originally written by Brian White (mscdex) for the io.js core querystring library. + // It has been adapted here for stricter adherence to RFC 3986 + if (str.length === 0) { + return str; + } + + var string = str; + if (typeof str === 'symbol') { + string = Symbol.prototype.toString.call(str); + } else if (typeof str !== 'string') { + string = String(str); + } + + if (charset === 'iso-8859-1') { + return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) { + return '%26%23' + parseInt($0.slice(2), 16) + '%3B'; + }); + } + + var out = ''; + for (var i = 0; i < string.length; ++i) { + var c = string.charCodeAt(i); + + if ( + c === 0x2D // - + || c === 0x2E // . + || c === 0x5F // _ + || c === 0x7E // ~ + || (c >= 0x30 && c <= 0x39) // 0-9 + || (c >= 0x41 && c <= 0x5A) // a-z + || (c >= 0x61 && c <= 0x7A) // A-Z + || (format === formats.RFC1738 && (c === 0x28 || c === 0x29)) // ( ) + ) { + out += string.charAt(i); + continue; + } + + if (c < 0x80) { + out = out + hexTable[c]; + continue; + } + + if (c < 0x800) { + out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + if (c < 0xD800 || c >= 0xE000) { + out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]); + continue; + } + + i += 1; + c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF)); + /* eslint operator-linebreak: [2, "before"] */ + out += hexTable[0xF0 | (c >> 18)] + + hexTable[0x80 | ((c >> 12) & 0x3F)] + + hexTable[0x80 | ((c >> 6) & 0x3F)] + + hexTable[0x80 | (c & 0x3F)]; + } + + return out; +}; + +var compact = function compact(value) { + var queue = [{ obj: { o: value }, prop: 'o' }]; + var refs = []; + + for (var i = 0; i < queue.length; ++i) { + var item = queue[i]; + var obj = item.obj[item.prop]; + + var keys = Object.keys(obj); + for (var j = 0; j < keys.length; ++j) { + var key = keys[j]; + var val = obj[key]; + if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) { + queue.push({ obj: obj, prop: key }); + refs.push(val); + } + } + } + + compactQueue(queue); + + return value; +}; + +var isRegExp = function isRegExp(obj) { + return Object.prototype.toString.call(obj) === '[object RegExp]'; +}; + +var isBuffer = function isBuffer(obj) { + if (!obj || typeof obj !== 'object') { + return false; + } + + return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj)); +}; + +var combine = function combine(a, b) { + return [].concat(a, b); +}; + +var maybeMap = function maybeMap(val, fn) { + if (isArray(val)) { + var mapped = []; + for (var i = 0; i < val.length; i += 1) { + mapped.push(fn(val[i])); + } + return mapped; + } + return fn(val); +}; + +module.exports = { + arrayToObject: arrayToObject, + assign: assign, + combine: combine, + compact: compact, + decode: decode, + encode: encode, + isBuffer: isBuffer, + isRegExp: isRegExp, + maybeMap: maybeMap, + merge: merge +}; + + +/***/ }), + +/***/ "./styles.scss": +/*!*********************!*\ + !*** ./styles.scss ***! + \*********************/ +/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +// extracted by mini-css-extract-plugin + + +/***/ }), + +/***/ "./node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js": +/*!**********************************************************************************************!*\ + !*** ./node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js ***! + \**********************************************************************************************/ +/***/ ((__unused_webpack_module, exports, __webpack_require__) => { + +"use strict"; +/** + * @license React + * use-sync-external-store-shim.development.js + * + * Copyright (c) Facebook, Inc. and its affiliates. + * + * This source code is licensed under the MIT license found in the + * LICENSE file in the root directory of this source tree. + */ + + + +if (true) { + (function() { + + 'use strict'; + +/* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */ +if ( + typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined' && + typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart === + 'function' +) { + __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(new Error()); +} + var React = __webpack_require__(/*! react */ "react"); + +var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED; + +function error(format) { + { + { + for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) { + args[_key2 - 1] = arguments[_key2]; + } + + printWarning('error', format, args); + } + } +} + +function printWarning(level, format, args) { + // When changing this logic, you might want to also + // update consoleWithStackDev.www.js as well. + { + var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame; + var stack = ReactDebugCurrentFrame.getStackAddendum(); + + if (stack !== '') { + format += '%s'; + args = args.concat([stack]); + } // eslint-disable-next-line react-internal/safe-string-coercion + + + var argsWithFormat = args.map(function (item) { + return String(item); + }); // Careful: RN currently depends on this prefix + + argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it + // breaks IE9: https://github.com/facebook/react/issues/13610 + // eslint-disable-next-line react-internal/no-production-logging + + Function.prototype.apply.call(console[level], console, argsWithFormat); + } +} + +/** + * inlined Object.is polyfill to avoid requiring consumers ship their own + * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is + */ +function is(x, y) { + return x === y && (x !== 0 || 1 / x === 1 / y) || x !== x && y !== y // eslint-disable-line no-self-compare + ; +} + +var objectIs = typeof Object.is === 'function' ? Object.is : is; + +// dispatch for CommonJS interop named imports. + +var useState = React.useState, + useEffect = React.useEffect, + useLayoutEffect = React.useLayoutEffect, + useDebugValue = React.useDebugValue; +var didWarnOld18Alpha = false; +var didWarnUncachedGetSnapshot = false; // Disclaimer: This shim breaks many of the rules of React, and only works +// because of a very particular set of implementation details and assumptions +// -- change any one of them and it will break. The most important assumption +// is that updates are always synchronous, because concurrent rendering is +// only available in versions of React that also have a built-in +// useSyncExternalStore API. And we only use this shim when the built-in API +// does not exist. +// +// Do not assume that the clever hacks used by this hook also work in general. +// The point of this shim is to replace the need for hacks by other libraries. + +function useSyncExternalStore(subscribe, getSnapshot, // Note: The shim does not use getServerSnapshot, because pre-18 versions of +// React do not expose a way to check if we're hydrating. So users of the shim +// will need to track that themselves and return the correct value +// from `getSnapshot`. +getServerSnapshot) { + { + if (!didWarnOld18Alpha) { + if (React.startTransition !== undefined) { + didWarnOld18Alpha = true; + + error('You are using an outdated, pre-release alpha of React 18 that ' + 'does not support useSyncExternalStore. The ' + 'use-sync-external-store shim will not work correctly. Upgrade ' + 'to a newer pre-release.'); + } + } + } // Read the current snapshot from the store on every render. Again, this + // breaks the rules of React, and only works here because of specific + // implementation details, most importantly that updates are + // always synchronous. + + + var value = getSnapshot(); + + { + if (!didWarnUncachedGetSnapshot) { + var cachedValue = getSnapshot(); + + if (!objectIs(value, cachedValue)) { + error('The result of getSnapshot should be cached to avoid an infinite loop'); + + didWarnUncachedGetSnapshot = true; + } + } + } // Because updates are synchronous, we don't queue them. Instead we force a + // re-render whenever the subscribed state changes by updating an some + // arbitrary useState hook. Then, during render, we call getSnapshot to read + // the current value. + // + // Because we don't actually use the state returned by the useState hook, we + // can save a bit of memory by storing other stuff in that slot. + // + // To implement the early bailout, we need to track some things on a mutable + // object. Usually, we would put that in a useRef hook, but we can stash it in + // our useState hook instead. + // + // To force a re-render, we call forceUpdate({inst}). That works because the + // new object always fails an equality check. + + + var _useState = useState({ + inst: { + value: value, + getSnapshot: getSnapshot + } + }), + inst = _useState[0].inst, + forceUpdate = _useState[1]; // Track the latest getSnapshot function with a ref. This needs to be updated + // in the layout phase so we can access it during the tearing check that + // happens on subscribe. + + + useLayoutEffect(function () { + inst.value = value; + inst.getSnapshot = getSnapshot; // Whenever getSnapshot or subscribe changes, we need to check in the + // commit phase if there was an interleaved mutation. In concurrent mode + // this can happen all the time, but even in synchronous mode, an earlier + // effect may have mutated the store. + + if (checkIfSnapshotChanged(inst)) { + // Force a re-render. + forceUpdate({ + inst: inst + }); + } + }, [subscribe, value, getSnapshot]); + useEffect(function () { + // Check for changes right before subscribing. Subsequent changes will be + // detected in the subscription handler. + if (checkIfSnapshotChanged(inst)) { + // Force a re-render. + forceUpdate({ + inst: inst + }); + } + + var handleStoreChange = function () { + // TODO: Because there is no cross-renderer API for batching updates, it's + // up to the consumer of this library to wrap their subscription event + // with unstable_batchedUpdates. Should we try to detect when this isn't + // the case and print a warning in development? + // The store changed. Check if the snapshot changed since the last time we + // read from the store. + if (checkIfSnapshotChanged(inst)) { + // Force a re-render. + forceUpdate({ + inst: inst + }); + } + }; // Subscribe to the store and return a clean-up function. + + + return subscribe(handleStoreChange); + }, [subscribe]); + useDebugValue(value); + return value; +} + +function checkIfSnapshotChanged(inst) { + var latestGetSnapshot = inst.getSnapshot; + var prevValue = inst.value; + + try { + var nextValue = latestGetSnapshot(); + return !objectIs(prevValue, nextValue); + } catch (error) { + return true; + } +} + +function useSyncExternalStore$1(subscribe, getSnapshot, getServerSnapshot) { + // Note: The shim does not use getServerSnapshot, because pre-18 versions of + // React do not expose a way to check if we're hydrating. So users of the shim + // will need to track that themselves and return the correct value + // from `getSnapshot`. + return getSnapshot(); +} + +var canUseDOM = !!(typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined'); + +var isServerEnvironment = !canUseDOM; + +var shim = isServerEnvironment ? useSyncExternalStore$1 : useSyncExternalStore; +var useSyncExternalStore$2 = React.useSyncExternalStore !== undefined ? React.useSyncExternalStore : shim; + +exports.useSyncExternalStore = useSyncExternalStore$2; + /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */ +if ( + typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined' && + typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop === + 'function' +) { + __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(new Error()); +} + + })(); +} + + +/***/ }), + +/***/ "./node_modules/use-sync-external-store/shim/index.js": +/*!************************************************************!*\ + !*** ./node_modules/use-sync-external-store/shim/index.js ***! + \************************************************************/ +/***/ ((module, __unused_webpack_exports, __webpack_require__) => { + +"use strict"; + + +if (false) {} else { + module.exports = __webpack_require__(/*! ../cjs/use-sync-external-store-shim.development.js */ "./node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js"); +} + + +/***/ }), + +/***/ "react": +/*!************************!*\ + !*** external "React" ***! + \************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["React"]; + +/***/ }), + +/***/ "lodash": +/*!*************************!*\ + !*** external "lodash" ***! + \*************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["lodash"]; + +/***/ }), + +/***/ "@wordpress/api-fetch": +/*!**********************************!*\ + !*** external ["wp","apiFetch"] ***! + \**********************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["wp"]["apiFetch"]; + +/***/ }), + +/***/ "@wordpress/data": +/*!******************************!*\ + !*** external ["wp","data"] ***! + \******************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["wp"]["data"]; + +/***/ }), + +/***/ "@wordpress/edit-post": +/*!**********************************!*\ + !*** external ["wp","editPost"] ***! + \**********************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["wp"]["editPost"]; + +/***/ }), + +/***/ "@wordpress/element": +/*!*********************************!*\ + !*** external ["wp","element"] ***! + \*********************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["wp"]["element"]; + +/***/ }), + +/***/ "@wordpress/i18n": +/*!******************************!*\ + !*** external ["wp","i18n"] ***! + \******************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["wp"]["i18n"]; + +/***/ }), + +/***/ "@wordpress/plugins": +/*!*********************************!*\ + !*** external ["wp","plugins"] ***! + \*********************************/ +/***/ ((module) => { + +"use strict"; +module.exports = window["wp"]["plugins"]; + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/connectors/configure/connectConfigure.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/connectors/configure/connectConfigure.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! algoliasearch-helper */ "./node_modules/algoliasearch-helper/index.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/documentation.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/noop.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/isPlainObject.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/mergeSearchParameters.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + +var withUsage = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.createDocumentationMessageGenerator)({ + name: 'configure', + connector: true +}); +function getInitialSearchParameters(state, widgetParams) { + // We leverage the helper internals to remove the `widgetParams` from + // the state. The function `setQueryParameters` omits the values that + // are `undefined` on the next state. + return state.setQueryParameters(Object.keys(widgetParams.searchParameters).reduce(function (acc, key) { + return _objectSpread(_objectSpread({}, acc), {}, _defineProperty({}, key, undefined)); + }, {})); +} +var connectConfigure = function connectConfigure() { + var renderFn = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.noop; + var unmountFn = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.noop; + return function (widgetParams) { + if (!widgetParams || !(0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.isPlainObject)(widgetParams.searchParameters)) { + throw new Error(withUsage('The `searchParameters` option expects an object.')); + } + var connectorState = {}; + function refine(helper) { + return function (searchParameters) { + // Merge new `searchParameters` with the ones set from other widgets + var actualState = getInitialSearchParameters(helper.state, widgetParams); + var nextSearchParameters = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__.mergeSearchParameters)(actualState, new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchParameters(searchParameters)); + + // Update original `widgetParams.searchParameters` to the new refined one + widgetParams.searchParameters = searchParameters; + + // Trigger a search with the resolved search parameters + helper.setState(nextSearchParameters).search(); + }; + } + return { + $$type: 'ais.configure', + init: function init(initOptions) { + var instantSearchInstance = initOptions.instantSearchInstance; + renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(initOptions)), {}, { + instantSearchInstance: instantSearchInstance + }), true); + }, + render: function render(renderOptions) { + var instantSearchInstance = renderOptions.instantSearchInstance; + renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(renderOptions)), {}, { + instantSearchInstance: instantSearchInstance + }), false); + }, + dispose: function dispose(_ref) { + var state = _ref.state; + unmountFn(); + return getInitialSearchParameters(state, widgetParams); + }, + getRenderState: function getRenderState(renderState, renderOptions) { + var _renderState$configur; + var widgetRenderState = this.getWidgetRenderState(renderOptions); + return _objectSpread(_objectSpread({}, renderState), {}, { + configure: _objectSpread(_objectSpread({}, widgetRenderState), {}, { + widgetParams: _objectSpread(_objectSpread({}, widgetRenderState.widgetParams), {}, { + searchParameters: (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__.mergeSearchParameters)(new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchParameters((_renderState$configur = renderState.configure) === null || _renderState$configur === void 0 ? void 0 : _renderState$configur.widgetParams.searchParameters), new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchParameters(widgetRenderState.widgetParams.searchParameters)).getQueryParams() + }) + }) + }); + }, + getWidgetRenderState: function getWidgetRenderState(_ref2) { + var helper = _ref2.helper; + if (!connectorState.refine) { + connectorState.refine = refine(helper); + } + return { + refine: connectorState.refine, + widgetParams: widgetParams + }; + }, + getWidgetSearchParameters: function getWidgetSearchParameters(state, _ref3) { + var uiState = _ref3.uiState; + return (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__.mergeSearchParameters)(state, new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchParameters(_objectSpread(_objectSpread({}, uiState.configure), widgetParams.searchParameters))); + }, + getWidgetUiState: function getWidgetUiState(uiState) { + return _objectSpread(_objectSpread({}, uiState), {}, { + configure: _objectSpread(_objectSpread({}, uiState.configure), widgetParams.searchParameters) + }); + } + }; + }; +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (connectConfigure); + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/connectors/search-box/connectSearchBox.js": +/*!************************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/connectors/search-box/connectSearchBox.js ***! + \************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/documentation.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/noop.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/checkRendering.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + +var withUsage = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__.createDocumentationMessageGenerator)({ + name: 'search-box', + connector: true +}); +var defaultQueryHook = function defaultQueryHook(query, hook) { + return hook(query); +}; + +/** + * **SearchBox** connector provides the logic to build a widget that will let the user search for a query. + * + * The connector provides to the rendering: `refine()` to set the query. The behaviour of this function + * may be impacted by the `queryHook` widget parameter. + */ +var connectSearchBox = function connectSearchBox(renderFn) { + var unmountFn = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.noop; + (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.checkRendering)(renderFn, withUsage()); + return function (widgetParams) { + var _ref = widgetParams || {}, + _ref$queryHook = _ref.queryHook, + queryHook = _ref$queryHook === void 0 ? defaultQueryHook : _ref$queryHook; + var _refine; + var _clear; + return { + $$type: 'ais.searchBox', + init: function init(initOptions) { + var instantSearchInstance = initOptions.instantSearchInstance; + renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(initOptions)), {}, { + instantSearchInstance: instantSearchInstance + }), true); + }, + render: function render(renderOptions) { + var instantSearchInstance = renderOptions.instantSearchInstance; + renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(renderOptions)), {}, { + instantSearchInstance: instantSearchInstance + }), false); + }, + dispose: function dispose(_ref2) { + var state = _ref2.state; + unmountFn(); + return state.setQueryParameter('query', undefined); + }, + getRenderState: function getRenderState(renderState, renderOptions) { + return _objectSpread(_objectSpread({}, renderState), {}, { + searchBox: this.getWidgetRenderState(renderOptions) + }); + }, + getWidgetRenderState: function getWidgetRenderState(_ref3) { + var helper = _ref3.helper, + searchMetadata = _ref3.searchMetadata, + state = _ref3.state; + if (!_refine) { + _refine = function _refine(query) { + queryHook(query, function (q) { + return helper.setQuery(q).search(); + }); + }; + _clear = function _clear() { + helper.setQuery('').search(); + }; + } + return { + query: state.query || '', + refine: _refine, + clear: _clear, + widgetParams: widgetParams, + isSearchStalled: searchMetadata.isSearchStalled + }; + }, + getWidgetUiState: function getWidgetUiState(uiState, _ref4) { + var searchParameters = _ref4.searchParameters; + var query = searchParameters.query || ''; + if (query === '' || uiState && uiState.query === query) { + return uiState; + } + return _objectSpread(_objectSpread({}, uiState), {}, { + query: query + }); + }, + getWidgetSearchParameters: function getWidgetSearchParameters(searchParameters, _ref5) { + var uiState = _ref5.uiState; + return searchParameters.setQueryParameter('query', uiState.query || ''); + } + }; + }; +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (connectSearchBox); + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/helpers/get-insights-anonymous-user-token.js": +/*!***************************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/helpers/get-insights-anonymous-user-token.js ***! + \***************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "ANONYMOUS_TOKEN_COOKIE_KEY": () => (/* binding */ ANONYMOUS_TOKEN_COOKIE_KEY), +/* harmony export */ "default": () => (/* binding */ getInsightsAnonymousUserToken), +/* harmony export */ "getInsightsAnonymousUserTokenInternal": () => (/* binding */ getInsightsAnonymousUserTokenInternal) +/* harmony export */ }); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } + +var ANONYMOUS_TOKEN_COOKIE_KEY = '_ALGOLIA'; +function getCookie(name) { + if ((typeof document === "undefined" ? "undefined" : _typeof(document)) !== 'object' || typeof document.cookie !== 'string') { + return undefined; + } + var prefix = "".concat(name, "="); + var cookies = document.cookie.split(';'); + for (var i = 0; i < cookies.length; i++) { + var cookie = cookies[i]; + while (cookie.charAt(0) === ' ') { + cookie = cookie.substring(1); + } + if (cookie.indexOf(prefix) === 0) { + return cookie.substring(prefix.length, cookie.length); + } + } + return undefined; +} +function getInsightsAnonymousUserTokenInternal() { + return getCookie(ANONYMOUS_TOKEN_COOKIE_KEY); +} + +/** + * @deprecated This function will be still supported in 4.x releases, but not further. It is replaced by the `insights` middleware. For more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/ + */ +function getInsightsAnonymousUserToken() { + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__.warning)(false, "`getInsightsAnonymousUserToken` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `insights` middleware.\n\nFor more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/") : 0; + return getInsightsAnonymousUserTokenInternal(); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/helpers/highlight.js": +/*!***************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/helpers/highlight.js ***! + \***************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ highlight) +/* harmony export */ }); +/* harmony import */ var _lib_suit_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/suit.js */ "./node_modules/instantsearch.js/es/lib/suit.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/getPropertyByPath.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js"); + + +var suit = (0,_lib_suit_js__WEBPACK_IMPORTED_MODULE_0__.component)('Highlight'); + +/** + * @deprecated use html tagged templates and the Highlight component instead + */ +function highlight(_ref) { + var attribute = _ref.attribute, + _ref$highlightedTagNa = _ref.highlightedTagName, + highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa, + hit = _ref.hit, + _ref$cssClasses = _ref.cssClasses, + cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses; + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(false, "`instantsearch.highlight` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `Highlight` component.\n\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates") : 0; + var highlightAttributeResult = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.getPropertyByPath)(hit._highlightResult, attribute); + + // @MAJOR fallback to attribute value if highlight is not found + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(highlightAttributeResult, "Could not enable highlight for \"".concat(attribute, "\", will display an empty string.\nPlease check whether this attribute exists and is either searchable or specified in `attributesToHighlight`.\n\nSee: https://alg.li/highlighting\n")) : 0; + var _ref2 = highlightAttributeResult || {}, + _ref2$value = _ref2.value, + attributeValue = _ref2$value === void 0 ? '' : _ref2$value; + + // cx is not used, since it would be bundled as a dependency for Vue & Angular + var className = suit({ + descendantName: 'highlighted' + }) + (cssClasses.highlighted ? " ".concat(cssClasses.highlighted) : ''); + return attributeValue.replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.TAG_REPLACEMENT.highlightPreTag, 'g'), "<".concat(highlightedTagName, " class=\"").concat(className, "\">")).replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.TAG_REPLACEMENT.highlightPostTag, 'g'), "")); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/helpers/insights.js": +/*!**************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/helpers/insights.js ***! + \**************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ insights), +/* harmony export */ "readDataAttributes": () => (/* binding */ readDataAttributes), +/* harmony export */ "writeDataAttributes": () => (/* binding */ writeDataAttributes) +/* harmony export */ }); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/serializer.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } + +/** @deprecated use bindEvent instead */ +function readDataAttributes(domElement) { + var method = domElement.getAttribute('data-insights-method'); + var serializedPayload = domElement.getAttribute('data-insights-payload'); + if (typeof serializedPayload !== 'string') { + throw new Error('The insights helper expects `data-insights-payload` to be a base64-encoded JSON string.'); + } + try { + var payload = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__.deserializePayload)(serializedPayload); + return { + method: method, + payload: payload + }; + } catch (error) { + throw new Error('The insights helper was unable to parse `data-insights-payload`.'); + } +} + +/** @deprecated use bindEvent instead */ +function writeDataAttributes(_ref) { + var method = _ref.method, + payload = _ref.payload; + if (_typeof(payload) !== 'object') { + throw new Error("The insights helper expects the payload to be an object."); + } + var serializedPayload; + try { + serializedPayload = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__.serializePayload)(payload); + } catch (error) { + throw new Error("Could not JSON serialize the payload object."); + } + return "data-insights-method=\"".concat(method, "\" data-insights-payload=\"").concat(serializedPayload, "\""); +} + +/** + * @deprecated This function will be still supported in 4.x releases, but not further. It is replaced by the `insights` middleware. For more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/ + */ +function insights(method, payload) { + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(false, "`insights` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `insights` middleware.\n\nFor more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/") : 0; + return writeDataAttributes({ + method: method, + payload: payload + }); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/helpers/reverseHighlight.js": +/*!**********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/helpers/reverseHighlight.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ reverseHighlight) +/* harmony export */ }); +/* harmony import */ var _lib_suit_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/suit.js */ "./node_modules/instantsearch.js/es/lib/suit.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/getPropertyByPath.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/concatHighlightedParts.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/reverseHighlightedParts.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/getHighlightedParts.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js"); + + +var suit = (0,_lib_suit_js__WEBPACK_IMPORTED_MODULE_0__.component)('ReverseHighlight'); + +/** + * @deprecated use html tagged templates and the ReverseHighlight component instead + */ +function reverseHighlight(_ref) { + var attribute = _ref.attribute, + _ref$highlightedTagNa = _ref.highlightedTagName, + highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa, + hit = _ref.hit, + _ref$cssClasses = _ref.cssClasses, + cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses; + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(false, "`instantsearch.reverseHighlight` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `ReverseHighlight` component.\n\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates") : 0; + var highlightAttributeResult = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.getPropertyByPath)(hit._highlightResult, attribute); + + // @MAJOR fallback to attribute value if highlight is not found + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(highlightAttributeResult, "Could not enable reverse highlight for \"".concat(attribute, "\", will display an empty string.\nPlease check whether this attribute exists and is either searchable or specified in `attributesToHighlight`.\n\nSee: https://alg.li/highlighting\n")) : 0; + var _ref2 = highlightAttributeResult || {}, + _ref2$value = _ref2.value, + attributeValue = _ref2$value === void 0 ? '' : _ref2$value; + + // cx is not used, since it would be bundled as a dependency for Vue & Angular + var className = suit({ + descendantName: 'highlighted' + }) + (cssClasses.highlighted ? " ".concat(cssClasses.highlighted) : ''); + var reverseHighlightedValue = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.concatHighlightedParts)((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__.reverseHighlightedParts)((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.getHighlightedParts)(attributeValue))); + return reverseHighlightedValue.replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__.TAG_REPLACEMENT.highlightPreTag, 'g'), "<".concat(highlightedTagName, " class=\"").concat(className, "\">")).replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__.TAG_REPLACEMENT.highlightPostTag, 'g'), "")); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/helpers/reverseSnippet.js": +/*!********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/helpers/reverseSnippet.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ reverseSnippet) +/* harmony export */ }); +/* harmony import */ var _lib_suit_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/suit.js */ "./node_modules/instantsearch.js/es/lib/suit.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/getPropertyByPath.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/concatHighlightedParts.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/reverseHighlightedParts.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/getHighlightedParts.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js"); + + +var suit = (0,_lib_suit_js__WEBPACK_IMPORTED_MODULE_0__.component)('ReverseSnippet'); + +/** + * @deprecated use html tagged templates and the ReverseSnippet component instead + */ +function reverseSnippet(_ref) { + var attribute = _ref.attribute, + _ref$highlightedTagNa = _ref.highlightedTagName, + highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa, + hit = _ref.hit, + _ref$cssClasses = _ref.cssClasses, + cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses; + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(false, "`instantsearch.reverseSnippet` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `ReverseSnippet` component.\n\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates") : 0; + var snippetAttributeResult = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.getPropertyByPath)(hit._snippetResult, attribute); + + // @MAJOR fallback to attribute value if snippet is not found + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(snippetAttributeResult, "Could not enable reverse snippet for \"".concat(attribute, "\", will display an empty string.\nPlease check whether this attribute exists and is specified in `attributesToSnippet`.\n\nSee: https://alg.li/highlighting\n")) : 0; + var _ref2 = snippetAttributeResult || {}, + _ref2$value = _ref2.value, + attributeValue = _ref2$value === void 0 ? '' : _ref2$value; + + // cx is not used, since it would be bundled as a dependency for Vue & Angular + var className = suit({ + descendantName: 'highlighted' + }) + (cssClasses.highlighted ? " ".concat(cssClasses.highlighted) : ''); + var reverseHighlightedValue = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.concatHighlightedParts)((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__.reverseHighlightedParts)((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.getHighlightedParts)(attributeValue))); + return reverseHighlightedValue.replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__.TAG_REPLACEMENT.highlightPreTag, 'g'), "<".concat(highlightedTagName, " class=\"").concat(className, "\">")).replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__.TAG_REPLACEMENT.highlightPostTag, 'g'), "")); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/helpers/snippet.js": +/*!*************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/helpers/snippet.js ***! + \*************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ snippet) +/* harmony export */ }); +/* harmony import */ var _lib_suit_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/suit.js */ "./node_modules/instantsearch.js/es/lib/suit.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/getPropertyByPath.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js"); + + +var suit = (0,_lib_suit_js__WEBPACK_IMPORTED_MODULE_0__.component)('Snippet'); + +/** + * @deprecated use html tagged templates and the Snippet component instead + */ +function snippet(_ref) { + var attribute = _ref.attribute, + _ref$highlightedTagNa = _ref.highlightedTagName, + highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa, + hit = _ref.hit, + _ref$cssClasses = _ref.cssClasses, + cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses; + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(false, "`instantsearch.snippet` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `Snippet` component.\n\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates") : 0; + var snippetAttributeResult = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.getPropertyByPath)(hit._snippetResult, attribute); + + // @MAJOR fallback to attribute value if snippet is not found + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.warning)(snippetAttributeResult, "Could not enable snippet for \"".concat(attribute, "\", will display an empty string.\nPlease check whether this attribute exists and is specified in `attributesToSnippet`.\n\nSee: https://alg.li/highlighting\n")) : 0; + var _ref2 = snippetAttributeResult || {}, + _ref2$value = _ref2.value, + attributeValue = _ref2$value === void 0 ? '' : _ref2$value; + + // cx is not used, since it would be bundled as a dependency for Vue & Angular + var className = suit({ + descendantName: 'highlighted' + }) + (cssClasses.highlighted ? " ".concat(cssClasses.highlighted) : ''); + return attributeValue.replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.TAG_REPLACEMENT.highlightPreTag, 'g'), "<".concat(highlightedTagName, " class=\"").concat(className, "\">")).replace(new RegExp(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.TAG_REPLACEMENT.highlightPostTag, 'g'), "")); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/InstantSearch.js": +/*!***************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/InstantSearch.js ***! + \***************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var _algolia_events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @algolia/events */ "./node_modules/@algolia/events/events.js"); +/* harmony import */ var algoliasearch_helper__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! algoliasearch-helper */ "./node_modules/algoliasearch-helper/index.js"); +/* harmony import */ var _middlewares_createInsightsMiddleware_js__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../middlewares/createInsightsMiddleware.js */ "./node_modules/instantsearch.js/es/middlewares/createInsightsMiddleware.js"); +/* harmony import */ var _middlewares_createMetadataMiddleware_js__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../middlewares/createMetadataMiddleware.js */ "./node_modules/instantsearch.js/es/middlewares/createMetadataMiddleware.js"); +/* harmony import */ var _middlewares_createRouterMiddleware_js__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../middlewares/createRouterMiddleware.js */ "./node_modules/instantsearch.js/es/middlewares/createRouterMiddleware.js"); +/* harmony import */ var _widgets_index_index_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../widgets/index/index.js */ "./node_modules/instantsearch.js/es/widgets/index/index.js"); +/* harmony import */ var _createHelpers_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./createHelpers.js */ "./node_modules/instantsearch.js/es/lib/createHelpers.js"); +/* harmony import */ var _utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/documentation.js"); +/* harmony import */ var _utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/defer.js"); +/* harmony import */ var _utils_index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +/* harmony import */ var _utils_index_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/noop.js"); +/* harmony import */ var _utils_index_js__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/setIndexHelperState.js"); +/* harmony import */ var _version_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./version.js */ "./node_modules/instantsearch.js/es/lib/version.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } } +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, "prototype", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); } +function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } +function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } +function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } else if (call !== void 0) { throw new TypeError("Derived constructors may only return object or undefined"); } return _assertThisInitialized(self); } +function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } +function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } +function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + + + + + + + + +var withUsage = (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.createDocumentationMessageGenerator)({ + name: 'instantsearch' +}); +function defaultCreateURL() { + return '#'; +} + +// this purposely breaks typescript's type inference to ensure it's not used +// as it's used for a default parameter for example +// source: https://github.com/Microsoft/TypeScript/issues/14829#issuecomment-504042546 +/** + * The actual implementation of the InstantSearch. This is + * created using the `instantsearch` factory function. + * It emits the 'render' event every time a search is done + */ +var InstantSearch = /*#__PURE__*/function (_EventEmitter) { + _inherits(InstantSearch, _EventEmitter); + var _super = _createSuper(InstantSearch); + function InstantSearch(options) { + var _this; + _classCallCheck(this, InstantSearch); + _this = _super.call(this); + + // prevent `render` event listening from causing a warning + _defineProperty(_assertThisInitialized(_this), "client", void 0); + _defineProperty(_assertThisInitialized(_this), "indexName", void 0); + _defineProperty(_assertThisInitialized(_this), "insightsClient", void 0); + _defineProperty(_assertThisInitialized(_this), "onStateChange", null); + _defineProperty(_assertThisInitialized(_this), "helper", void 0); + _defineProperty(_assertThisInitialized(_this), "mainHelper", void 0); + _defineProperty(_assertThisInitialized(_this), "mainIndex", void 0); + _defineProperty(_assertThisInitialized(_this), "started", void 0); + _defineProperty(_assertThisInitialized(_this), "templatesConfig", void 0); + _defineProperty(_assertThisInitialized(_this), "renderState", {}); + _defineProperty(_assertThisInitialized(_this), "_stalledSearchDelay", void 0); + _defineProperty(_assertThisInitialized(_this), "_searchStalledTimer", void 0); + _defineProperty(_assertThisInitialized(_this), "_initialUiState", void 0); + _defineProperty(_assertThisInitialized(_this), "_initialResults", void 0); + _defineProperty(_assertThisInitialized(_this), "_createURL", void 0); + _defineProperty(_assertThisInitialized(_this), "_searchFunction", void 0); + _defineProperty(_assertThisInitialized(_this), "_mainHelperSearch", void 0); + _defineProperty(_assertThisInitialized(_this), "middleware", []); + _defineProperty(_assertThisInitialized(_this), "sendEventToInsights", void 0); + _defineProperty(_assertThisInitialized(_this), "status", 'idle'); + _defineProperty(_assertThisInitialized(_this), "error", undefined); + _defineProperty(_assertThisInitialized(_this), "scheduleSearch", (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.defer)(function () { + if (_this.started) { + _this.mainHelper.search(); + } + })); + _defineProperty(_assertThisInitialized(_this), "scheduleRender", (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.defer)(function () { + var _this$mainHelper; + var shouldResetStatus = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true; + if (!((_this$mainHelper = _this.mainHelper) !== null && _this$mainHelper !== void 0 && _this$mainHelper.hasPendingRequests())) { + clearTimeout(_this._searchStalledTimer); + _this._searchStalledTimer = null; + if (shouldResetStatus) { + _this.status = 'idle'; + _this.error = undefined; + } + } + _this.mainIndex.render({ + instantSearchInstance: _assertThisInitialized(_this) + }); + _this.emit('render'); + })); + _defineProperty(_assertThisInitialized(_this), "onInternalStateChange", (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.defer)(function () { + var nextUiState = _this.mainIndex.getWidgetUiState({}); + _this.middleware.forEach(function (_ref) { + var instance = _ref.instance; + instance.onStateChange({ + uiState: nextUiState + }); + }); + })); + _this.setMaxListeners(100); + var _options$indexName = options.indexName, + indexName = _options$indexName === void 0 ? null : _options$indexName, + numberLocale = options.numberLocale, + _options$initialUiSta = options.initialUiState, + initialUiState = _options$initialUiSta === void 0 ? {} : _options$initialUiSta, + _options$routing = options.routing, + routing = _options$routing === void 0 ? null : _options$routing, + _options$insights = options.insights, + insights = _options$insights === void 0 ? false : _options$insights, + searchFunction = options.searchFunction, + _options$stalledSearc = options.stalledSearchDelay, + stalledSearchDelay = _options$stalledSearc === void 0 ? 200 : _options$stalledSearc, + _options$searchClient = options.searchClient, + searchClient = _options$searchClient === void 0 ? null : _options$searchClient, + _options$insightsClie = options.insightsClient, + insightsClient = _options$insightsClie === void 0 ? null : _options$insightsClie, + _options$onStateChang = options.onStateChange, + onStateChange = _options$onStateChang === void 0 ? null : _options$onStateChang; + if (indexName === null) { + throw new Error(withUsage('The `indexName` option is required.')); + } + if (searchClient === null) { + throw new Error(withUsage('The `searchClient` option is required.')); + } + if (typeof searchClient.search !== 'function') { + throw new Error("The `searchClient` must implement a `search` method.\n\nSee: https://www.algolia.com/doc/guides/building-search-ui/going-further/backend-search/in-depth/backend-instantsearch/js/"); + } + if (typeof searchClient.addAlgoliaAgent === 'function') { + searchClient.addAlgoliaAgent("instantsearch.js (".concat(_version_js__WEBPACK_IMPORTED_MODULE_4__["default"], ")")); + } + true ? (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.warning)(insightsClient === null, "`insightsClient` property has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `insights` middleware.\n\nFor more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/") : 0; + if (insightsClient && typeof insightsClient !== 'function') { + throw new Error(withUsage('The `insightsClient` option should be a function.')); + } + true ? (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.warning)(!options.searchParameters, "The `searchParameters` option is deprecated and will not be supported in InstantSearch.js 4.x.\n\nYou can replace it with the `configure` widget:\n\n```\nsearch.addWidgets([\n configure(".concat(JSON.stringify(options.searchParameters, null, 2), ")\n]);\n```\n\nSee ").concat((0,_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.createDocumentationLink)({ + name: 'configure' + }))) : 0; + _this.client = searchClient; + _this.insightsClient = insightsClient; + _this.indexName = indexName; + _this.helper = null; + _this.mainHelper = null; + _this.mainIndex = (0,_widgets_index_index_js__WEBPACK_IMPORTED_MODULE_6__["default"])({ + indexName: indexName + }); + _this.onStateChange = onStateChange; + _this.started = false; + _this.templatesConfig = { + helpers: (0,_createHelpers_js__WEBPACK_IMPORTED_MODULE_7__["default"])({ + numberLocale: numberLocale + }), + compileOptions: {} + }; + _this._stalledSearchDelay = stalledSearchDelay; + _this._searchStalledTimer = null; + _this._createURL = defaultCreateURL; + _this._initialUiState = initialUiState; + _this._initialResults = null; + if (searchFunction) { + true ? (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.warning)(false, "The `searchFunction` option is deprecated. Use `onStateChange` instead.") : 0; + _this._searchFunction = searchFunction; + } + _this.sendEventToInsights = _utils_index_js__WEBPACK_IMPORTED_MODULE_8__.noop; + if (routing) { + var routerOptions = typeof routing === 'boolean' ? {} : routing; + routerOptions.$$internal = true; + _this.use((0,_middlewares_createRouterMiddleware_js__WEBPACK_IMPORTED_MODULE_9__.createRouterMiddleware)(routerOptions)); + } + + // This is the default middleware, + // any user-provided middleware will be added later and override this one. + if (insights) { + var insightsOptions = typeof insights === 'boolean' ? {} : insights; + insightsOptions.$$internal = true; + _this.use((0,_middlewares_createInsightsMiddleware_js__WEBPACK_IMPORTED_MODULE_10__.createInsightsMiddleware)(insightsOptions)); + } + if ((0,_middlewares_createMetadataMiddleware_js__WEBPACK_IMPORTED_MODULE_11__.isMetadataEnabled)()) { + _this.use((0,_middlewares_createMetadataMiddleware_js__WEBPACK_IMPORTED_MODULE_11__.createMetadataMiddleware)({ + $$internal: true + })); + } + return _this; + } + + /** + * Hooks a middleware into the InstantSearch lifecycle. + */ + _createClass(InstantSearch, [{ + key: "_isSearchStalled", + get: + /** + * The status of the search. Can be "idle", "loading", "stalled", or "error". + */ + + /** + * The last returned error from the Search API. + * The error gets cleared when the next valid search response is rendered. + */ + + /** + * @deprecated use `status === 'stalled'` instead + */ + function get() { + true ? (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.warning)(false, "`InstantSearch._isSearchStalled` is deprecated and will be removed in InstantSearch.js 5.0.\n\nUse `InstantSearch.status === \"stalled\"` instead.") : 0; + return this.status === 'stalled'; + } + }, { + key: "use", + value: function use() { + var _this2 = this; + for (var _len = arguments.length, middleware = new Array(_len), _key = 0; _key < _len; _key++) { + middleware[_key] = arguments[_key]; + } + var newMiddlewareList = middleware.map(function (fn) { + var newMiddleware = _objectSpread({ + $$type: '__unknown__', + $$internal: false, + subscribe: _utils_index_js__WEBPACK_IMPORTED_MODULE_8__.noop, + started: _utils_index_js__WEBPACK_IMPORTED_MODULE_8__.noop, + unsubscribe: _utils_index_js__WEBPACK_IMPORTED_MODULE_8__.noop, + onStateChange: _utils_index_js__WEBPACK_IMPORTED_MODULE_8__.noop + }, fn({ + instantSearchInstance: _this2 + })); + _this2.middleware.push({ + creator: fn, + instance: newMiddleware + }); + return newMiddleware; + }); + + // If the instance has already started, we directly subscribe the + // middleware so they're notified of changes. + if (this.started) { + newMiddlewareList.forEach(function (m) { + m.subscribe(); + m.started(); + }); + } + return this; + } + + /** + * Removes a middleware from the InstantSearch lifecycle. + */ + }, { + key: "unuse", + value: function unuse() { + for (var _len2 = arguments.length, middlewareToUnuse = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + middlewareToUnuse[_key2] = arguments[_key2]; + } + this.middleware.filter(function (m) { + return middlewareToUnuse.includes(m.creator); + }).forEach(function (m) { + return m.instance.unsubscribe(); + }); + this.middleware = this.middleware.filter(function (m) { + return !middlewareToUnuse.includes(m.creator); + }); + return this; + } + + // @major we shipped with EXPERIMENTAL_use, but have changed that to just `use` now + }, { + key: "EXPERIMENTAL_use", + value: function EXPERIMENTAL_use() { + true ? (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.warning)(false, 'The middleware API is now considered stable, so we recommend replacing `EXPERIMENTAL_use` with `use` before upgrading to the next major version.') : 0; + return this.use.apply(this, arguments); + } + + /** + * Adds a widget to the search instance. + * A widget can be added either before or after InstantSearch has started. + * @param widget The widget to add to InstantSearch. + * + * @deprecated This method will still be supported in 4.x releases, but not further. It is replaced by `addWidgets([widget])`. + */ + }, { + key: "addWidget", + value: function addWidget(widget) { + true ? (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.warning)(false, 'addWidget will still be supported in 4.x releases, but not further. It is replaced by `addWidgets([widget])`') : 0; + return this.addWidgets([widget]); + } + + /** + * Adds multiple widgets to the search instance. + * Widgets can be added either before or after InstantSearch has started. + * @param widgets The array of widgets to add to InstantSearch. + */ + }, { + key: "addWidgets", + value: function addWidgets(widgets) { + if (!Array.isArray(widgets)) { + throw new Error(withUsage('The `addWidgets` method expects an array of widgets. Please use `addWidget`.')); + } + if (widgets.some(function (widget) { + return typeof widget.init !== 'function' && typeof widget.render !== 'function'; + })) { + throw new Error(withUsage('The widget definition expects a `render` and/or an `init` method.')); + } + this.mainIndex.addWidgets(widgets); + return this; + } + + /** + * Removes a widget from the search instance. + * @deprecated This method will still be supported in 4.x releases, but not further. It is replaced by `removeWidgets([widget])` + * @param widget The widget instance to remove from InstantSearch. + * + * The widget must implement a `dispose()` method to clear its state. + */ + }, { + key: "removeWidget", + value: function removeWidget(widget) { + true ? (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.warning)(false, 'removeWidget will still be supported in 4.x releases, but not further. It is replaced by `removeWidgets([widget])`') : 0; + return this.removeWidgets([widget]); + } + + /** + * Removes multiple widgets from the search instance. + * @param widgets Array of widgets instances to remove from InstantSearch. + * + * The widgets must implement a `dispose()` method to clear their states. + */ + }, { + key: "removeWidgets", + value: function removeWidgets(widgets) { + if (!Array.isArray(widgets)) { + throw new Error(withUsage('The `removeWidgets` method expects an array of widgets. Please use `removeWidget`.')); + } + if (widgets.some(function (widget) { + return typeof widget.dispose !== 'function'; + })) { + throw new Error(withUsage('The widget definition expects a `dispose` method.')); + } + this.mainIndex.removeWidgets(widgets); + return this; + } + + /** + * Ends the initialization of InstantSearch.js and triggers the + * first search. This method should be called after all widgets have been added + * to the instance of InstantSearch.js. InstantSearch.js also supports adding and removing + * widgets after the start as an **EXPERIMENTAL** feature. + */ + }, { + key: "start", + value: function start() { + var _this3 = this; + if (this.started) { + throw new Error(withUsage('The `start` method has already been called once.')); + } + + // This Helper is used for the queries, we don't care about its state. The + // states are managed at the `index` level. We use this Helper to create + // DerivedHelper scoped into the `index` widgets. + // In Vue InstantSearch' hydrate, a main helper gets set before start, so + // we need to respect this helper as a way to keep all listeners correct. + var mainHelper = this.mainHelper || algoliasearch_helper__WEBPACK_IMPORTED_MODULE_1__(this.client, this.indexName); + mainHelper.search = function () { + _this3.status = 'loading'; + _this3.scheduleRender(false); + + // This solution allows us to keep the exact same API for the users but + // under the hood, we have a different implementation. It should be + // completely transparent for the rest of the codebase. Only this module + // is impacted. + return mainHelper.searchOnlyWithDerivedHelpers(); + }; + if (this._searchFunction) { + // this client isn't used to actually search, but required for the helper + // to not throw errors + var fakeClient = { + search: function search() { + return new Promise(_utils_index_js__WEBPACK_IMPORTED_MODULE_8__.noop); + } + }; + this._mainHelperSearch = mainHelper.search.bind(mainHelper); + mainHelper.search = function () { + var mainIndexHelper = _this3.mainIndex.getHelper(); + var searchFunctionHelper = algoliasearch_helper__WEBPACK_IMPORTED_MODULE_1__(fakeClient, mainIndexHelper.state.index, mainIndexHelper.state); + searchFunctionHelper.once('search', function (_ref2) { + var state = _ref2.state; + mainIndexHelper.overrideStateWithoutTriggeringChangeEvent(state); + _this3._mainHelperSearch(); + }); + // Forward state changes from `searchFunctionHelper` to `mainIndexHelper` + searchFunctionHelper.on('change', function (_ref3) { + var state = _ref3.state; + mainIndexHelper.setState(state); + }); + _this3._searchFunction(searchFunctionHelper); + return mainHelper; + }; + } + + // Only the "main" Helper emits the `error` event vs the one for `search` + // and `results` that are also emitted on the derived one. + mainHelper.on('error', function (_ref4) { + var error = _ref4.error; + if (!(error instanceof Error)) { + // typescript lies here, error is in some cases { name: string, message: string } + var err = error; + error = Object.keys(err).reduce(function (acc, key) { + acc[key] = err[key]; + return acc; + }, new Error(err.message)); + } + // If an error is emitted, it is re-thrown by events. In previous versions + // we emitted {error}, which is thrown as: + // "Uncaught, unspecified \"error\" event. ([object Object])" + // To avoid breaking changes, we make the error available in both + // `error` and `error.error` + // @MAJOR emit only error + error.error = error; + _this3.error = error; + _this3.status = 'error'; + _this3.scheduleRender(false); + + // This needs to execute last because it throws the error. + _this3.emit('error', error); + }); + this.mainHelper = mainHelper; + this.middleware.forEach(function (_ref5) { + var instance = _ref5.instance; + instance.subscribe(); + }); + this.mainIndex.init({ + instantSearchInstance: this, + parent: null, + uiState: this._initialUiState + }); + if (this._initialResults) { + var originalScheduleSearch = this.scheduleSearch; + // We don't schedule a first search when initial results are provided + // because we already have the results to render. This skips the initial + // network request on the browser on `start`. + this.scheduleSearch = (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.defer)(_utils_index_js__WEBPACK_IMPORTED_MODULE_8__.noop); + // We also skip the initial network request when widgets are dynamically + // added in the first tick (that's the case in all the framework-based flavors). + // When we add a widget to `index`, it calls `scheduleSearch`. We can rely + // on our `defer` util to restore the original `scheduleSearch` value once + // widgets are added to hook back to the regular lifecycle. + (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.defer)(function () { + _this3.scheduleSearch = originalScheduleSearch; + })(); + } + // We only schedule a search when widgets have been added before `start()` + // because there are listeners that can use these results. + // This is especially useful in framework-based flavors that wait for + // dynamically-added widgets to trigger a network request. It avoids + // having to batch this initial network request with the one coming from + // `addWidgets()`. + // Later, we could also skip `index()` widgets and widgets that don't read + // the results, but this is an optimization that has a very low impact for now. + else if (this.mainIndex.getWidgets().length > 0) { + this.scheduleSearch(); + } + + // Keep the previous reference for legacy purpose, some pattern use + // the direct Helper access `search.helper` (e.g multi-index). + this.helper = this.mainIndex.getHelper(); + + // track we started the search if we add more widgets, + // to init them directly after add + this.started = true; + this.middleware.forEach(function (_ref6) { + var instance = _ref6.instance; + instance.started(); + }); + } + + /** + * Removes all widgets without triggering a search afterwards. This is an **EXPERIMENTAL** feature, + * if you find an issue with it, please + * [open an issue](https://github.com/algolia/instantsearch.js/issues/new?title=Problem%20with%20dispose). + * @return {undefined} This method does not return anything + */ + }, { + key: "dispose", + value: function dispose() { + var _this$mainHelper2; + this.scheduleSearch.cancel(); + this.scheduleRender.cancel(); + clearTimeout(this._searchStalledTimer); + this.removeWidgets(this.mainIndex.getWidgets()); + this.mainIndex.dispose(); + + // You can not start an instance two times, therefore a disposed instance + // needs to set started as false otherwise this can not be restarted at a + // later point. + this.started = false; + + // The helper needs to be reset to perform the next search from a fresh state. + // If not reset, it would use the state stored before calling `dispose()`. + this.removeAllListeners(); + (_this$mainHelper2 = this.mainHelper) === null || _this$mainHelper2 === void 0 ? void 0 : _this$mainHelper2.removeAllListeners(); + this.mainHelper = null; + this.helper = null; + this.middleware.forEach(function (_ref7) { + var instance = _ref7.instance; + instance.unsubscribe(); + }); + } + }, { + key: "scheduleStalledRender", + value: function scheduleStalledRender() { + var _this4 = this; + if (!this._searchStalledTimer) { + this._searchStalledTimer = setTimeout(function () { + _this4.status = 'stalled'; + _this4.scheduleRender(); + }, this._stalledSearchDelay); + } + } + + /** + * Set the UI state and trigger a search. + * @param uiState The next UI state or a function computing it from the current state + * @param callOnStateChange private parameter used to know if the method is called from a state change + */ + }, { + key: "setUiState", + value: function setUiState(uiState) { + var _this5 = this; + var callOnStateChange = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true; + if (!this.mainHelper) { + throw new Error(withUsage('The `start` method needs to be called before `setUiState`.')); + } + + // We refresh the index UI state to update the local UI state that the + // main index passes to the function form of `setUiState`. + this.mainIndex.refreshUiState(); + var nextUiState = typeof uiState === 'function' ? uiState(this.mainIndex.getWidgetUiState({})) : uiState; + if (this.onStateChange && callOnStateChange) { + this.onStateChange({ + uiState: nextUiState, + setUiState: function setUiState(finalUiState) { + (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_12__.setIndexHelperState)(typeof finalUiState === 'function' ? finalUiState(nextUiState) : finalUiState, _this5.mainIndex); + _this5.scheduleSearch(); + _this5.onInternalStateChange(); + } + }); + } else { + (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_12__.setIndexHelperState)(nextUiState, this.mainIndex); + this.scheduleSearch(); + this.onInternalStateChange(); + } + } + }, { + key: "getUiState", + value: function getUiState() { + if (this.started) { + // We refresh the index UI state to make sure changes from `refine` are taken in account + this.mainIndex.refreshUiState(); + } + return this.mainIndex.getWidgetUiState({}); + } + }, { + key: "createURL", + value: function createURL() { + var nextState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (!this.started) { + throw new Error(withUsage('The `start` method needs to be called before `createURL`.')); + } + return this._createURL(nextState); + } + }, { + key: "refresh", + value: function refresh() { + if (!this.mainHelper) { + throw new Error(withUsage('The `start` method needs to be called before `refresh`.')); + } + this.mainHelper.clearCache().search(); + } + }]); + return InstantSearch; +}(_algolia_events__WEBPACK_IMPORTED_MODULE_0__); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (InstantSearch); + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/createHelpers.js": +/*!***************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/createHelpers.js ***! + \***************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ hoganHelpers) +/* harmony export */ }); +/* harmony import */ var _helpers_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../helpers/index.js */ "./node_modules/instantsearch.js/es/helpers/highlight.js"); +/* harmony import */ var _helpers_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../helpers/index.js */ "./node_modules/instantsearch.js/es/helpers/reverseHighlight.js"); +/* harmony import */ var _helpers_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../helpers/index.js */ "./node_modules/instantsearch.js/es/helpers/snippet.js"); +/* harmony import */ var _helpers_index_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../helpers/index.js */ "./node_modules/instantsearch.js/es/helpers/reverseSnippet.js"); +/* harmony import */ var _helpers_index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../helpers/index.js */ "./node_modules/instantsearch.js/es/helpers/insights.js"); +/* harmony import */ var _formatNumber_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./formatNumber.js */ "./node_modules/instantsearch.js/es/lib/formatNumber.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + +function hoganHelpers(_ref) { + var numberLocale = _ref.numberLocale; + return { + formatNumber: function formatNumber(value, render) { + return (0,_formatNumber_js__WEBPACK_IMPORTED_MODULE_0__.formatNumber)(Number(render(value)), numberLocale); + }, + highlight: function highlight(options, render) { + try { + var highlightOptions = JSON.parse(options); + return render((0,_helpers_index_js__WEBPACK_IMPORTED_MODULE_1__["default"])(_objectSpread(_objectSpread({}, highlightOptions), {}, { + hit: this + }))); + } catch (error) { + throw new Error("\nThe highlight helper expects a JSON object of the format:\n{ \"attribute\": \"name\", \"highlightedTagName\": \"mark\" }"); + } + }, + reverseHighlight: function reverseHighlight(options, render) { + try { + var reverseHighlightOptions = JSON.parse(options); + return render((0,_helpers_index_js__WEBPACK_IMPORTED_MODULE_2__["default"])(_objectSpread(_objectSpread({}, reverseHighlightOptions), {}, { + hit: this + }))); + } catch (error) { + throw new Error("\n The reverseHighlight helper expects a JSON object of the format:\n { \"attribute\": \"name\", \"highlightedTagName\": \"mark\" }"); + } + }, + snippet: function snippet(options, render) { + try { + var snippetOptions = JSON.parse(options); + return render((0,_helpers_index_js__WEBPACK_IMPORTED_MODULE_3__["default"])(_objectSpread(_objectSpread({}, snippetOptions), {}, { + hit: this + }))); + } catch (error) { + throw new Error("\nThe snippet helper expects a JSON object of the format:\n{ \"attribute\": \"name\", \"highlightedTagName\": \"mark\" }"); + } + }, + reverseSnippet: function reverseSnippet(options, render) { + try { + var reverseSnippetOptions = JSON.parse(options); + return render((0,_helpers_index_js__WEBPACK_IMPORTED_MODULE_4__["default"])(_objectSpread(_objectSpread({}, reverseSnippetOptions), {}, { + hit: this + }))); + } catch (error) { + throw new Error("\n The reverseSnippet helper expects a JSON object of the format:\n { \"attribute\": \"name\", \"highlightedTagName\": \"mark\" }"); + } + }, + insights: function insights(options, render) { + try { + var _JSON$parse = JSON.parse(options), + method = _JSON$parse.method, + payload = _JSON$parse.payload; + return render((0,_helpers_index_js__WEBPACK_IMPORTED_MODULE_5__["default"])(method, _objectSpread({ + objectIDs: [this.objectID] + }, payload))); + } catch (error) { + throw new Error("\nThe insights helper expects a JSON object of the format:\n{ \"method\": \"method-name\", \"payload\": { \"eventName\": \"name of the event\" } }"); + } + } + }; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/formatNumber.js": +/*!**************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/formatNumber.js ***! + \**************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "formatNumber": () => (/* binding */ formatNumber) +/* harmony export */ }); +function formatNumber(value, numberLocale) { + return value.toLocaleString(numberLocale); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/routers/history.js": +/*!*****************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/routers/history.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ historyRouter) +/* harmony export */ }); +/* harmony import */ var qs__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! qs */ "./node_modules/instantsearch.js/node_modules/qs/lib/index.js"); +/* harmony import */ var _utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/safelyRunOnBrowser.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } +function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } } +function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + +var setWindowTitle = function setWindowTitle(title) { + if (title) { + // This function is only executed on browsers so we can disable this check. + // eslint-disable-next-line no-restricted-globals + window.document.title = title; + } +}; +var BrowserHistory = /*#__PURE__*/function () { + /** + * Initializes a new storage provider that syncs the search state to the URL + * using web APIs (`window.location.pushState` and `onpopstate` event). + */ + function BrowserHistory(_ref) { + var _this = this; + var windowTitle = _ref.windowTitle, + _ref$writeDelay = _ref.writeDelay, + writeDelay = _ref$writeDelay === void 0 ? 400 : _ref$writeDelay, + createURL = _ref.createURL, + parseURL = _ref.parseURL, + getLocation = _ref.getLocation, + start = _ref.start, + dispose = _ref.dispose, + push = _ref.push; + _classCallCheck(this, BrowserHistory); + _defineProperty(this, "$$type", 'ais.browser'); + _defineProperty(this, "windowTitle", void 0); + _defineProperty(this, "writeDelay", void 0); + _defineProperty(this, "_createURL", void 0); + _defineProperty(this, "parseURL", void 0); + _defineProperty(this, "getLocation", void 0); + _defineProperty(this, "writeTimer", void 0); + _defineProperty(this, "inPopState", false); + _defineProperty(this, "isDisposed", false); + _defineProperty(this, "latestAcknowledgedHistory", 0); + _defineProperty(this, "_start", void 0); + _defineProperty(this, "_dispose", void 0); + _defineProperty(this, "_push", void 0); + this.windowTitle = windowTitle; + this.writeTimer = undefined; + this.writeDelay = writeDelay; + this._createURL = createURL; + this.parseURL = parseURL; + this.getLocation = getLocation; + this._start = start; + this._dispose = dispose; + this._push = push; + (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.safelyRunOnBrowser)(function (_ref2) { + var window = _ref2.window; + var title = _this.windowTitle && _this.windowTitle(_this.read()); + setWindowTitle(title); + _this.latestAcknowledgedHistory = window.history.length; + }); + } + + /** + * Reads the URL and returns a syncable UI search state. + */ + _createClass(BrowserHistory, [{ + key: "read", + value: function read() { + return this.parseURL({ + qsModule: qs__WEBPACK_IMPORTED_MODULE_0__, + location: this.getLocation() + }); + } + + /** + * Pushes a search state into the URL. + */ + }, { + key: "write", + value: function write(routeState) { + var _this2 = this; + (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.safelyRunOnBrowser)(function (_ref3) { + var window = _ref3.window; + var url = _this2.createURL(routeState); + var title = _this2.windowTitle && _this2.windowTitle(routeState); + if (_this2.writeTimer) { + clearTimeout(_this2.writeTimer); + } + _this2.writeTimer = setTimeout(function () { + setWindowTitle(title); + if (_this2.shouldWrite(url)) { + if (_this2._push) { + _this2._push(url); + } else { + window.history.pushState(routeState, title || '', url); + } + _this2.latestAcknowledgedHistory = window.history.length; + } + _this2.inPopState = false; + _this2.writeTimer = undefined; + }, _this2.writeDelay); + }); + } + + /** + * Sets a callback on the `onpopstate` event of the history API of the current page. + * It enables the URL sync to keep track of the changes. + */ + }, { + key: "onUpdate", + value: function onUpdate(callback) { + var _this3 = this; + if (this._start) { + this._start(function () { + callback(_this3.read()); + }); + } + this._onPopState = function () { + if (_this3.writeTimer) { + clearTimeout(_this3.writeTimer); + _this3.writeTimer = undefined; + } + _this3.inPopState = true; + + // We always read the state from the URL because the state of the history + // can be incorect in some cases (e.g. using React Router). + callback(_this3.read()); + }; + (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.safelyRunOnBrowser)(function (_ref4) { + var window = _ref4.window; + window.addEventListener('popstate', _this3._onPopState); + }); + } + + /** + * Creates a complete URL from a given syncable UI state. + * + * It always generates the full URL, not a relative one. + * This allows to handle cases like using a . + * See: https://github.com/algolia/instantsearch.js/issues/790 + */ + }, { + key: "createURL", + value: function createURL(routeState) { + return this._createURL({ + qsModule: qs__WEBPACK_IMPORTED_MODULE_0__, + routeState: routeState, + location: this.getLocation() + }); + } + + /** + * Removes the event listener and cleans up the URL. + */ + }, { + key: "dispose", + value: function dispose() { + var _this4 = this; + if (this._dispose) { + this._dispose(); + } + this.isDisposed = true; + (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.safelyRunOnBrowser)(function (_ref5) { + var window = _ref5.window; + if (_this4._onPopState) { + window.removeEventListener('popstate', _this4._onPopState); + } + }); + if (this.writeTimer) { + clearTimeout(this.writeTimer); + } + this.write({}); + } + }, { + key: "start", + value: function start() { + this.isDisposed = false; + } + }, { + key: "shouldWrite", + value: function shouldWrite(url) { + var _this5 = this; + return (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.safelyRunOnBrowser)(function (_ref6) { + var window = _ref6.window; + // We do want to `pushState` if: + // - the router is not disposed, IS.js needs to update the URL + // OR + // - the last write was from InstantSearch.js + // (unlike a SPA, where it would have last written) + var lastPushWasByISAfterDispose = !(_this5.isDisposed && _this5.latestAcknowledgedHistory !== window.history.length); + return ( + // When the last state change was through popstate, the IS.js state changes, + // but that should not write the URL. + !_this5.inPopState && + // When the previous pushState after dispose was by IS.js, we want to write the URL. + lastPushWasByISAfterDispose && + // When the URL is the same as the current one, we do not want to write it. + url !== window.location.href + ); + }); + } + }]); + return BrowserHistory; +}(); +function historyRouter() { + var _ref7 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, + _ref7$createURL = _ref7.createURL, + createURL = _ref7$createURL === void 0 ? function (_ref8) { + var qsModule = _ref8.qsModule, + routeState = _ref8.routeState, + location = _ref8.location; + var protocol = location.protocol, + hostname = location.hostname, + _location$port = location.port, + port = _location$port === void 0 ? '' : _location$port, + pathname = location.pathname, + hash = location.hash; + var queryString = qsModule.stringify(routeState); + var portWithPrefix = port === '' ? '' : ":".concat(port); + + // IE <= 11 has no proper `location.origin` so we cannot rely on it. + if (!queryString) { + return "".concat(protocol, "//").concat(hostname).concat(portWithPrefix).concat(pathname).concat(hash); + } + return "".concat(protocol, "//").concat(hostname).concat(portWithPrefix).concat(pathname, "?").concat(queryString).concat(hash); + } : _ref7$createURL, + _ref7$parseURL = _ref7.parseURL, + parseURL = _ref7$parseURL === void 0 ? function (_ref9) { + var qsModule = _ref9.qsModule, + location = _ref9.location; + // `qs` by default converts arrays with more than 20 items to an object. + // We want to avoid this because the data structure manipulated can therefore vary. + // Setting the limit to `100` seems a good number because the engine's default is 100 + // (it can go up to 1000 but it is very unlikely to select more than 100 items in the UI). + // + // Using an `arrayLimit` of `n` allows `n + 1` items. + // + // See: + // - https://github.com/ljharb/qs#parsing-arrays + // - https://www.algolia.com/doc/api-reference/api-parameters/maxValuesPerFacet/ + return qsModule.parse(location.search.slice(1), { + arrayLimit: 99 + }); + } : _ref7$parseURL, + _ref7$writeDelay = _ref7.writeDelay, + writeDelay = _ref7$writeDelay === void 0 ? 400 : _ref7$writeDelay, + windowTitle = _ref7.windowTitle, + _ref7$getLocation = _ref7.getLocation, + getLocation = _ref7$getLocation === void 0 ? function () { + return (0,_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.safelyRunOnBrowser)(function (_ref10) { + var window = _ref10.window; + return window.location; + }, { + fallback: function fallback() { + throw new Error('You need to provide `getLocation` to the `history` router in environments where `window` does not exist.'); + } + }); + } : _ref7$getLocation, + start = _ref7.start, + dispose = _ref7.dispose, + push = _ref7.push; + return new BrowserHistory({ + createURL: createURL, + parseURL: parseURL, + writeDelay: writeDelay, + windowTitle: windowTitle, + getLocation: getLocation, + start: start, + dispose: dispose, + push: push + }); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/stateMappings/simple.js": +/*!**********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/stateMappings/simple.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (/* binding */ simpleStateMapping) +/* harmony export */ }); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +var _excluded = ["configure"]; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } +function getIndexStateWithoutConfigure(uiState) { + var configure = uiState.configure, + trackedUiState = _objectWithoutProperties(uiState, _excluded); + return trackedUiState; +} + +// technically a URL could contain any key, since users provide it, +// which is why the input to this function is UiState, not something +// which excludes "configure" as this function does. +function simpleStateMapping() { + return { + $$type: 'ais.simple', + stateToRoute: function stateToRoute(uiState) { + return Object.keys(uiState).reduce(function (state, indexId) { + return _objectSpread(_objectSpread({}, state), {}, _defineProperty({}, indexId, getIndexStateWithoutConfigure(uiState[indexId]))); + }, {}); + }, + routeToState: function routeToState() { + var routeState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + return Object.keys(routeState).reduce(function (state, indexId) { + return _objectSpread(_objectSpread({}, state), {}, _defineProperty({}, indexId, getIndexStateWithoutConfigure(routeState[indexId]))); + }, {}); + } + }; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/suit.js": +/*!******************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/suit.js ***! + \******************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "component": () => (/* binding */ component) +/* harmony export */ }); +var NAMESPACE = 'ais'; +var component = function component(componentName) { + return function () { + var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, + descendantName = _ref.descendantName, + modifierName = _ref.modifierName; + var descendent = descendantName ? "-".concat(descendantName) : ''; + var modifier = modifierName ? "--".concat(modifierName) : ''; + return "".concat(NAMESPACE, "-").concat(componentName).concat(descendent).concat(modifier); + }; +}; + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/capitalize.js": +/*!******************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/capitalize.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "capitalize": () => (/* binding */ capitalize) +/* harmony export */ }); +function capitalize(text) { + return text.toString().charAt(0).toUpperCase() + text.toString().slice(1); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/checkIndexUiState.js": +/*!*************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/checkIndexUiState.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "checkIndexUiState": () => (/* binding */ checkIndexUiState) +/* harmony export */ }); +/* harmony import */ var _capitalize_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./capitalize.js */ "./node_modules/instantsearch.js/es/lib/utils/capitalize.js"); +/* harmony import */ var _logger_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./logger.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +/* harmony import */ var _typedObject_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./typedObject.js */ "./node_modules/instantsearch.js/es/lib/utils/typedObject.js"); +function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + + + +// Some connectors are responsible for multiple widgets so we need +// to map them. +function getWidgetNames(connectorName) { + switch (connectorName) { + case 'range': + return []; + case 'menu': + return ['menu', 'menuSelect']; + default: + return [connectorName]; + } +} +var stateToWidgetsMap = { + query: { + connectors: ['connectSearchBox'], + widgets: ['ais.searchBox', 'ais.autocomplete', 'ais.voiceSearch'] + }, + refinementList: { + connectors: ['connectRefinementList'], + widgets: ['ais.refinementList'] + }, + menu: { + connectors: ['connectMenu'], + widgets: ['ais.menu'] + }, + hierarchicalMenu: { + connectors: ['connectHierarchicalMenu'], + widgets: ['ais.hierarchicalMenu'] + }, + numericMenu: { + connectors: ['connectNumericMenu'], + widgets: ['ais.numericMenu'] + }, + ratingMenu: { + connectors: ['connectRatingMenu'], + widgets: ['ais.ratingMenu'] + }, + range: { + connectors: ['connectRange'], + widgets: ['ais.rangeInput', 'ais.rangeSlider', 'ais.range'] + }, + toggle: { + connectors: ['connectToggleRefinement'], + widgets: ['ais.toggleRefinement'] + }, + geoSearch: { + connectors: ['connectGeoSearch'], + widgets: ['ais.geoSearch'] + }, + sortBy: { + connectors: ['connectSortBy'], + widgets: ['ais.sortBy'] + }, + page: { + connectors: ['connectPagination'], + widgets: ['ais.pagination', 'ais.infiniteHits'] + }, + hitsPerPage: { + connectors: ['connectHitsPerPage'], + widgets: ['ais.hitsPerPage'] + }, + configure: { + connectors: ['connectConfigure'], + widgets: ['ais.configure'] + }, + places: { + connectors: [], + widgets: ['ais.places'] + } +}; +function checkIndexUiState(_ref) { + var index = _ref.index, + indexUiState = _ref.indexUiState; + var mountedWidgets = index.getWidgets().map(function (widget) { + return widget.$$type; + }).filter(Boolean); + var missingWidgets = (0,_typedObject_js__WEBPACK_IMPORTED_MODULE_0__.keys)(indexUiState).reduce(function (acc, parameter) { + var widgetUiState = stateToWidgetsMap[parameter]; + if (!widgetUiState) { + return acc; + } + var requiredWidgets = widgetUiState.widgets; + if (requiredWidgets && !requiredWidgets.some(function (requiredWidget) { + return mountedWidgets.includes(requiredWidget); + })) { + acc.push([parameter, { + connectors: widgetUiState.connectors, + widgets: widgetUiState.widgets.map(function (widgetIdentifier) { + return widgetIdentifier.split('ais.')[1]; + }) + }]); + } + return acc; + }, []); + true ? (0,_logger_js__WEBPACK_IMPORTED_MODULE_1__.warning)(missingWidgets.length === 0, "The UI state for the index \"".concat(index.getIndexId(), "\" is not consistent with the widgets mounted.\n\nThis can happen when the UI state is specified via `initialUiState`, `routing` or `setUiState` but that the widgets responsible for this state were not added. This results in those query parameters not being sent to the API.\n\nTo fully reflect the state, some widgets need to be added to the index \"").concat(index.getIndexId(), "\":\n\n").concat(missingWidgets.map(function (_ref2) { + var _ref4; + var _ref3 = _slicedToArray(_ref2, 2), + stateParameter = _ref3[0], + widgets = _ref3[1].widgets; + return "- `".concat(stateParameter, "` needs one of these widgets: ").concat((_ref4 = []).concat.apply(_ref4, _toConsumableArray(widgets.map(function (name) { + return getWidgetNames(name); + }))).map(function (name) { + return "\"".concat(name, "\""); + }).join(', ')); + }).join('\n'), "\n\nIf you do not wish to display widgets but still want to support their search parameters, you can mount \"virtual widgets\" that don't render anything:\n\n```\n").concat(missingWidgets.filter(function (_ref5) { + var _ref6 = _slicedToArray(_ref5, 2), + _stateParameter = _ref6[0], + connectors = _ref6[1].connectors; + return connectors.length > 0; + }).map(function (_ref7) { + var _ref8 = _slicedToArray(_ref7, 2), + _stateParameter = _ref8[0], + _ref8$ = _ref8[1], + connectors = _ref8$.connectors, + widgets = _ref8$.widgets; + var capitalizedWidget = (0,_capitalize_js__WEBPACK_IMPORTED_MODULE_2__.capitalize)(widgets[0]); + var connectorName = connectors[0]; + return "const virtual".concat(capitalizedWidget, " = ").concat(connectorName, "(() => null);"); + }).join('\n'), "\n\nsearch.addWidgets([\n ").concat(missingWidgets.filter(function (_ref9) { + var _ref10 = _slicedToArray(_ref9, 2), + _stateParameter = _ref10[0], + connectors = _ref10[1].connectors; + return connectors.length > 0; + }).map(function (_ref11) { + var _ref12 = _slicedToArray(_ref11, 2), + _stateParameter = _ref12[0], + widgets = _ref12[1].widgets; + var capitalizedWidget = (0,_capitalize_js__WEBPACK_IMPORTED_MODULE_2__.capitalize)(widgets[0]); + return "virtual".concat(capitalizedWidget, "({ /* ... */ })"); + }).join(',\n '), "\n]);\n```\n\nIf you're using custom widgets that do set these query parameters, we recommend using connectors instead.\n\nSee https://www.algolia.com/doc/guides/building-search-ui/widgets/customize-an-existing-widget/js/#customize-the-complete-ui-of-the-widgets")) : 0; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/checkRendering.js": +/*!**********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/checkRendering.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "checkRendering": () => (/* binding */ checkRendering) +/* harmony export */ }); +/* harmony import */ var _getObjectType_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./getObjectType.js */ "./node_modules/instantsearch.js/es/lib/utils/getObjectType.js"); + +function checkRendering(rendering, usage) { + if (rendering === undefined || typeof rendering !== 'function') { + throw new Error("The render function is not valid (received type ".concat((0,_getObjectType_js__WEBPACK_IMPORTED_MODULE_0__.getObjectType)(rendering), ").\n\n").concat(usage)); + } +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/concatHighlightedParts.js": +/*!******************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/concatHighlightedParts.js ***! + \******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "concatHighlightedParts": () => (/* binding */ concatHighlightedParts) +/* harmony export */ }); +/* harmony import */ var _escape_highlight_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./escape-highlight.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js"); + +function concatHighlightedParts(parts) { + var highlightPreTag = _escape_highlight_js__WEBPACK_IMPORTED_MODULE_0__.TAG_REPLACEMENT.highlightPreTag, + highlightPostTag = _escape_highlight_js__WEBPACK_IMPORTED_MODULE_0__.TAG_REPLACEMENT.highlightPostTag; + return parts.map(function (part) { + return part.isHighlighted ? highlightPreTag + part.value + highlightPostTag : part.value; + }).join(''); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/defer.js": +/*!*************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/defer.js ***! + \*************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "defer": () => (/* binding */ defer) +/* harmony export */ }); +var nextMicroTask = Promise.resolve(); +function defer(callback) { + var progress = null; + var cancelled = false; + var fn = function fn() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + if (progress !== null) { + return; + } + progress = nextMicroTask.then(function () { + progress = null; + if (cancelled) { + cancelled = false; + return; + } + callback.apply(void 0, args); + }); + }; + fn.wait = function () { + if (progress === null) { + throw new Error('The deferred function should be called before calling `wait()`'); + } + return progress; + }; + fn.cancel = function () { + if (progress === null) { + return; + } + cancelled = true; + }; + return fn; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/documentation.js": +/*!*********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/documentation.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "createDocumentationLink": () => (/* binding */ createDocumentationLink), +/* harmony export */ "createDocumentationMessageGenerator": () => (/* binding */ createDocumentationMessageGenerator) +/* harmony export */ }); +function createDocumentationLink(_ref) { + var name = _ref.name, + _ref$connector = _ref.connector, + connector = _ref$connector === void 0 ? false : _ref$connector; + return ['https://www.algolia.com/doc/api-reference/widgets/', name, '/js/', connector ? '#connector' : ''].join(''); +} +function createDocumentationMessageGenerator() { + for (var _len = arguments.length, widgets = new Array(_len), _key = 0; _key < _len; _key++) { + widgets[_key] = arguments[_key]; + } + var links = widgets.map(function (widget) { + return createDocumentationLink(widget); + }).join(', '); + return function (message) { + return [message, "See documentation: ".concat(links)].filter(Boolean).join('\n\n'); + }; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js": +/*!************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js ***! + \************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "TAG_PLACEHOLDER": () => (/* binding */ TAG_PLACEHOLDER), +/* harmony export */ "TAG_REPLACEMENT": () => (/* binding */ TAG_REPLACEMENT), +/* harmony export */ "escapeFacets": () => (/* binding */ escapeFacets), +/* harmony export */ "escapeHits": () => (/* binding */ escapeHits) +/* harmony export */ }); +/* harmony import */ var _escape_html_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./escape-html.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-html.js"); +/* harmony import */ var _isPlainObject_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./isPlainObject.js */ "./node_modules/instantsearch.js/es/lib/utils/isPlainObject.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function _objectDestructuringEmpty(obj) { if (obj == null) throw new TypeError("Cannot destructure " + obj); } +function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + +var TAG_PLACEHOLDER = { + highlightPreTag: '__ais-highlight__', + highlightPostTag: '__/ais-highlight__' +}; +var TAG_REPLACEMENT = { + highlightPreTag: '', + highlightPostTag: '' +}; +function replaceTagsAndEscape(value) { + return (0,_escape_html_js__WEBPACK_IMPORTED_MODULE_0__.escape)(value).replace(new RegExp(TAG_PLACEHOLDER.highlightPreTag, 'g'), TAG_REPLACEMENT.highlightPreTag).replace(new RegExp(TAG_PLACEHOLDER.highlightPostTag, 'g'), TAG_REPLACEMENT.highlightPostTag); +} +function recursiveEscape(input) { + if ((0,_isPlainObject_js__WEBPACK_IMPORTED_MODULE_1__.isPlainObject)(input) && typeof input.value !== 'string') { + return Object.keys(input).reduce(function (acc, key) { + return _objectSpread(_objectSpread({}, acc), {}, _defineProperty({}, key, recursiveEscape(input[key]))); + }, {}); + } + if (Array.isArray(input)) { + return input.map(recursiveEscape); + } + return _objectSpread(_objectSpread({}, input), {}, { + value: replaceTagsAndEscape(input.value) + }); +} +function escapeHits(hits) { + if (hits.__escaped === undefined) { + // We don't override the value on hit because it will mutate the raw results + // instead we make a shallow copy and we assign the escaped values on it. + hits = hits.map(function (_ref) { + var hit = _extends({}, (_objectDestructuringEmpty(_ref), _ref)); + if (hit._highlightResult) { + hit._highlightResult = recursiveEscape(hit._highlightResult); + } + if (hit._snippetResult) { + hit._snippetResult = recursiveEscape(hit._snippetResult); + } + return hit; + }); + hits.__escaped = true; + } + return hits; +} +function escapeFacets(facetHits) { + return facetHits.map(function (h) { + return _objectSpread(_objectSpread({}, h), {}, { + highlighted: replaceTagsAndEscape(h.highlighted) + }); + }); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/escape-html.js": +/*!*******************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/escape-html.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "escape": () => (/* binding */ escape), +/* harmony export */ "unescape": () => (/* binding */ unescape) +/* harmony export */ }); +/** + * This implementation is taken from Lodash implementation. + * See: https://github.com/lodash/lodash/blob/4.17.11-npm/escape.js + */ + +// Used to map characters to HTML entities. +var htmlEntities = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + "'": ''' +}; + +// Used to match HTML entities and HTML characters. +var regexUnescapedHtml = /[&<>"']/g; +var regexHasUnescapedHtml = RegExp(regexUnescapedHtml.source); + +/** + * Converts the characters "&", "<", ">", '"', and "'" in `string` to their + * corresponding HTML entities. + */ +function escape(value) { + return value && regexHasUnescapedHtml.test(value) ? value.replace(regexUnescapedHtml, function (character) { + return htmlEntities[character]; + }) : value; +} + +/** + * This implementation is taken from Lodash implementation. + * See: https://github.com/lodash/lodash/blob/4.17.11-npm/unescape.js + */ + +// Used to map HTML entities to characters. +var htmlCharacters = { + '&': '&', + '<': '<', + '>': '>', + '"': '"', + ''': "'" +}; + +// Used to match HTML entities and HTML characters. +var regexEscapedHtml = /&(amp|quot|lt|gt|#39);/g; +var regexHasEscapedHtml = RegExp(regexEscapedHtml.source); + +/** + * Converts the HTML entities "&", "<", ">", '"', and "'" in `string` to their + * characters. + */ +function unescape(value) { + return value && regexHasEscapedHtml.test(value) ? value.replace(regexEscapedHtml, function (character) { + return htmlCharacters[character]; + }) : value; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/find.js": +/*!************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/find.js ***! + \************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "find": () => (/* binding */ find) +/* harmony export */ }); +// We aren't using the native `Array.prototype.find` because the refactor away from Lodash is not +// published as a major version. +// Relying on the `find` polyfill on user-land, which before was only required for niche use-cases, +// was decided as too risky. +// @MAJOR Replace with the native `Array.prototype.find` method +// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find +function find(items, predicate) { + var value; + for (var i = 0; i < items.length; i++) { + value = items[i]; + // inlined for performance: if (Call(predicate, thisArg, [value, i, list])) { + if (predicate(value, i, items)) { + return value; + } + } + return undefined; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/findIndex.js": +/*!*****************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/findIndex.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "findIndex": () => (/* binding */ findIndex) +/* harmony export */ }); +// We aren't using the native `Array.prototype.findIndex` because the refactor away from Lodash is not +// published as a major version. +// Relying on the `findIndex` polyfill on user-land, which before was only required for niche use-cases, +// was decided as too risky. +// @MAJOR Replace with the native `Array.prototype.findIndex` method +// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex +function findIndex(array, comparator) { + if (!Array.isArray(array)) { + return -1; + } + for (var i = 0; i < array.length; i++) { + if (comparator(array[i])) { + return i; + } + } + return -1; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/getAppIdAndApiKey.js": +/*!*************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/getAppIdAndApiKey.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "getAppIdAndApiKey": () => (/* binding */ getAppIdAndApiKey) +/* harmony export */ }); +// typed as any, since it accepts the _real_ js clients, not the interface we otherwise expect +function getAppIdAndApiKey(searchClient) { + if (searchClient.transporter) { + // searchClient v4 + var _searchClient$transpo = searchClient.transporter, + headers = _searchClient$transpo.headers, + queryParameters = _searchClient$transpo.queryParameters; + var APP_ID = 'x-algolia-application-id'; + var API_KEY = 'x-algolia-api-key'; + var appId = headers[APP_ID] || queryParameters[APP_ID]; + var apiKey = headers[API_KEY] || queryParameters[API_KEY]; + return [appId, apiKey]; + } else { + // searchClient v3 + return [searchClient.applicationID, searchClient.apiKey]; + } +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/getHighlightFromSiblings.js": +/*!********************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/getHighlightFromSiblings.js ***! + \********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "getHighlightFromSiblings": () => (/* binding */ getHighlightFromSiblings) +/* harmony export */ }); +/* harmony import */ var _escape_html_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./escape-html.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-html.js"); + +var hasAlphanumeric = new RegExp(/\w/i); +function getHighlightFromSiblings(parts, i) { + var _parts, _parts2; + var current = parts[i]; + var isNextHighlighted = ((_parts = parts[i + 1]) === null || _parts === void 0 ? void 0 : _parts.isHighlighted) || true; + var isPreviousHighlighted = ((_parts2 = parts[i - 1]) === null || _parts2 === void 0 ? void 0 : _parts2.isHighlighted) || true; + if (!hasAlphanumeric.test((0,_escape_html_js__WEBPACK_IMPORTED_MODULE_0__.unescape)(current.value)) && isPreviousHighlighted === isNextHighlighted) { + return isPreviousHighlighted; + } + return current.isHighlighted; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/getHighlightedParts.js": +/*!***************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/getHighlightedParts.js ***! + \***************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "getHighlightedParts": () => (/* binding */ getHighlightedParts) +/* harmony export */ }); +/* harmony import */ var _escape_highlight_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./escape-highlight.js */ "./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js"); + +function getHighlightedParts(highlightedValue) { + var highlightPostTag = _escape_highlight_js__WEBPACK_IMPORTED_MODULE_0__.TAG_REPLACEMENT.highlightPostTag, + highlightPreTag = _escape_highlight_js__WEBPACK_IMPORTED_MODULE_0__.TAG_REPLACEMENT.highlightPreTag; + var splitByPreTag = highlightedValue.split(highlightPreTag); + var firstValue = splitByPreTag.shift(); + var elements = !firstValue ? [] : [{ + value: firstValue, + isHighlighted: false + }]; + splitByPreTag.forEach(function (split) { + var splitByPostTag = split.split(highlightPostTag); + elements.push({ + value: splitByPostTag[0], + isHighlighted: true + }); + if (splitByPostTag[1] !== '') { + elements.push({ + value: splitByPostTag[1], + isHighlighted: false + }); + } + }); + return elements; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/getObjectType.js": +/*!*********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/getObjectType.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "getObjectType": () => (/* binding */ getObjectType) +/* harmony export */ }); +function getObjectType(object) { + return Object.prototype.toString.call(object).slice(8, -1); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/getPropertyByPath.js": +/*!*************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/getPropertyByPath.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "getPropertyByPath": () => (/* binding */ getPropertyByPath) +/* harmony export */ }); +function getPropertyByPath(object, path) { + var parts = Array.isArray(path) ? path : path.split('.'); + return parts.reduce(function (current, key) { + return current && current[key]; + }, object); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/isEqual.js": +/*!***************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/isEqual.js ***! + \***************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "isEqual": () => (/* binding */ isEqual) +/* harmony export */ }); +function isPrimitive(obj) { + return obj !== Object(obj); +} +function isEqual(first, second) { + if (first === second) { + return true; + } + if (isPrimitive(first) || isPrimitive(second) || typeof first === 'function' || typeof second === 'function') { + return first === second; + } + if (Object.keys(first).length !== Object.keys(second).length) { + return false; + } + + // @TODO avoid for..of because of the large polyfill + // eslint-disable-next-line no-restricted-syntax + for (var _i = 0, _Object$keys = Object.keys(first); _i < _Object$keys.length; _i++) { + var key = _Object$keys[_i]; + if (!(key in second)) { + return false; + } + if (!isEqual(first[key], second[key])) { + return false; + } + } + return true; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/isIndexWidget.js": +/*!*********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/isIndexWidget.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "isIndexWidget": () => (/* binding */ isIndexWidget) +/* harmony export */ }); +function isIndexWidget(widget) { + return widget.$$type === 'ais.index'; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/isPlainObject.js": +/*!*********************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/isPlainObject.js ***! + \*********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "isPlainObject": () => (/* binding */ isPlainObject) +/* harmony export */ }); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +/** + * This implementation is taken from Lodash implementation. + * See: https://github.com/lodash/lodash/blob/master/isPlainObject.js + */ + +function getTag(value) { + if (value === null) { + return value === undefined ? '[object Undefined]' : '[object Null]'; + } + return Object.prototype.toString.call(value); +} +function isObjectLike(value) { + return _typeof(value) === 'object' && value !== null; +} + +/** + * Checks if `value` is a plain object. + * + * A plain object is an object created by the `Object` + * constructor or with a `[[Prototype]]` of `null`. + */ +function isPlainObject(value) { + if (!isObjectLike(value) || getTag(value) !== '[object Object]') { + return false; + } + if (Object.getPrototypeOf(value) === null) { + return true; + } + var proto = value; + while (Object.getPrototypeOf(proto) !== null) { + proto = Object.getPrototypeOf(proto); + } + return Object.getPrototypeOf(value) === proto; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/logger.js": +/*!**************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/logger.js ***! + \**************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "deprecate": () => (/* binding */ deprecate), +/* harmony export */ "warn": () => (/* binding */ warn), +/* harmony export */ "warning": () => (/* binding */ _warning) +/* harmony export */ }); +/* harmony import */ var _noop_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./noop.js */ "./node_modules/instantsearch.js/es/lib/utils/noop.js"); + +/** + * Logs a warning when this function is called, in development environment only. + */ +var deprecate = function deprecate(fn, message) { + return fn; +}; + +/** + * Logs a warning + * This is used to log issues in development environment only. + */ +var warn = _noop_js__WEBPACK_IMPORTED_MODULE_0__.noop; + +/** + * Logs a warning if the condition is not met. + * This is used to log issues in development environment only. + */ +var _warning = _noop_js__WEBPACK_IMPORTED_MODULE_0__.noop; +if (true) { + warn = function warn(message) { + // eslint-disable-next-line no-console + console.warn("[InstantSearch.js]: ".concat(message.trim())); + }; + deprecate = function deprecate(fn, message) { + var hasAlreadyPrinted = false; + return function () { + if (!hasAlreadyPrinted) { + hasAlreadyPrinted = true; + true ? warn(message) : 0; + } + return fn.apply(void 0, arguments); + }; + }; + _warning = function warning(condition, message) { + if (condition) { + return; + } + var hasAlreadyPrinted = _warning.cache[message]; + if (!hasAlreadyPrinted) { + _warning.cache[message] = true; + true ? warn(message) : 0; + } + }; + _warning.cache = {}; +} + + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/mergeSearchParameters.js": +/*!*****************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/mergeSearchParameters.js ***! + \*****************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "mergeSearchParameters": () => (/* binding */ mergeSearchParameters) +/* harmony export */ }); +/* harmony import */ var _findIndex_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./findIndex.js */ "./node_modules/instantsearch.js/es/lib/utils/findIndex.js"); +/* harmony import */ var _uniq_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./uniq.js */ "./node_modules/instantsearch.js/es/lib/utils/uniq.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +var _excluded = ["facets", "disjunctiveFacets", "facetsRefinements", "facetsExcludes", "disjunctiveFacetsRefinements", "numericRefinements", "tagRefinements", "hierarchicalFacets", "hierarchicalFacetsRefinements", "ruleContexts"]; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } + + +var mergeWithRest = function mergeWithRest(left, right) { + var facets = right.facets, + disjunctiveFacets = right.disjunctiveFacets, + facetsRefinements = right.facetsRefinements, + facetsExcludes = right.facetsExcludes, + disjunctiveFacetsRefinements = right.disjunctiveFacetsRefinements, + numericRefinements = right.numericRefinements, + tagRefinements = right.tagRefinements, + hierarchicalFacets = right.hierarchicalFacets, + hierarchicalFacetsRefinements = right.hierarchicalFacetsRefinements, + ruleContexts = right.ruleContexts, + rest = _objectWithoutProperties(right, _excluded); + return left.setQueryParameters(rest); +}; + +// Merge facets +var mergeFacets = function mergeFacets(left, right) { + return right.facets.reduce(function (_, name) { + return _.addFacet(name); + }, left); +}; +var mergeDisjunctiveFacets = function mergeDisjunctiveFacets(left, right) { + return right.disjunctiveFacets.reduce(function (_, name) { + return _.addDisjunctiveFacet(name); + }, left); +}; +var mergeHierarchicalFacets = function mergeHierarchicalFacets(left, right) { + return left.setQueryParameters({ + hierarchicalFacets: right.hierarchicalFacets.reduce(function (facets, facet) { + var index = (0,_findIndex_js__WEBPACK_IMPORTED_MODULE_0__.findIndex)(facets, function (_) { + return _.name === facet.name; + }); + if (index === -1) { + return facets.concat(facet); + } + var nextFacets = facets.slice(); + nextFacets.splice(index, 1, facet); + return nextFacets; + }, left.hierarchicalFacets) + }); +}; + +// Merge facet refinements +var mergeTagRefinements = function mergeTagRefinements(left, right) { + return right.tagRefinements.reduce(function (_, value) { + return _.addTagRefinement(value); + }, left); +}; +var mergeFacetRefinements = function mergeFacetRefinements(left, right) { + return left.setQueryParameters({ + facetsRefinements: _objectSpread(_objectSpread({}, left.facetsRefinements), right.facetsRefinements) + }); +}; +var mergeFacetsExcludes = function mergeFacetsExcludes(left, right) { + return left.setQueryParameters({ + facetsExcludes: _objectSpread(_objectSpread({}, left.facetsExcludes), right.facetsExcludes) + }); +}; +var mergeDisjunctiveFacetsRefinements = function mergeDisjunctiveFacetsRefinements(left, right) { + return left.setQueryParameters({ + disjunctiveFacetsRefinements: _objectSpread(_objectSpread({}, left.disjunctiveFacetsRefinements), right.disjunctiveFacetsRefinements) + }); +}; +var mergeNumericRefinements = function mergeNumericRefinements(left, right) { + return left.setQueryParameters({ + numericRefinements: _objectSpread(_objectSpread({}, left.numericRefinements), right.numericRefinements) + }); +}; +var mergeHierarchicalFacetsRefinements = function mergeHierarchicalFacetsRefinements(left, right) { + return left.setQueryParameters({ + hierarchicalFacetsRefinements: _objectSpread(_objectSpread({}, left.hierarchicalFacetsRefinements), right.hierarchicalFacetsRefinements) + }); +}; +var mergeRuleContexts = function mergeRuleContexts(left, right) { + var ruleContexts = (0,_uniq_js__WEBPACK_IMPORTED_MODULE_1__.uniq)([].concat(left.ruleContexts).concat(right.ruleContexts).filter(Boolean)); + if (ruleContexts.length > 0) { + return left.setQueryParameters({ + ruleContexts: ruleContexts + }); + } + return left; +}; +var mergeSearchParameters = function mergeSearchParameters() { + for (var _len = arguments.length, parameters = new Array(_len), _key = 0; _key < _len; _key++) { + parameters[_key] = arguments[_key]; + } + return parameters.reduce(function (left, right) { + var hierarchicalFacetsRefinementsMerged = mergeHierarchicalFacetsRefinements(left, right); + var hierarchicalFacetsMerged = mergeHierarchicalFacets(hierarchicalFacetsRefinementsMerged, right); + var tagRefinementsMerged = mergeTagRefinements(hierarchicalFacetsMerged, right); + var numericRefinementsMerged = mergeNumericRefinements(tagRefinementsMerged, right); + var disjunctiveFacetsRefinementsMerged = mergeDisjunctiveFacetsRefinements(numericRefinementsMerged, right); + var facetsExcludesMerged = mergeFacetsExcludes(disjunctiveFacetsRefinementsMerged, right); + var facetRefinementsMerged = mergeFacetRefinements(facetsExcludesMerged, right); + var disjunctiveFacetsMerged = mergeDisjunctiveFacets(facetRefinementsMerged, right); + var ruleContextsMerged = mergeRuleContexts(disjunctiveFacetsMerged, right); + var facetsMerged = mergeFacets(ruleContextsMerged, right); + return mergeWithRest(facetsMerged, right); + }); +}; + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/noop.js": +/*!************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/noop.js ***! + \************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "noop": () => (/* binding */ noop) +/* harmony export */ }); +function noop() {} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/render-args.js": +/*!*******************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/render-args.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "createInitArgs": () => (/* binding */ createInitArgs), +/* harmony export */ "createRenderArgs": () => (/* binding */ createRenderArgs) +/* harmony export */ }); +function createInitArgs(instantSearchInstance, parent, uiState) { + var helper = parent.getHelper(); + return { + uiState: uiState, + helper: helper, + parent: parent, + instantSearchInstance: instantSearchInstance, + state: helper.state, + renderState: instantSearchInstance.renderState, + templatesConfig: instantSearchInstance.templatesConfig, + createURL: parent.createURL, + scopedResults: [], + searchMetadata: { + isSearchStalled: instantSearchInstance.status === 'stalled' + }, + status: instantSearchInstance.status, + error: instantSearchInstance.error + }; +} +function createRenderArgs(instantSearchInstance, parent) { + var results = parent.getResults(); + return { + helper: parent.getHelper(), + parent: parent, + instantSearchInstance: instantSearchInstance, + results: results, + scopedResults: parent.getScopedResults(), + state: results._state, + renderState: instantSearchInstance.renderState, + templatesConfig: instantSearchInstance.templatesConfig, + createURL: parent.createURL, + searchMetadata: { + isSearchStalled: instantSearchInstance.status === 'stalled' + }, + status: instantSearchInstance.status, + error: instantSearchInstance.error + }; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/resolveSearchParameters.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/resolveSearchParameters.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "resolveSearchParameters": () => (/* binding */ resolveSearchParameters) +/* harmony export */ }); +function resolveSearchParameters(current) { + var parent = current.getParent(); + var states = [current.getHelper().state]; + while (parent !== null) { + states = [parent.getHelper().state].concat(states); + parent = parent.getParent(); + } + return states; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/reverseHighlightedParts.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/reverseHighlightedParts.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "reverseHighlightedParts": () => (/* binding */ reverseHighlightedParts) +/* harmony export */ }); +/* harmony import */ var _getHighlightFromSiblings_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./getHighlightFromSiblings.js */ "./node_modules/instantsearch.js/es/lib/utils/getHighlightFromSiblings.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + +function reverseHighlightedParts(parts) { + if (!parts.some(function (part) { + return part.isHighlighted; + })) { + return parts.map(function (part) { + return _objectSpread(_objectSpread({}, part), {}, { + isHighlighted: false + }); + }); + } + return parts.map(function (part, i) { + return _objectSpread(_objectSpread({}, part), {}, { + isHighlighted: !(0,_getHighlightFromSiblings_js__WEBPACK_IMPORTED_MODULE_0__.getHighlightFromSiblings)(parts, i) + }); + }); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/safelyRunOnBrowser.js": +/*!**************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/safelyRunOnBrowser.js ***! + \**************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "safelyRunOnBrowser": () => (/* binding */ safelyRunOnBrowser) +/* harmony export */ }); +// eslint-disable-next-line no-restricted-globals + +/** + * Runs code on browser environments safely. + */ +function safelyRunOnBrowser(callback) { + var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : { + fallback: function fallback() { + return undefined; + } + }, + fallback = _ref.fallback; + // eslint-disable-next-line no-restricted-globals + if (typeof window === 'undefined') { + return fallback(); + } + + // eslint-disable-next-line no-restricted-globals + return callback({ + window: window + }); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/serializer.js": +/*!******************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/serializer.js ***! + \******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "deserializePayload": () => (/* binding */ deserializePayload), +/* harmony export */ "serializePayload": () => (/* binding */ serializePayload) +/* harmony export */ }); +function serializePayload(payload) { + return btoa(encodeURIComponent(JSON.stringify(payload))); +} +function deserializePayload(serialized) { + return JSON.parse(decodeURIComponent(atob(serialized))); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/setIndexHelperState.js": +/*!***************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/setIndexHelperState.js ***! + \***************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "setIndexHelperState": () => (/* binding */ setIndexHelperState) +/* harmony export */ }); +/* harmony import */ var _checkIndexUiState_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./checkIndexUiState.js */ "./node_modules/instantsearch.js/es/lib/utils/checkIndexUiState.js"); +/* harmony import */ var _isIndexWidget_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./isIndexWidget.js */ "./node_modules/instantsearch.js/es/lib/utils/isIndexWidget.js"); + + +function setIndexHelperState(finalUiState, indexWidget) { + var nextIndexUiState = finalUiState[indexWidget.getIndexId()] || {}; + if (true) { + (0,_checkIndexUiState_js__WEBPACK_IMPORTED_MODULE_0__.checkIndexUiState)({ + index: indexWidget, + indexUiState: nextIndexUiState + }); + } + indexWidget.getHelper().setState(indexWidget.getWidgetSearchParameters(indexWidget.getHelper().state, { + uiState: nextIndexUiState + })); + indexWidget.getWidgets().filter(_isIndexWidget_js__WEBPACK_IMPORTED_MODULE_1__.isIndexWidget).forEach(function (widget) { + return setIndexHelperState(finalUiState, widget); + }); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/typedObject.js": +/*!*******************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/typedObject.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "keys": () => (/* binding */ keys) +/* harmony export */ }); +/** + * A typed version of Object.keys, to use when looping over a static object + * inspired from https://stackoverflow.com/a/65117465/3185307 + */ +var keys = Object.keys; + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/utils/uniq.js": +/*!************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/utils/uniq.js ***! + \************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "uniq": () => (/* binding */ uniq) +/* harmony export */ }); +function uniq(array) { + return array.filter(function (value, index, self) { + return self.indexOf(value) === index; + }); +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/lib/version.js": +/*!*********************************************************!*\ + !*** ./node_modules/instantsearch.js/es/lib/version.js ***! + \*********************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ('4.55.0'); + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/middlewares/createInsightsMiddleware.js": +/*!**********************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/middlewares/createInsightsMiddleware.js ***! + \**********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "createInsightsMiddleware": () => (/* binding */ createInsightsMiddleware) +/* harmony export */ }); +/* harmony import */ var _helpers_index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../helpers/index.js */ "./node_modules/instantsearch.js/es/helpers/get-insights-anonymous-user-token.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/safelyRunOnBrowser.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/noop.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/getAppIdAndApiKey.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/find.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } +function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } + + +var ALGOLIA_INSIGHTS_VERSION = '2.6.0'; +var ALGOLIA_INSIGHTS_SRC = "https://cdn.jsdelivr.net/npm/search-insights@".concat(ALGOLIA_INSIGHTS_VERSION, "/dist/search-insights.min.js"); +function createInsightsMiddleware() { + var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var _insightsClient = props.insightsClient, + insightsInitParams = props.insightsInitParams, + onEvent = props.onEvent, + _props$$$internal = props.$$internal, + $$internal = _props$$$internal === void 0 ? false : _props$$$internal; + var potentialInsightsClient = _insightsClient; + if (!_insightsClient && _insightsClient !== null) { + (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__.safelyRunOnBrowser)(function (_ref) { + var window = _ref.window; + var pointer = window.AlgoliaAnalyticsObject || 'aa'; + if (typeof pointer === 'string') { + potentialInsightsClient = window[pointer]; + } + if (!potentialInsightsClient) { + window.AlgoliaAnalyticsObject = pointer; + if (!window[pointer]) { + window[pointer] = function () { + if (!window[pointer].queue) { + window[pointer].queue = []; + } + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + window[pointer].queue.push(args); + }; + window[pointer].version = ALGOLIA_INSIGHTS_VERSION; + window[pointer].shouldAddScript = true; + } + potentialInsightsClient = window[pointer]; + } + }); + } + // if still no insightsClient was found, we use a noop + var insightsClient = potentialInsightsClient || _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.noop; + return function (_ref2) { + var instantSearchInstance = _ref2.instantSearchInstance; + // remove existing default insights middleware + // user-provided insights middleware takes precedence + var existingInsightsMiddlewares = instantSearchInstance.middleware.filter(function (m) { + return m.instance.$$type === 'ais.insights' && m.instance.$$internal; + }).map(function (m) { + return m.creator; + }); + instantSearchInstance.unuse.apply(instantSearchInstance, _toConsumableArray(existingInsightsMiddlewares)); + var _getAppIdAndApiKey = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.getAppIdAndApiKey)(instantSearchInstance.client), + _getAppIdAndApiKey2 = _slicedToArray(_getAppIdAndApiKey, 2), + appId = _getAppIdAndApiKey2[0], + apiKey = _getAppIdAndApiKey2[1]; + + // search-insights.js also throws an error so dev-only clarification is sufficient + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.warning)(Boolean(appId && apiKey), 'could not extract Algolia credentials from searchClient in insights middleware.') : 0; + var queuedUserToken = undefined; + var userTokenBeforeInit = undefined; + if (Array.isArray(insightsClient.queue)) { + // Context: The umd build of search-insights is asynchronously loaded by the snippet. + // + // When user calls `aa('setUserToken', 'my-user-token')` before `search-insights` is loaded, + // ['setUserToken', 'my-user-token'] gets stored in `aa.queue`. + // Whenever `search-insights` is finally loaded, it will process the queue. + // + // But here's the reason why we handle it here: + // At this point, even though `search-insights` is not loaded yet, + // we still want to read the token from the queue. + // Otherwise, the first search call will be fired without the token. + var _ref3 = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__.find)(insightsClient.queue.slice().reverse(), function (_ref5) { + var _ref6 = _slicedToArray(_ref5, 1), + method = _ref6[0]; + return method === 'setUserToken'; + }) || []; + var _ref4 = _slicedToArray(_ref3, 2); + queuedUserToken = _ref4[1]; + } + insightsClient('getUserToken', null, function (_error, userToken) { + // If user has called `aa('setUserToken', 'my-user-token')` before creating + // the `insights` middleware, we store them temporarily and + // set it later on. + // + // Otherwise, the `init` call might override it with anonymous user token. + userTokenBeforeInit = userToken; + }); + + // Only `init` if the `insightsInitParams` option is passed or + // if the `insightsClient` version doesn't supports optional `init` calling. + if (insightsInitParams || !isModernInsightsClient(insightsClient)) { + insightsClient('init', _objectSpread({ + appId: appId, + apiKey: apiKey, + partial: true + }, insightsInitParams)); + } + var initialParameters; + var helper; + return { + $$type: 'ais.insights', + $$internal: $$internal, + onStateChange: function onStateChange() {}, + subscribe: function subscribe() { + if (!insightsClient.shouldAddScript) return; + var errorMessage = '[insights middleware]: could not load search-insights.js. Please load it manually following https://alg.li/insights-init'; + try { + var script = document.createElement('script'); + script.async = true; + script.src = ALGOLIA_INSIGHTS_SRC; + script.onerror = function () { + instantSearchInstance.emit('error', new Error(errorMessage)); + }; + document.body.appendChild(script); + insightsClient.shouldAddScript = false; + } catch (cause) { + insightsClient.shouldAddScript = false; + instantSearchInstance.emit('error', new Error(errorMessage)); + } + }, + started: function started() { + insightsClient('addAlgoliaAgent', 'insights-middleware'); + helper = instantSearchInstance.helper; + initialParameters = { + userToken: helper.state.userToken, + clickAnalytics: helper.state.clickAnalytics + }; + helper.overrideStateWithoutTriggeringChangeEvent(_objectSpread(_objectSpread({}, helper.state), {}, { + clickAnalytics: true + })); + if (!$$internal) { + instantSearchInstance.scheduleSearch(); + } + var setUserTokenToSearch = function setUserTokenToSearch(userToken) { + if (!userToken) { + return; + } + var existingToken = helper.state.userToken; + helper.overrideStateWithoutTriggeringChangeEvent(_objectSpread(_objectSpread({}, helper.state), {}, { + userToken: userToken + })); + if (existingToken && existingToken !== userToken) { + instantSearchInstance.scheduleSearch(); + } + }; + var anonymousUserToken = (0,_helpers_index_js__WEBPACK_IMPORTED_MODULE_5__.getInsightsAnonymousUserTokenInternal)(); + if (anonymousUserToken) { + // When `aa('init', { ... })` is called, it creates an anonymous user token in cookie. + // We can set it as userToken. + setUserTokenToSearch(anonymousUserToken); + } + + // We consider the `userToken` coming from a `init` call to have a higher + // importance than the one coming from the queue. + if (userTokenBeforeInit) { + setUserTokenToSearch(userTokenBeforeInit); + insightsClient('setUserToken', userTokenBeforeInit); + } else if (queuedUserToken) { + setUserTokenToSearch(queuedUserToken); + insightsClient('setUserToken', queuedUserToken); + } + + // This updates userToken which is set explicitly by `aa('setUserToken', userToken)` + insightsClient('onUserTokenChange', setUserTokenToSearch, { + immediate: true + }); + var insightsClientWithLocalCredentials = insightsClient; + if (isModernInsightsClient(insightsClient)) { + insightsClientWithLocalCredentials = function insightsClientWithLocalCredentials(method, payload) { + var extraParams = { + headers: { + 'X-Algolia-Application-Id': appId, + 'X-Algolia-API-Key': apiKey + } + }; + + // @ts-ignore we are calling this only when we know that the client actually is correct + return insightsClient(method, payload, extraParams); + }; + } + instantSearchInstance.sendEventToInsights = function (event) { + if (onEvent) { + onEvent(event, insightsClientWithLocalCredentials); + } else if (event.insightsMethod) { + // Source is used to differentiate events sent by instantsearch from those sent manually. + event.payload.algoliaSource = ['instantsearch']; + if (event.eventModifier === 'internal') { + event.payload.algoliaSource.push('instantsearch-internal'); + } + insightsClientWithLocalCredentials(event.insightsMethod, event.payload); + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.warning)(Boolean(helper.state.userToken), "\nCannot send event to Algolia Insights because `userToken` is not set.\n\nSee documentation: https://www.algolia.com/doc/guides/building-search-ui/going-further/send-insights-events/js/#setting-the-usertoken\n") : 0; + } else { + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.warning)(false, 'Cannot send event to Algolia Insights because `insightsMethod` option is missing.') : 0; + } + }; + }, + unsubscribe: function unsubscribe() { + insightsClient('onUserTokenChange', undefined); + instantSearchInstance.sendEventToInsights = _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.noop; + if (helper && initialParameters) { + helper.overrideStateWithoutTriggeringChangeEvent(_objectSpread(_objectSpread({}, helper.state), initialParameters)); + instantSearchInstance.scheduleSearch(); + } + } + }; + }; +} + +/** + * Determines if a given insights `client` supports the optional call to `init` + * and the ability to set credentials via extra parameters when sending events. + */ +function isModernInsightsClient(client) { + var _split$map = (client.version || '').split('.').map(Number), + _split$map2 = _slicedToArray(_split$map, 2), + major = _split$map2[0], + minor = _split$map2[1]; + + /* eslint-disable @typescript-eslint/naming-convention */ + var v3 = major >= 3; + var v2_6 = major === 2 && minor >= 6; + var v1_10 = major === 1 && minor >= 10; + /* eslint-enable @typescript-eslint/naming-convention */ + + return v3 || v2_6 || v1_10; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/middlewares/createMetadataMiddleware.js": +/*!**********************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/middlewares/createMetadataMiddleware.js ***! + \**********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "createMetadataMiddleware": () => (/* binding */ createMetadataMiddleware), +/* harmony export */ "isMetadataEnabled": () => (/* binding */ isMetadataEnabled) +/* harmony export */ }); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/render-args.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/safelyRunOnBrowser.js"); + +function extractWidgetPayload(widgets, instantSearchInstance, payload) { + var initOptions = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_0__.createInitArgs)(instantSearchInstance, instantSearchInstance.mainIndex, instantSearchInstance._initialUiState); + widgets.forEach(function (widget) { + var widgetParams = {}; + if (widget.getWidgetRenderState) { + var renderState = widget.getWidgetRenderState(initOptions); + if (renderState && renderState.widgetParams) { + // casting, as we just earlier checked widgetParams exists, and thus an object + widgetParams = renderState.widgetParams; + } + } + + // since we destructure in all widgets, the parameters with defaults are set to "undefined" + var params = Object.keys(widgetParams).filter(function (key) { + return widgetParams[key] !== undefined; + }); + payload.widgets.push({ + type: widget.$$type, + widgetType: widget.$$widgetType, + params: params + }); + if (widget.$$type === 'ais.index') { + extractWidgetPayload(widget.getWidgets(), instantSearchInstance, payload); + } + }); +} +function isMetadataEnabled() { + return (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.safelyRunOnBrowser)(function (_ref) { + var _window$navigator, _window$navigator$use; + var window = _ref.window; + return ((_window$navigator = window.navigator) === null || _window$navigator === void 0 ? void 0 : (_window$navigator$use = _window$navigator.userAgent) === null || _window$navigator$use === void 0 ? void 0 : _window$navigator$use.indexOf('Algolia Crawler')) > -1; + }, { + fallback: function fallback() { + return false; + } + }); +} + +/** + * Exposes the metadata of mounted widgets in a custom + * `` tag. The metadata per widget is: + * - applied parameters + * - widget name + * - connector name + */ +function createMetadataMiddleware() { + var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, + _ref2$$$internal = _ref2.$$internal, + $$internal = _ref2$$$internal === void 0 ? false : _ref2$$$internal; + return function (_ref3) { + var instantSearchInstance = _ref3.instantSearchInstance; + var payload = { + widgets: [] + }; + var payloadContainer = document.createElement('meta'); + var refNode = document.querySelector('head'); + payloadContainer.name = 'instantsearch:widgets'; + return { + $$type: 'ais.metadata', + $$internal: $$internal, + onStateChange: function onStateChange() {}, + subscribe: function subscribe() { + // using setTimeout here to delay extraction until widgets have been added in a tick (e.g. Vue) + setTimeout(function () { + var client = instantSearchInstance.client; + payload.ua = client.transporter && client.transporter.userAgent ? client.transporter.userAgent.value : client._ua; + extractWidgetPayload(instantSearchInstance.mainIndex.getWidgets(), instantSearchInstance, payload); + instantSearchInstance.middleware.forEach(function (middleware) { + return payload.widgets.push({ + middleware: true, + type: middleware.instance.$$type, + internal: middleware.instance.$$internal + }); + }); + payloadContainer.content = JSON.stringify(payload); + refNode.appendChild(payloadContainer); + }, 0); + }, + started: function started() {}, + unsubscribe: function unsubscribe() { + payloadContainer.remove(); + } + }; + }; +} + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/middlewares/createRouterMiddleware.js": +/*!********************************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/middlewares/createRouterMiddleware.js ***! + \********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "createRouterMiddleware": () => (/* binding */ createRouterMiddleware) +/* harmony export */ }); +/* harmony import */ var _lib_routers_history_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../lib/routers/history.js */ "./node_modules/instantsearch.js/es/lib/routers/history.js"); +/* harmony import */ var _lib_stateMappings_simple_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/stateMappings/simple.js */ "./node_modules/instantsearch.js/es/lib/stateMappings/simple.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/isEqual.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + + + +var createRouterMiddleware = function createRouterMiddleware() { + var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var _props$router = props.router, + router = _props$router === void 0 ? (0,_lib_routers_history_js__WEBPACK_IMPORTED_MODULE_0__["default"])() : _props$router, + _props$stateMapping = props.stateMapping, + stateMapping = _props$stateMapping === void 0 ? (0,_lib_stateMappings_simple_js__WEBPACK_IMPORTED_MODULE_1__["default"])() : _props$stateMapping, + _props$$$internal = props.$$internal, + $$internal = _props$$$internal === void 0 ? false : _props$$$internal; + return function (_ref) { + var instantSearchInstance = _ref.instantSearchInstance; + function topLevelCreateURL(nextState) { + var uiState = Object.keys(nextState).reduce(function (acc, indexId) { + return _objectSpread(_objectSpread({}, acc), {}, _defineProperty({}, indexId, nextState[indexId])); + }, instantSearchInstance.mainIndex.getWidgetUiState({})); + var route = stateMapping.stateToRoute(uiState); + return router.createURL(route); + } + + // casting to UiState here to keep createURL unaware of custom UiState + // (as long as it's an object, it's ok) + instantSearchInstance._createURL = topLevelCreateURL; + var lastRouteState = undefined; + var initialUiState = instantSearchInstance._initialUiState; + return { + $$type: "ais.router({router:".concat(router.$$type || '__unknown__', ", stateMapping:").concat(stateMapping.$$type || '__unknown__', "})"), + $$internal: $$internal, + onStateChange: function onStateChange(_ref2) { + var uiState = _ref2.uiState; + var routeState = stateMapping.stateToRoute(uiState); + if (lastRouteState === undefined || !(0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.isEqual)(lastRouteState, routeState)) { + router.write(routeState); + lastRouteState = routeState; + } + }, + subscribe: function subscribe() { + instantSearchInstance._initialUiState = _objectSpread(_objectSpread({}, initialUiState), stateMapping.routeToState(router.read())); + router.onUpdate(function (route) { + instantSearchInstance.setUiState(stateMapping.routeToState(route)); + }); + }, + started: function started() { + var _router$start; + (_router$start = router.start) === null || _router$start === void 0 ? void 0 : _router$start.call(router); + }, + unsubscribe: function unsubscribe() { + router.dispose(); + } + }; + }; +}; + +/***/ }), + +/***/ "./node_modules/instantsearch.js/es/widgets/index/index.js": +/*!*****************************************************************!*\ + !*** ./node_modules/instantsearch.js/es/widgets/index/index.js ***! + \*****************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony import */ var algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! algoliasearch-helper */ "./node_modules/algoliasearch-helper/index.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/documentation.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/isIndexWidget.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/render-args.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/mergeSearchParameters.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/resolveSearchParameters.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/checkIndexUiState.js"); +/* harmony import */ var _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../../lib/utils/index.js */ "./node_modules/instantsearch.js/es/lib/utils/logger.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +var _excluded = ["initialSearchParameters"]; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } +function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); } +function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } + + +var withUsage = (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_1__.createDocumentationMessageGenerator)({ + name: 'index-widget' +}); +/** + * This is the same content as helper._change / setState, but allowing for extra + * UiState to be synchronized. + * see: https://github.com/algolia/algoliasearch-helper-js/blob/6b835ffd07742f2d6b314022cce6848f5cfecd4a/src/algoliasearch.helper.js#L1311-L1324 + */ +function privateHelperSetState(helper, _ref) { + var state = _ref.state, + isPageReset = _ref.isPageReset, + _uiState = _ref._uiState; + if (state !== helper.state) { + helper.state = state; + helper.emit('change', { + state: helper.state, + results: helper.lastResults, + isPageReset: isPageReset, + _uiState: _uiState + }); + } +} +function getLocalWidgetsUiState(widgets, widgetStateOptions) { + var initialUiState = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + return widgets.reduce(function (uiState, widget) { + if ((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.isIndexWidget)(widget)) { + return uiState; + } + if (!widget.getWidgetUiState && !widget.getWidgetState) { + return uiState; + } + if (widget.getWidgetUiState) { + return widget.getWidgetUiState(uiState, widgetStateOptions); + } + return widget.getWidgetState(uiState, widgetStateOptions); + }, initialUiState); +} +function getLocalWidgetsSearchParameters(widgets, widgetSearchParametersOptions) { + var initialSearchParameters = widgetSearchParametersOptions.initialSearchParameters, + rest = _objectWithoutProperties(widgetSearchParametersOptions, _excluded); + return widgets.filter(function (widget) { + return !(0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.isIndexWidget)(widget); + }).reduce(function (state, widget) { + if (!widget.getWidgetSearchParameters) { + return state; + } + return widget.getWidgetSearchParameters(state, rest); + }, initialSearchParameters); +} +function resetPageFromWidgets(widgets) { + var indexWidgets = widgets.filter(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.isIndexWidget); + if (indexWidgets.length === 0) { + return; + } + indexWidgets.forEach(function (widget) { + var widgetHelper = widget.getHelper(); + privateHelperSetState(widgetHelper, { + state: widgetHelper.state.resetPage(), + isPageReset: true + }); + resetPageFromWidgets(widget.getWidgets()); + }); +} +function resolveScopedResultsFromWidgets(widgets) { + var indexWidgets = widgets.filter(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.isIndexWidget); + return indexWidgets.reduce(function (scopedResults, current) { + return scopedResults.concat.apply(scopedResults, [{ + indexId: current.getIndexId(), + results: current.getResults(), + helper: current.getHelper() + }].concat(_toConsumableArray(resolveScopedResultsFromWidgets(current.getWidgets())))); + }, []); +} +var index = function index(widgetParams) { + if (widgetParams === undefined || widgetParams.indexName === undefined) { + throw new Error(withUsage('The `indexName` option is required.')); + } + var indexName = widgetParams.indexName, + _widgetParams$indexId = widgetParams.indexId, + indexId = _widgetParams$indexId === void 0 ? indexName : _widgetParams$indexId; + var localWidgets = []; + var localUiState = {}; + var localInstantSearchInstance = null; + var localParent = null; + var helper = null; + var derivedHelper = null; + var lastValidSearchParameters = null; + return { + $$type: 'ais.index', + $$widgetType: 'ais.index', + getIndexName: function getIndexName() { + return indexName; + }, + getIndexId: function getIndexId() { + return indexId; + }, + getHelper: function getHelper() { + return helper; + }, + getResults: function getResults() { + var _derivedHelper; + if (!((_derivedHelper = derivedHelper) !== null && _derivedHelper !== void 0 && _derivedHelper.lastResults)) return null; + + // To make the UI optimistic, we patch the state to display to the current + // one instead of the one associated with the latest results. + // This means user-driven UI changes (e.g., checked checkbox) are reflected + // immediately instead of waiting for Algolia to respond, regardless of + // the status of the network request. + derivedHelper.lastResults._state = helper.state; + return derivedHelper.lastResults; + }, + getPreviousState: function getPreviousState() { + return lastValidSearchParameters; + }, + getScopedResults: function getScopedResults() { + var widgetParent = this.getParent(); + + // If the widget is the root, we consider itself as the only sibling. + var widgetSiblings = widgetParent ? widgetParent.getWidgets() : [this]; + return resolveScopedResultsFromWidgets(widgetSiblings); + }, + getParent: function getParent() { + return localParent; + }, + createURL: function createURL(nextState) { + return localInstantSearchInstance._createURL(_defineProperty({}, indexId, getLocalWidgetsUiState(localWidgets, { + searchParameters: nextState, + helper: helper + }))); + }, + getWidgets: function getWidgets() { + return localWidgets; + }, + addWidgets: function addWidgets(widgets) { + var _this = this; + if (!Array.isArray(widgets)) { + throw new Error(withUsage('The `addWidgets` method expects an array of widgets.')); + } + if (widgets.some(function (widget) { + return typeof widget.init !== 'function' && typeof widget.render !== 'function'; + })) { + throw new Error(withUsage('The widget definition expects a `render` and/or an `init` method.')); + } + localWidgets = localWidgets.concat(widgets); + if (localInstantSearchInstance && Boolean(widgets.length)) { + privateHelperSetState(helper, { + state: getLocalWidgetsSearchParameters(localWidgets, { + uiState: localUiState, + initialSearchParameters: helper.state + }), + _uiState: localUiState + }); + + // We compute the render state before calling `init` in a separate loop + // to construct the whole render state object that is then passed to + // `init`. + widgets.forEach(function (widget) { + if (widget.getRenderState) { + var renderState = widget.getRenderState(localInstantSearchInstance.renderState[_this.getIndexId()] || {}, (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.createInitArgs)(localInstantSearchInstance, _this, localInstantSearchInstance._initialUiState)); + storeRenderState({ + renderState: renderState, + instantSearchInstance: localInstantSearchInstance, + parent: _this + }); + } + }); + widgets.forEach(function (widget) { + if (widget.init) { + widget.init((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.createInitArgs)(localInstantSearchInstance, _this, localInstantSearchInstance._initialUiState)); + } + }); + localInstantSearchInstance.scheduleSearch(); + } + return this; + }, + removeWidgets: function removeWidgets(widgets) { + var _this2 = this; + if (!Array.isArray(widgets)) { + throw new Error(withUsage('The `removeWidgets` method expects an array of widgets.')); + } + if (widgets.some(function (widget) { + return typeof widget.dispose !== 'function'; + })) { + throw new Error(withUsage('The widget definition expects a `dispose` method.')); + } + localWidgets = localWidgets.filter(function (widget) { + return widgets.indexOf(widget) === -1; + }); + if (localInstantSearchInstance && Boolean(widgets.length)) { + var nextState = widgets.reduce(function (state, widget) { + // the `dispose` method exists at this point we already assert it + var next = widget.dispose({ + helper: helper, + state: state, + parent: _this2 + }); + return next || state; + }, helper.state); + localUiState = getLocalWidgetsUiState(localWidgets, { + searchParameters: nextState, + helper: helper + }); + helper.setState(getLocalWidgetsSearchParameters(localWidgets, { + uiState: localUiState, + initialSearchParameters: nextState + })); + if (localWidgets.length) { + localInstantSearchInstance.scheduleSearch(); + } + } + return this; + }, + init: function init(_ref2) { + var _this3 = this, + _instantSearchInstanc; + var instantSearchInstance = _ref2.instantSearchInstance, + parent = _ref2.parent, + uiState = _ref2.uiState; + if (helper !== null) { + // helper is already initialized, therefore we do not need to set up + // any listeners + return; + } + localInstantSearchInstance = instantSearchInstance; + localParent = parent; + localUiState = uiState[indexId] || {}; + + // The `mainHelper` is already defined at this point. The instance is created + // inside InstantSearch at the `start` method, which occurs before the `init` + // step. + var mainHelper = instantSearchInstance.mainHelper; + var parameters = getLocalWidgetsSearchParameters(localWidgets, { + uiState: localUiState, + initialSearchParameters: new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchParameters({ + index: indexName + }) + }); + + // This Helper is only used for state management we do not care about the + // `searchClient`. Only the "main" Helper created at the `InstantSearch` + // level is aware of the client. + helper = algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__({}, parameters.index, parameters); + + // We forward the call to `search` to the "main" instance of the Helper + // which is responsible for managing the queries (it's the only one that is + // aware of the `searchClient`). + helper.search = function () { + if (instantSearchInstance.onStateChange) { + instantSearchInstance.onStateChange({ + uiState: instantSearchInstance.mainIndex.getWidgetUiState({}), + setUiState: function setUiState(nextState) { + return instantSearchInstance.setUiState(nextState, false); + } + }); + + // We don't trigger a search when controlled because it becomes the + // responsibility of `setUiState`. + return mainHelper; + } + return mainHelper.search(); + }; + helper.searchWithoutTriggeringOnStateChange = function () { + return mainHelper.search(); + }; + + // We use the same pattern for the `searchForFacetValues`. + helper.searchForFacetValues = function (facetName, facetValue, maxFacetHits, userState) { + var state = helper.state.setQueryParameters(userState); + return mainHelper.searchForFacetValues(facetName, facetValue, maxFacetHits, state); + }; + derivedHelper = mainHelper.derive(function () { + return _lib_utils_index_js__WEBPACK_IMPORTED_MODULE_4__.mergeSearchParameters.apply(void 0, _toConsumableArray((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_5__.resolveSearchParameters)(_this3))); + }); + var indexInitialResults = (_instantSearchInstanc = instantSearchInstance._initialResults) === null || _instantSearchInstanc === void 0 ? void 0 : _instantSearchInstanc[this.getIndexId()]; + if (indexInitialResults) { + // We restore the shape of the results provided to the instance to respect + // the helper's structure. + var results = new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchResults(new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchParameters(indexInitialResults.state), indexInitialResults.results); + derivedHelper.lastResults = results; + helper.lastResults = results; + } + + // Subscribe to the Helper state changes for the page before widgets + // are initialized. This behavior mimics the original one of the Helper. + // It makes sense to replicate it at the `init` step. We have another + // listener on `change` below, once `init` is done. + helper.on('change', function (_ref3) { + var isPageReset = _ref3.isPageReset; + if (isPageReset) { + resetPageFromWidgets(localWidgets); + } + }); + derivedHelper.on('search', function () { + // The index does not manage the "staleness" of the search. This is the + // responsibility of the main instance. It does not make sense to manage + // it at the index level because it's either: all of them or none of them + // that are stalled. The queries are performed into a single network request. + instantSearchInstance.scheduleStalledRender(); + if (true) { + (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_6__.checkIndexUiState)({ + index: _this3, + indexUiState: localUiState + }); + } + }); + derivedHelper.on('result', function (_ref4) { + var results = _ref4.results; + // The index does not render the results it schedules a new render + // to let all the other indices emit their own results. It allows us to + // run the render process in one pass. + instantSearchInstance.scheduleRender(); + + // the derived helper is the one which actually searches, but the helper + // which is exposed e.g. via instance.helper, doesn't search, and thus + // does not have access to lastResults, which it used to in pre-federated + // search behavior. + helper.lastResults = results; + lastValidSearchParameters = results._state; + }); + + // We compute the render state before calling `init` in a separate loop + // to construct the whole render state object that is then passed to + // `init`. + localWidgets.forEach(function (widget) { + if (widget.getRenderState) { + var renderState = widget.getRenderState(instantSearchInstance.renderState[_this3.getIndexId()] || {}, (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.createInitArgs)(instantSearchInstance, _this3, uiState)); + storeRenderState({ + renderState: renderState, + instantSearchInstance: instantSearchInstance, + parent: _this3 + }); + } + }); + localWidgets.forEach(function (widget) { + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_7__.warning)( + // if it has NO getWidgetState or if it has getWidgetUiState, we don't warn + // aka we warn if there's _only_ getWidgetState + !widget.getWidgetState || Boolean(widget.getWidgetUiState), 'The `getWidgetState` method is renamed `getWidgetUiState` and will no longer exist under that name in InstantSearch.js 5.x. Please use `getWidgetUiState` instead.') : 0; + if (widget.init) { + widget.init((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.createInitArgs)(instantSearchInstance, _this3, uiState)); + } + }); + + // Subscribe to the Helper state changes for the `uiState` once widgets + // are initialized. Until the first render, state changes are part of the + // configuration step. This is mainly for backward compatibility with custom + // widgets. When the subscription happens before the `init` step, the (static) + // configuration of the widget is pushed in the URL. That's what we want to avoid. + // https://github.com/algolia/instantsearch.js/pull/994/commits/4a672ae3fd78809e213de0368549ef12e9dc9454 + helper.on('change', function (event) { + var state = event.state; + var _uiState = event._uiState; + localUiState = getLocalWidgetsUiState(localWidgets, { + searchParameters: state, + helper: helper + }, _uiState || {}); + + // We don't trigger an internal change when controlled because it + // becomes the responsibility of `setUiState`. + if (!instantSearchInstance.onStateChange) { + instantSearchInstance.onInternalStateChange(); + } + }); + if (indexInitialResults) { + // If there are initial results, we're not notified of the next results + // because we don't trigger an initial search. We therefore need to directly + // schedule a render that will render the results injected on the helper. + instantSearchInstance.scheduleRender(); + } + }, + render: function render(_ref5) { + var _this4 = this; + var instantSearchInstance = _ref5.instantSearchInstance; + if (!this.getResults()) { + return; + } + + // we can't attach a listener to the error event of search, as the error + // then would no longer be thrown for global handlers. + if (instantSearchInstance.status === 'error' && !instantSearchInstance.mainHelper.hasPendingRequests()) { + helper.setState(lastValidSearchParameters); + } + localWidgets.forEach(function (widget) { + if (widget.getRenderState) { + var renderState = widget.getRenderState(instantSearchInstance.renderState[_this4.getIndexId()] || {}, (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.createRenderArgs)(instantSearchInstance, _this4)); + storeRenderState({ + renderState: renderState, + instantSearchInstance: instantSearchInstance, + parent: _this4 + }); + } + }); + localWidgets.forEach(function (widget) { + // At this point, all the variables used below are set. Both `helper` + // and `derivedHelper` have been created at the `init` step. The attribute + // `lastResults` might be `null` though. It's possible that a stalled render + // happens before the result e.g with a dynamically added index the request might + // be delayed. The render is triggered for the complete tree but some parts do + // not have results yet. + + if (widget.render) { + widget.render((0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_3__.createRenderArgs)(instantSearchInstance, _this4)); + } + }); + }, + dispose: function dispose() { + var _this5 = this, + _helper, + _derivedHelper2; + localWidgets.forEach(function (widget) { + if (widget.dispose) { + // The dispose function is always called once the instance is started + // (it's an effect of `removeWidgets`). The index is initialized and + // the Helper is available. We don't care about the return value of + // `dispose` because the index is removed. We can't call `removeWidgets` + // because we want to keep the widgets on the instance, to allow idempotent + // operations on `add` & `remove`. + widget.dispose({ + helper: helper, + state: helper.state, + parent: _this5 + }); + } + }); + localInstantSearchInstance = null; + localParent = null; + (_helper = helper) === null || _helper === void 0 ? void 0 : _helper.removeAllListeners(); + helper = null; + (_derivedHelper2 = derivedHelper) === null || _derivedHelper2 === void 0 ? void 0 : _derivedHelper2.detach(); + derivedHelper = null; + }, + getWidgetUiState: function getWidgetUiState(uiState) { + return localWidgets.filter(_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_2__.isIndexWidget).reduce(function (previousUiState, innerIndex) { + return innerIndex.getWidgetUiState(previousUiState); + }, _objectSpread(_objectSpread({}, uiState), {}, _defineProperty({}, indexId, _objectSpread(_objectSpread({}, uiState[indexId]), localUiState)))); + }, + getWidgetState: function getWidgetState(uiState) { + true ? (0,_lib_utils_index_js__WEBPACK_IMPORTED_MODULE_7__.warning)(false, 'The `getWidgetState` method is renamed `getWidgetUiState` and will no longer exist under that name in InstantSearch.js 5.x. Please use `getWidgetUiState` instead.') : 0; + return this.getWidgetUiState(uiState); + }, + getWidgetSearchParameters: function getWidgetSearchParameters(searchParameters, _ref6) { + var uiState = _ref6.uiState; + return getLocalWidgetsSearchParameters(localWidgets, { + uiState: uiState, + initialSearchParameters: searchParameters + }); + }, + refreshUiState: function refreshUiState() { + localUiState = getLocalWidgetsUiState(localWidgets, { + searchParameters: this.getHelper().state, + helper: this.getHelper() + }, localUiState); + }, + setIndexUiState: function setIndexUiState(indexUiState) { + var nextIndexUiState = typeof indexUiState === 'function' ? indexUiState(localUiState) : indexUiState; + localInstantSearchInstance.setUiState(function (state) { + return _objectSpread(_objectSpread({}, state), {}, _defineProperty({}, indexId, nextIndexUiState)); + }); + } + }; +}; +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (index); +function storeRenderState(_ref7) { + var renderState = _ref7.renderState, + instantSearchInstance = _ref7.instantSearchInstance, + parent = _ref7.parent; + var parentIndexName = parent ? parent.getIndexId() : instantSearchInstance.mainIndex.getIndexId(); + instantSearchInstance.renderState = _objectSpread(_objectSpread({}, instantSearchInstance.renderState), {}, _defineProperty({}, parentIndexName, _objectSpread(_objectSpread({}, instantSearchInstance.renderState[parentIndexName]), renderState))); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/components/Configure.js": +/*!********************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/components/Configure.js ***! + \********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "Configure": () => (/* binding */ Configure) +/* harmony export */ }); +/* harmony import */ var _connectors_useConfigure_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../connectors/useConfigure.js */ "./node_modules/react-instantsearch-hooks/dist/es/connectors/useConfigure.js"); + +function Configure(props) { + (0,_connectors_useConfigure_js__WEBPACK_IMPORTED_MODULE_0__.useConfigure)(props, { + $$widgetType: 'ais.configure' + }); + return null; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/components/Index.js": +/*!****************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/components/Index.js ***! + \****************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "Index": () => (/* binding */ Index) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _lib_IndexContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/IndexContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/IndexContext.js"); +/* harmony import */ var _lib_useIndex_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/useIndex.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIndex.js"); +var _excluded = ["children"]; +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } + + + +function Index(_ref) { + var children = _ref.children, + props = _objectWithoutProperties(_ref, _excluded); + var index = (0,_lib_useIndex_js__WEBPACK_IMPORTED_MODULE_1__.useIndex)(props); + if (index.getHelper() === null) { + return null; + } + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(_lib_IndexContext_js__WEBPACK_IMPORTED_MODULE_2__.IndexContext.Provider, { + value: index + }, children); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearch.js": +/*!************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearch.js ***! + \************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "InstantSearch": () => (/* binding */ InstantSearch) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _lib_IndexContext_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/IndexContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/IndexContext.js"); +/* harmony import */ var _lib_InstantSearchContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/InstantSearchContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchContext.js"); +/* harmony import */ var _lib_useInstantSearchApi_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/useInstantSearchApi.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchApi.js"); +var _excluded = ["children"]; +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } + + + + +function InstantSearch(_ref) { + var children = _ref.children, + props = _objectWithoutProperties(_ref, _excluded); + var search = (0,_lib_useInstantSearchApi_js__WEBPACK_IMPORTED_MODULE_1__.useInstantSearchApi)(props); + if (!search.started) { + return null; + } + return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(_lib_InstantSearchContext_js__WEBPACK_IMPORTED_MODULE_2__.InstantSearchContext.Provider, { + value: search + }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0__.createElement(_lib_IndexContext_js__WEBPACK_IMPORTED_MODULE_3__.IndexContext.Provider, { + value: search.mainIndex + }, children)); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearchServerContext.js": +/*!*************************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearchServerContext.js ***! + \*************************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "InstantSearchServerContext": () => (/* binding */ InstantSearchServerContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); + +var InstantSearchServerContext = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(null); +if (true) { + InstantSearchServerContext.displayName = 'InstantSearchServer'; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/connectors/useConfigure.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/connectors/useConfigure.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useConfigure": () => (/* binding */ useConfigure) +/* harmony export */ }); +/* harmony import */ var instantsearch_js_es_connectors_configure_connectConfigure_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! instantsearch.js/es/connectors/configure/connectConfigure.js */ "./node_modules/instantsearch.js/es/connectors/configure/connectConfigure.js"); +/* harmony import */ var _hooks_useConnector_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../hooks/useConnector.js */ "./node_modules/react-instantsearch-hooks/dist/es/hooks/useConnector.js"); + + +function useConfigure(props, additionalWidgetProperties) { + return (0,_hooks_useConnector_js__WEBPACK_IMPORTED_MODULE_0__.useConnector)(instantsearch_js_es_connectors_configure_connectConfigure_js__WEBPACK_IMPORTED_MODULE_1__["default"], { + searchParameters: props + }, additionalWidgetProperties); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/connectors/useSearchBox.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/connectors/useSearchBox.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useSearchBox": () => (/* binding */ useSearchBox) +/* harmony export */ }); +/* harmony import */ var instantsearch_js_es_connectors_search_box_connectSearchBox_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! instantsearch.js/es/connectors/search-box/connectSearchBox.js */ "./node_modules/instantsearch.js/es/connectors/search-box/connectSearchBox.js"); +/* harmony import */ var _hooks_useConnector_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../hooks/useConnector.js */ "./node_modules/react-instantsearch-hooks/dist/es/hooks/useConnector.js"); + + +function useSearchBox(props, additionalWidgetProperties) { + return (0,_hooks_useConnector_js__WEBPACK_IMPORTED_MODULE_0__.useConnector)(instantsearch_js_es_connectors_search_box_connectSearchBox_js__WEBPACK_IMPORTED_MODULE_1__["default"], props, additionalWidgetProperties); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/hooks/useConnector.js": +/*!******************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/hooks/useConnector.js ***! + \******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useConnector": () => (/* binding */ useConnector) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _lib_dequal_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../lib/dequal.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/dequal.js"); +/* harmony import */ var _lib_getIndexSearchResults_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../lib/getIndexSearchResults.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/getIndexSearchResults.js"); +/* harmony import */ var _lib_useIndexContext_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/useIndexContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIndexContext.js"); +/* harmony import */ var _lib_useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/useInstantSearchContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js"); +/* harmony import */ var _lib_useInstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/useInstantSearchServerContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchServerContext.js"); +/* harmony import */ var _lib_useStableValue_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../lib/useStableValue.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useStableValue.js"); +/* harmony import */ var _lib_useWidget_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../lib/useWidget.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useWidget.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +var _excluded = ["instantSearchInstance", "widgetParams"], + _excluded2 = ["widgetParams"]; +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } +function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } +function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } + + + + + + + + +function useConnector(connector) { + var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var additionalWidgetProperties = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var serverContext = (0,_lib_useInstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_1__.useInstantSearchServerContext)(); + var search = (0,_lib_useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_2__.useInstantSearchContext)(); + var parentIndex = (0,_lib_useIndexContext_js__WEBPACK_IMPORTED_MODULE_3__.useIndexContext)(); + var stableProps = (0,_lib_useStableValue_js__WEBPACK_IMPORTED_MODULE_4__.useStableValue)(props); + var stableAdditionalWidgetProperties = (0,_lib_useStableValue_js__WEBPACK_IMPORTED_MODULE_4__.useStableValue)(additionalWidgetProperties); + var shouldSetStateRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(true); + var previousRenderStateRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null); + var widget = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function () { + var createWidget = connector(function (connectorState, isFirstRender) { + // We skip the `init` widget render because: + // - We rely on `getWidgetRenderState` to compute the initial state before + // the InstantSearch.js lifecycle starts. + // - It prevents UI flashes when updating the widget props. + if (isFirstRender) { + shouldSetStateRef.current = true; + return; + } + + // There are situations where InstantSearch.js may render widgets slightly + // after they're removed by React, and thus try to update the React state + // on unmounted components. React 16 and 17 consider them as memory leaks + // and display a warning. + // This happens in when `attributesToRender` contains a + // value without an attribute previously mounted. React will unmount the + // component controlled by that attribute, but InstantSearch.js will stay + // unaware of this change until the render pass finishes, and therefore + // notifies of a state change. + // This ref lets us track this situation and ignore these state updates. + if (shouldSetStateRef.current) { + var instantSearchInstance = connectorState.instantSearchInstance, + widgetParams = connectorState.widgetParams, + renderState = _objectWithoutProperties(connectorState, _excluded); + + // We only update the state when a widget render state param changes, + // except for functions. We ignore function reference changes to avoid + // infinite loops. It's safe to omit them because they get updated + // every time another render param changes. + if (!(0,_lib_dequal_js__WEBPACK_IMPORTED_MODULE_5__.dequal)(renderState, previousRenderStateRef.current, function (a, b) { + return (a === null || a === void 0 ? void 0 : a.constructor) === Function && (b === null || b === void 0 ? void 0 : b.constructor) === Function; + })) { + // eslint-disable-next-line @typescript-eslint/no-use-before-define + setState(renderState); + previousRenderStateRef.current = renderState; + } + } + }, function () { + // We'll ignore the next state update until we know for sure that + // InstantSearch.js re-inits the component. + shouldSetStateRef.current = false; + }); + return _objectSpread(_objectSpread({}, createWidget(stableProps)), stableAdditionalWidgetProperties); + }, [connector, stableProps, stableAdditionalWidgetProperties]); + var _useState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(function () { + if (widget.getWidgetRenderState) { + var _widget$getWidgetSear; + // The helper exists because we've started InstantSearch. + var helper = parentIndex.getHelper(); + var uiState = parentIndex.getWidgetUiState({})[parentIndex.getIndexId()]; + helper.state = ((_widget$getWidgetSear = widget.getWidgetSearchParameters) === null || _widget$getWidgetSear === void 0 ? void 0 : _widget$getWidgetSear.call(widget, helper.state, { + uiState: uiState + })) || helper.state; + var _getIndexSearchResult = (0,_lib_getIndexSearchResults_js__WEBPACK_IMPORTED_MODULE_6__.getIndexSearchResults)(parentIndex), + results = _getIndexSearchResult.results, + scopedResults = _getIndexSearchResult.scopedResults; + + // We get the widget render state by providing the same parameters as + // InstantSearch provides to the widget's `render` method. + // See https://github.com/algolia/instantsearch.js/blob/019cd18d0de6dd320284aa4890541b7fe2198c65/src/widgets/index/index.ts#L604-L617 + var _widget$getWidgetRend = widget.getWidgetRenderState({ + helper: helper, + parent: parentIndex, + instantSearchInstance: search, + results: results, + scopedResults: scopedResults, + state: helper.state, + renderState: search.renderState, + templatesConfig: search.templatesConfig, + createURL: parentIndex.createURL, + searchMetadata: { + isSearchStalled: search.status === 'stalled' + }, + status: search.status, + error: search.error + }), + widgetParams = _widget$getWidgetRend.widgetParams, + renderState = _objectWithoutProperties(_widget$getWidgetRend, _excluded2); + return renderState; + } + return {}; + }), + _useState2 = _slicedToArray(_useState, 2), + state = _useState2[0], + setState = _useState2[1]; + (0,_lib_useWidget_js__WEBPACK_IMPORTED_MODULE_7__.useWidget)({ + widget: widget, + parentIndex: parentIndex, + props: stableProps, + shouldSsr: Boolean(serverContext) + }); + return state; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/hooks/useInstantSearch.js": +/*!**********************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/hooks/useInstantSearch.js ***! + \**********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useInstantSearch": () => (/* binding */ useInstantSearch) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _lib_useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../lib/useInstantSearchContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js"); +/* harmony import */ var _lib_useIsomorphicLayoutEffect_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../lib/useIsomorphicLayoutEffect.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIsomorphicLayoutEffect.js"); +/* harmony import */ var _lib_useSearchResults_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../lib/useSearchResults.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchResults.js"); +/* harmony import */ var _lib_useSearchState_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../lib/useSearchState.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchState.js"); + + + + + +function useInstantSearch() { + var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, + catchError = _ref.catchError; + var search = (0,_lib_useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__.useInstantSearchContext)(); + var _useSearchState = (0,_lib_useSearchState_js__WEBPACK_IMPORTED_MODULE_2__.useSearchState)(), + uiState = _useSearchState.uiState, + setUiState = _useSearchState.setUiState, + indexUiState = _useSearchState.indexUiState, + setIndexUiState = _useSearchState.setIndexUiState; + var _useSearchResults = (0,_lib_useSearchResults_js__WEBPACK_IMPORTED_MODULE_3__.useSearchResults)(), + results = _useSearchResults.results, + scopedResults = _useSearchResults.scopedResults; + var use = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function () { + for (var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++) { + middlewares[_key] = arguments[_key]; + } + search.use.apply(search, middlewares); + return function () { + search.unuse.apply(search, middlewares); + }; + }, [search]); + var refresh = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function () { + search.refresh(); + }, [search]); + (0,_lib_useIsomorphicLayoutEffect_js__WEBPACK_IMPORTED_MODULE_4__.useIsomorphicLayoutEffect)(function () { + if (catchError) { + var onError = function onError() {}; + search.addListener('error', onError); + return function () { + return search.removeListener('error', onError); + }; + } + return function () {}; + }, [search, catchError]); + return { + results: results, + scopedResults: scopedResults, + uiState: uiState, + setUiState: setUiState, + indexUiState: indexUiState, + setIndexUiState: setIndexUiState, + use: use, + refresh: refresh, + status: search.status, + error: search.error + }; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/IndexContext.js": +/*!****************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/IndexContext.js ***! + \****************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "IndexContext": () => (/* binding */ IndexContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); + +var IndexContext = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(null); +if (true) { + IndexContext.displayName = 'Index'; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchContext.js": +/*!************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchContext.js ***! + \************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "InstantSearchContext": () => (/* binding */ InstantSearchContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); + +var InstantSearchContext = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(null); +if (true) { + InstantSearchContext.displayName = 'InstantSearch'; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchSSRContext.js": +/*!***************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchSSRContext.js ***! + \***************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "InstantSearchSSRContext": () => (/* binding */ InstantSearchSSRContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); + +var InstantSearchSSRContext = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)(null); +if (true) { + InstantSearchSSRContext.displayName = 'InstantSearchSSR'; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/createSearchResults.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/createSearchResults.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "createSearchResults": () => (/* binding */ createSearchResults) +/* harmony export */ }); +/* harmony import */ var algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! algoliasearch-helper */ "./node_modules/algoliasearch-helper/index.js"); + +function createSearchResults(state) { + var _state$query, _state$page, _state$hitsPerPage; + return new algoliasearch_helper__WEBPACK_IMPORTED_MODULE_0__.SearchResults(state, [{ + query: (_state$query = state.query) !== null && _state$query !== void 0 ? _state$query : '', + page: (_state$page = state.page) !== null && _state$page !== void 0 ? _state$page : 0, + hitsPerPage: (_state$hitsPerPage = state.hitsPerPage) !== null && _state$hitsPerPage !== void 0 ? _state$hitsPerPage : 20, + hits: [], + nbHits: 0, + nbPages: 0, + params: '', + exhaustiveNbHits: true, + exhaustiveFacetsCount: true, + processingTimeMS: 0, + index: state.index + }], { + /** used by connectors to prevent persisting these results */ + __isArtificial: true + }); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/dequal.js": +/*!**********************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/dequal.js ***! + \**********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "dequal": () => (/* binding */ dequal) +/* harmony export */ }); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +/* eslint-disable complexity */ + +/* + * Code taken from dequal/lite v2.0.0 + * https://github.com/lukeed/dequal/blob/9aa73181ac7e081cd330cac67d313632ac04bb02/src/lite.js + * + * It adds a 3rd argument `compare(a, b)` that lets execute custom logic to + * compare values. + * We use it to skip comparing function references. + */ + +var has = Object.prototype.hasOwnProperty; +function dequal(foo, bar, compare) { + // start of custom implementation + if (compare !== null && compare !== void 0 && compare(foo, bar)) { + return true; + } + // end of custom implementation + + var ctor; + var len; + if (foo === bar) return true; + if (foo && bar && (ctor = foo.constructor) === bar.constructor) { + if (ctor === Date) return foo.getTime() === bar.getTime(); + if (ctor === RegExp) return foo.toString() === bar.toString(); + if (ctor === Array) { + if ((len = foo.length) === bar.length) { + while (len-- && dequal(foo[len], bar[len], compare)); + } + return len === -1; + } + if (!ctor || _typeof(foo) === 'object') { + len = 0; + // eslint-disable-next-line guard-for-in, no-restricted-syntax + for (ctor in foo) { + if (has.call(foo, ctor) && ++len && !has.call(bar, ctor)) return false; + if (!(ctor in bar) || !dequal(foo[ctor], bar[ctor], compare)) return false; + } + return Object.keys(bar).length === len; + } + } + + // eslint-disable-next-line no-self-compare + return foo !== foo && bar !== bar; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/getIndexSearchResults.js": +/*!*************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/getIndexSearchResults.js ***! + \*************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "getIndexSearchResults": () => (/* binding */ getIndexSearchResults) +/* harmony export */ }); +/* harmony import */ var _createSearchResults_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./createSearchResults.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/createSearchResults.js"); +function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; } +function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } +function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); } +function _toPrimitive(input, hint) { if (_typeof(input) !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (_typeof(res) !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); } + +function getIndexSearchResults(indexWidget) { + var helper = indexWidget.getHelper(); + var results = + // On SSR, we get the results injected on the Index. + indexWidget.getResults() || + // On the browser, we create fallback results based on the helper state. + (0,_createSearchResults_js__WEBPACK_IMPORTED_MODULE_0__.createSearchResults)(helper.state); + var scopedResults = indexWidget.getScopedResults().map(function (scopedResult) { + var fallbackResults = scopedResult.indexId === indexWidget.getIndexId() ? results : (0,_createSearchResults_js__WEBPACK_IMPORTED_MODULE_0__.createSearchResults)(scopedResult.helper.state); + return _objectSpread(_objectSpread({}, scopedResult), {}, { + // We keep `results` from being `null`. + results: scopedResult.results || fallbackResults + }); + }); + return { + results: results, + scopedResults: scopedResults + }; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/invariant.js": +/*!*************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/invariant.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "invariant": () => (/* binding */ invariant) +/* harmony export */ }); +/** + * Throws an error if the condition is not met. + * + * The error is exhaustive in development, and becomes generic in production. + * + * This is used to make development a better experience to provide guidance as + * to where the error comes from. + */ +function invariant(condition, message) { + if (condition) { + return; + } + if (false) {} + if (true) { + throw new Error("[InstantSearch] ".concat(typeof message === 'function' ? message() : message)); + } +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useForceUpdate.js": +/*!******************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useForceUpdate.js ***! + \******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useForceUpdate": () => (/* binding */ useForceUpdate) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + + +/** + * Forces a React update that triggers a rerender. + * @link https://reactjs.org/docs/hooks-faq.html#is-there-something-like-forceupdate + */ +function useForceUpdate() { + var _useReducer = (0,react__WEBPACK_IMPORTED_MODULE_0__.useReducer)(function (x) { + return x + 1; + }, 0), + _useReducer2 = _slicedToArray(_useReducer, 2), + forceUpdate = _useReducer2[1]; + return forceUpdate; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIndex.js": +/*!************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useIndex.js ***! + \************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useIndex": () => (/* binding */ useIndex) +/* harmony export */ }); +/* harmony import */ var instantsearch_js_es_widgets_index_index_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! instantsearch.js/es/widgets/index/index.js */ "./node_modules/instantsearch.js/es/widgets/index/index.js"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _useIndexContext_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./useIndexContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIndexContext.js"); +/* harmony import */ var _useForceUpdate_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./useForceUpdate.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useForceUpdate.js"); +/* harmony import */ var _useInstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./useInstantSearchServerContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchServerContext.js"); +/* harmony import */ var _useInstantSearchSSRContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./useInstantSearchSSRContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchSSRContext.js"); +/* harmony import */ var _useIsomorphicLayoutEffect_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./useIsomorphicLayoutEffect.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIsomorphicLayoutEffect.js"); +/* harmony import */ var _useStableValue_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./useStableValue.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useStableValue.js"); +/* harmony import */ var _useWidget_js__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./useWidget.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useWidget.js"); + + + + + + + + + +function useIndex(props) { + var serverContext = (0,_useInstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_1__.useInstantSearchServerContext)(); + var ssrContext = (0,_useInstantSearchSSRContext_js__WEBPACK_IMPORTED_MODULE_2__.useInstantSearchSSRContext)(); + var initialResults = ssrContext === null || ssrContext === void 0 ? void 0 : ssrContext.initialResults; + var parentIndex = (0,_useIndexContext_js__WEBPACK_IMPORTED_MODULE_3__.useIndexContext)(); + var stableProps = (0,_useStableValue_js__WEBPACK_IMPORTED_MODULE_4__.useStableValue)(props); + var indexWidget = (0,react__WEBPACK_IMPORTED_MODULE_0__.useMemo)(function () { + return (0,instantsearch_js_es_widgets_index_index_js__WEBPACK_IMPORTED_MODULE_5__["default"])(stableProps); + }, [stableProps]); + var helper = indexWidget.getHelper(); + var forceUpdate = (0,_useForceUpdate_js__WEBPACK_IMPORTED_MODULE_6__.useForceUpdate)(); + (0,_useIsomorphicLayoutEffect_js__WEBPACK_IMPORTED_MODULE_7__.useIsomorphicLayoutEffect)(function () { + forceUpdate(); + }, [helper, forceUpdate]); + (0,_useWidget_js__WEBPACK_IMPORTED_MODULE_8__.useWidget)({ + widget: indexWidget, + parentIndex: parentIndex, + props: stableProps, + shouldSsr: Boolean(serverContext || initialResults) + }); + return indexWidget; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIndexContext.js": +/*!*******************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useIndexContext.js ***! + \*******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useIndexContext": () => (/* binding */ useIndexContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _invariant_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./invariant.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/invariant.js"); +/* harmony import */ var _IndexContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./IndexContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/IndexContext.js"); + + + +function useIndexContext() { + var context = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_IndexContext_js__WEBPACK_IMPORTED_MODULE_1__.IndexContext); + (0,_invariant_js__WEBPACK_IMPORTED_MODULE_2__.invariant)(context !== null, 'The component must be used within .'); + return context; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchApi.js": +/*!***********************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchApi.js ***! + \***********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useInstantSearchApi": () => (/* binding */ useInstantSearchApi) +/* harmony export */ }); +/* harmony import */ var instantsearch_js_es_lib_InstantSearch_js__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! instantsearch.js/es/lib/InstantSearch.js */ "./node_modules/instantsearch.js/es/lib/InstantSearch.js"); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var use_sync_external_store_shim_index_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! use-sync-external-store/shim/index.js */ "./node_modules/use-sync-external-store/shim/index.js"); +/* harmony import */ var _useInstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./useInstantSearchServerContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchServerContext.js"); +/* harmony import */ var _useInstantSearchSSRContext_js__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./useInstantSearchSSRContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchSSRContext.js"); +/* harmony import */ var _version_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../version.js */ "./node_modules/react-instantsearch-hooks/dist/es/version.js"); +/* harmony import */ var _useForceUpdate_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./useForceUpdate.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useForceUpdate.js"); +/* harmony import */ var _warn_js__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./warn.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/warn.js"); + + + + + + + + +var defaultUserAgents = ["react (".concat(react__WEBPACK_IMPORTED_MODULE_0__.version, ")"), "react-instantsearch (".concat(_version_js__WEBPACK_IMPORTED_MODULE_2__["default"], ")"), "react-instantsearch-hooks (".concat(_version_js__WEBPACK_IMPORTED_MODULE_2__["default"], ")")]; +var serverUserAgent = "react-instantsearch-server (".concat(_version_js__WEBPACK_IMPORTED_MODULE_2__["default"], ")"); +function useInstantSearchApi(props) { + var forceUpdate = (0,_useForceUpdate_js__WEBPACK_IMPORTED_MODULE_3__.useForceUpdate)(); + var serverContext = (0,_useInstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_4__.useInstantSearchServerContext)(); + var serverState = (0,_useInstantSearchSSRContext_js__WEBPACK_IMPORTED_MODULE_5__.useInstantSearchSSRContext)(); + var initialResults = serverState === null || serverState === void 0 ? void 0 : serverState.initialResults; + var prevPropsRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(props); + var searchRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null); + // As we need to render on mount with SSR, using the local ref above in `StrictMode` will + // create and start two instances of InstantSearch. To avoid this, we instead discard it and use + // an upward ref from `InstantSearchSSRContext` as it has already been mounted a second time at this point. + if (serverState) { + searchRef = serverState.ssrSearchRef; + } + if (searchRef.current === null) { + // We don't use the `instantsearch()` function because it comes with other + // top-level APIs that we don't need. + // See https://github.com/algolia/instantsearch.js/blob/5b529f43d8acc680f85837eaaa41f7fd03a3f833/src/index.es.ts#L63-L86 + var search = new instantsearch_js_es_lib_InstantSearch_js__WEBPACK_IMPORTED_MODULE_6__["default"](props); + search._schedule = function _schedule(cb) { + search._schedule.queue.push(cb); + clearTimeout(search._schedule.timer); + search._schedule.timer = setTimeout(function () { + search._schedule.queue.forEach(function (callback) { + callback(); + }); + search._schedule.queue = []; + }, 0); + }; + search._schedule.queue = []; + if (serverContext || initialResults) { + // InstantSearch.js has a private Initial Results API that lets us inject + // results on the search instance. + // On the server, we default the initial results to an empty object so that + // InstantSearch.js doesn't schedule a search that isn't used, leading to + // an additional network request. (This is equivalent to monkey-patching + // `scheduleSearch` to a noop.) + search._initialResults = initialResults || {}; + } + addAlgoliaAgents(props.searchClient, [].concat(defaultUserAgents, [serverContext && serverUserAgent])); + + // On the server, we start the search early to compute the search parameters. + // On SSR, we start the search early to directly catch up with the lifecycle + // and render. + if (serverContext || initialResults) { + search.start(); + } + if (serverContext) { + // We notify `getServerState()` of the InstantSearch internals to retrieve + // the server state and pass it to the render on SSR. + serverContext.notifyServer({ + search: search + }); + } + warnNextRouter(props.routing); + searchRef.current = search; + } + { + var _search = searchRef.current; + var prevProps = prevPropsRef.current; + if (prevProps.indexName !== props.indexName) { + _search.helper.setIndex(props.indexName).search(); + prevPropsRef.current = props; + } + if (prevProps.searchClient !== props.searchClient) { + true ? (0,_warn_js__WEBPACK_IMPORTED_MODULE_7__.warn)(false, 'The `searchClient` prop of `` changed between renders, which may cause more search requests than necessary. If this is an unwanted behavior, please provide a stable reference: https://www.algolia.com/doc/api-reference/widgets/instantsearch/react-hooks/#widget-param-searchclient') : 0; + addAlgoliaAgents(props.searchClient, [].concat(defaultUserAgents, [serverContext && serverUserAgent])); + _search.mainHelper.setClient(props.searchClient).search(); + prevPropsRef.current = props; + } + if (prevProps.onStateChange !== props.onStateChange) { + _search.onStateChange = props.onStateChange; + prevPropsRef.current = props; + } + if (prevProps.searchFunction !== props.searchFunction) { + // Updating the `searchFunction` to `undefined` is not supported by + // InstantSearch.js, so it will throw an error. + // This is a fair behavior until we add an update API in InstantSearch.js. + _search._searchFunction = props.searchFunction; + prevPropsRef.current = props; + } + if (prevProps.stalledSearchDelay !== props.stalledSearchDelay) { + var _props$stalledSearchD; + // The default `stalledSearchDelay` in InstantSearch.js is 200ms. + // We need to reset it when it's undefined to get back to the original value. + _search._stalledSearchDelay = (_props$stalledSearchD = props.stalledSearchDelay) !== null && _props$stalledSearchD !== void 0 ? _props$stalledSearchD : 200; + prevPropsRef.current = props; + } + + // Updating the `routing` prop is not supported because InstantSearch.js + // doesn't let us change it. This might not be a problem though, because `routing` + // shouldn't need to be dynamic. + // If we find scenarios where `routing` needs to change, we can always expose + // it privately on the InstantSearch instance. Another way would be to + // manually inject the routing middleware in this library, and not rely + // on the provided `routing` prop. + } + + var cleanupTimerRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null); + var store = (0,use_sync_external_store_shim_index_js__WEBPACK_IMPORTED_MODULE_1__.useSyncExternalStore)((0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function () { + var search = searchRef.current; + + // Scenario 1: the component mounts. + if (cleanupTimerRef.current === null) { + // On SSR, the instance is already started so we don't start it again. + if (!search.started) { + search.start(); + forceUpdate(); + } + } + // Scenario 2: the component updates. + else { + // We cancel the previous cleanup function because we don't want to + // dispose the search during an update. + clearTimeout(cleanupTimerRef.current); + search._preventWidgetCleanup = false; + } + return function () { + function cleanup() { + search.dispose(); + } + clearTimeout(search._schedule.timer); + // We clean up only when the component that uses this subscription unmounts, + // but not when it updates, because it would dispose the instance, which + // would remove all the widgets and break routing. + // Executing the cleanup function in a `setTimeout()` lets us cancel it + // in the next effect. + // (There might be better ways to do this.) + cleanupTimerRef.current = setTimeout(cleanup); + + // We need to prevent the `useWidget` cleanup function so that widgets + // are not removed before the instance is disposed, triggering + // an unwanted search request. + search._preventWidgetCleanup = true; + }; + }, [forceUpdate]), function () { + return searchRef.current; + }, function () { + return searchRef.current; + }); + return store; +} +function addAlgoliaAgents(searchClient, userAgents) { + if (typeof searchClient.addAlgoliaAgent !== 'function') { + return; + } + userAgents.filter(Boolean).forEach(function (userAgent) { + searchClient.addAlgoliaAgent(userAgent); + }); +} +function warnNextRouter(routing) { + if (true) { + var _routing$router; + if (!routing || typeof window === 'undefined' || !('__NEXT_DATA__' in window)) { + return; + } + var isUsingNextRouter = + // @ts-expect-error: _isNextRouter is only set on the Next.js router + routing !== true && (routing === null || routing === void 0 ? void 0 : (_routing$router = routing.router) === null || _routing$router === void 0 ? void 0 : _routing$router._isNextRouter); + true ? (0,_warn_js__WEBPACK_IMPORTED_MODULE_7__.warn)(isUsingNextRouter, "\nYou are using Next.js with InstantSearch without the \"react-instantsearch-hooks-router-nextjs\" package.\nThis package is recommended to make the routing work correctly with Next.js.\nPlease check its usage instructions: https://github.com/algolia/instantsearch/tree/master/packages/react-instantsearch-hooks-router-nextjs\n\nYou can ignore this warning if you are using a custom router that suits your needs, it won't be outputted in production builds.") : 0; + } +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js": +/*!***************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js ***! + \***************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useInstantSearchContext": () => (/* binding */ useInstantSearchContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _invariant_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./invariant.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/invariant.js"); +/* harmony import */ var _InstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./InstantSearchContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchContext.js"); + + + +function useInstantSearchContext() { + var search = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_InstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__.InstantSearchContext); + (0,_invariant_js__WEBPACK_IMPORTED_MODULE_2__.invariant)(search !== null, 'Hooks must be used inside the component.\n\n' + 'They are not compatible with the `react-instantsearch-core` and `react-instantsearch-dom` packages, so make sure to use the component from `react-instantsearch-hooks`.'); + return search; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchSSRContext.js": +/*!******************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchSSRContext.js ***! + \******************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useInstantSearchSSRContext": () => (/* binding */ useInstantSearchSSRContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _InstantSearchSSRContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./InstantSearchSSRContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchSSRContext.js"); + + +function useInstantSearchSSRContext() { + return (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_InstantSearchSSRContext_js__WEBPACK_IMPORTED_MODULE_1__.InstantSearchSSRContext); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchServerContext.js": +/*!*********************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchServerContext.js ***! + \*********************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useInstantSearchServerContext": () => (/* binding */ useInstantSearchServerContext) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _components_InstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../components/InstantSearchServerContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearchServerContext.js"); + + +function useInstantSearchServerContext() { + return (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(_components_InstantSearchServerContext_js__WEBPACK_IMPORTED_MODULE_1__.InstantSearchServerContext); +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIsomorphicLayoutEffect.js": +/*!*****************************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useIsomorphicLayoutEffect.js ***! + \*****************************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useIsomorphicLayoutEffect": () => (/* binding */ useIsomorphicLayoutEffect) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); + + +/** + * `useLayoutEffect` that doesn't show a warning when server-side rendering. + * + * It uses `useEffect` on the server (no-op), and `useLayoutEffect` on the browser. + */ +var useIsomorphicLayoutEffect = typeof window !== 'undefined' ? react__WEBPACK_IMPORTED_MODULE_0__.useLayoutEffect : react__WEBPACK_IMPORTED_MODULE_0__.useEffect; + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchResults.js": +/*!********************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchResults.js ***! + \********************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useSearchResults": () => (/* binding */ useSearchResults) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _getIndexSearchResults_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./getIndexSearchResults.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/getIndexSearchResults.js"); +/* harmony import */ var _useIndexContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./useIndexContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIndexContext.js"); +/* harmony import */ var _useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./useInstantSearchContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js"); +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + + + + +function useSearchResults() { + var search = (0,_useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__.useInstantSearchContext)(); + var searchIndex = (0,_useIndexContext_js__WEBPACK_IMPORTED_MODULE_2__.useIndexContext)(); + var _useState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(function () { + return (0,_getIndexSearchResults_js__WEBPACK_IMPORTED_MODULE_3__.getIndexSearchResults)(searchIndex); + }), + _useState2 = _slicedToArray(_useState, 2), + searchResults = _useState2[0], + setSearchResults = _useState2[1]; + (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () { + function handleRender() { + var results = searchIndex.getResults(); + + // Results can be `null` when the first search is stalled. + // In this case, we skip the update. + // See: https://github.com/algolia/instantsearch.js/blob/20996c7a159988c58e00ff24d2d2dc98af8b980f/src/widgets/index/index.ts#L652-L657 + if (results !== null) { + setSearchResults({ + results: results, + scopedResults: searchIndex.getScopedResults() + }); + } + } + search.addListener('render', handleRender); + return function () { + search.removeListener('render', handleRender); + }; + }, [search, searchIndex]); + return searchResults; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchState.js": +/*!******************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchState.js ***! + \******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useSearchState": () => (/* binding */ useSearchState) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _useIndexContext_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./useIndexContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIndexContext.js"); +/* harmony import */ var _useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./useInstantSearchContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js"); +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + + + +function useSearchState() { + var search = (0,_useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__.useInstantSearchContext)(); + var searchIndex = (0,_useIndexContext_js__WEBPACK_IMPORTED_MODULE_2__.useIndexContext)(); + var indexId = searchIndex.getIndexId(); + var _useState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(function () { + return search.getUiState(); + }), + _useState2 = _slicedToArray(_useState, 2), + uiState = _useState2[0], + setLocalUiState = _useState2[1]; + var indexUiState = uiState[indexId]; + var setUiState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function (nextUiState) { + search.setUiState(nextUiState); + }, [search]); + var setIndexUiState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useCallback)(function (nextIndexUiState) { + searchIndex.setIndexUiState(nextIndexUiState); + }, [searchIndex]); + (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () { + function handleRender() { + setLocalUiState(search.getUiState()); + } + search.addListener('render', handleRender); + return function () { + search.removeListener('render', handleRender); + }; + }, [search]); + return { + uiState: uiState, + setUiState: setUiState, + indexUiState: indexUiState, + setIndexUiState: setIndexUiState + }; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useStableValue.js": +/*!******************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useStableValue.js ***! + \******************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useStableValue": () => (/* binding */ useStableValue) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _dequal_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./dequal.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/dequal.js"); +function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } +function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } +function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } +function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; } +function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } } +function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } + + +function useStableValue(value) { + var _useState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(function () { + return value; + }), + _useState2 = _slicedToArray(_useState, 2), + stableValue = _useState2[0], + setStableValue = _useState2[1]; + if (!(0,_dequal_js__WEBPACK_IMPORTED_MODULE_1__.dequal)(stableValue, value)) { + setStableValue(value); + } + return stableValue; +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/useWidget.js": +/*!*************************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/useWidget.js ***! + \*************************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "useWidget": () => (/* binding */ useWidget) +/* harmony export */ }); +/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ "react"); +/* harmony import */ var _dequal_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./dequal.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/dequal.js"); +/* harmony import */ var _useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./useInstantSearchContext.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js"); +/* harmony import */ var _useIsomorphicLayoutEffect_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./useIsomorphicLayoutEffect.js */ "./node_modules/react-instantsearch-hooks/dist/es/lib/useIsomorphicLayoutEffect.js"); + + + + +function useWidget(_ref) { + var widget = _ref.widget, + parentIndex = _ref.parentIndex, + props = _ref.props, + shouldSsr = _ref.shouldSsr; + var prevPropsRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(props); + (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () { + prevPropsRef.current = props; + }, [props]); + var prevWidgetRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(widget); + (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () { + prevWidgetRef.current = widget; + }, [widget]); + var cleanupTimerRef = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null); + var shouldAddWidgetEarly = shouldSsr && !parentIndex.getWidgets().includes(widget); + var search = (0,_useInstantSearchContext_js__WEBPACK_IMPORTED_MODULE_1__.useInstantSearchContext)(); + + // This effect is responsible for adding, removing, and updating the widget. + // We need to support scenarios where the widget is remounted quickly, like in + // Strict Mode, so that we don't lose its state, and therefore that we don't + // break routing. + (0,_useIsomorphicLayoutEffect_js__WEBPACK_IMPORTED_MODULE_2__.useIsomorphicLayoutEffect)(function () { + var previousWidget = prevWidgetRef.current; + + // Scenario 1: the widget is added for the first time. + if (!cleanupTimerRef.current) { + if (!shouldAddWidgetEarly) { + parentIndex.addWidgets([widget]); + } + } + // Scenario 2: the widget is rerendered or updated. + else { + // We cancel the original effect cleanup because it may not be necessary if + // props haven't changed. (We manually call it if it is below.) + clearTimeout(cleanupTimerRef.current); + + // Warning: if an unstable function prop is provided, `dequal` is not able + // to keep its reference and therefore will consider that props did change. + // This could unsollicitely remove/add the widget, therefore forget its state, + // and could be a source of confusion. + // If users face this issue, we should advise them to provide stable function + // references. + var arePropsEqual = (0,_dequal_js__WEBPACK_IMPORTED_MODULE_3__.dequal)(props, prevPropsRef.current); + + // If props did change, then we execute the cleanup function instantly + // and then add the widget back. This lets us add the widget without + // waiting for the scheduled cleanup function to finish (that we canceled + // above). + if (!arePropsEqual) { + parentIndex.removeWidgets([previousWidget]); + parentIndex.addWidgets([widget]); + } + } + return function () { + // We don't remove the widget right away, but rather schedule it so that + // we're able to cancel it in the next effect. + cleanupTimerRef.current = setTimeout(function () { + search._schedule(function () { + if (search._preventWidgetCleanup) return; + parentIndex.removeWidgets([previousWidget]); + }); + }); + }; + }, [parentIndex, widget, shouldAddWidgetEarly, search, props]); + if (shouldAddWidgetEarly) { + parentIndex.addWidgets([widget]); + } +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/lib/warn.js": +/*!********************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/lib/warn.js ***! + \********************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "warn": () => (/* binding */ warn), +/* harmony export */ "warnCache": () => (/* binding */ warnCache) +/* harmony export */ }); +/* eslint-disable no-console, no-empty */ + +var warnCache = { + current: {} +}; + +/** + * Logs a warning if the condition is not met. + * This is used to log issues in development environment only. + */ +function warn(condition, message) { + if (false) {} + if (condition) { + return; + } + var sanitizedMessage = message.trim(); + var hasAlreadyPrinted = warnCache.current[sanitizedMessage]; + if (!hasAlreadyPrinted) { + warnCache.current[sanitizedMessage] = true; + var warning = "[InstantSearch] ".concat(sanitizedMessage); + console.warn(warning); + try { + // Welcome to debugging InstantSearch. + // + // This error was thrown as a convenience so that you can find the source + // of the warning that appears in the console by enabling "Pause on exceptions" + // in your debugger. + throw new Error(warning); + } catch (error) {} + } +} + +/***/ }), + +/***/ "./node_modules/react-instantsearch-hooks/dist/es/version.js": +/*!*******************************************************************!*\ + !*** ./node_modules/react-instantsearch-hooks/dist/es/version.js ***! + \*******************************************************************/ +/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export */ __webpack_require__.d(__webpack_exports__, { +/* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__) +/* harmony export */ }); +/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = ('6.38.1'); + +/***/ }) + +/******/ }); +/************************************************************************/ +/******/ // The module cache +/******/ var __webpack_module_cache__ = {}; +/******/ +/******/ // The require function +/******/ function __webpack_require__(moduleId) { +/******/ // Check if module is in cache +/******/ var cachedModule = __webpack_module_cache__[moduleId]; +/******/ if (cachedModule !== undefined) { +/******/ return cachedModule.exports; +/******/ } +/******/ // Create a new module (and put it into the cache) +/******/ var module = __webpack_module_cache__[moduleId] = { +/******/ // no module.id needed +/******/ // no module.loaded needed +/******/ exports: {} +/******/ }; +/******/ +/******/ // Execute the module function +/******/ __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__); +/******/ +/******/ // Return the exports of the module +/******/ return module.exports; +/******/ } +/******/ +/************************************************************************/ +/******/ /* webpack/runtime/compat get default export */ +/******/ (() => { +/******/ // getDefaultExport function for compatibility with non-harmony modules +/******/ __webpack_require__.n = (module) => { +/******/ var getter = module && module.__esModule ? +/******/ () => (module['default']) : +/******/ () => (module); +/******/ __webpack_require__.d(getter, { a: getter }); +/******/ return getter; +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/define property getters */ +/******/ (() => { +/******/ // define getter functions for harmony exports +/******/ __webpack_require__.d = (exports, definition) => { +/******/ for(var key in definition) { +/******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) { +/******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] }); +/******/ } +/******/ } +/******/ }; +/******/ })(); +/******/ +/******/ /* webpack/runtime/hasOwnProperty shorthand */ +/******/ (() => { +/******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop)) +/******/ })(); +/******/ +/******/ /* webpack/runtime/make namespace object */ +/******/ (() => { +/******/ // define __esModule on exports +/******/ __webpack_require__.r = (exports) => { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ })(); +/******/ +/************************************************************************/ +/******/ +/******/ // startup +/******/ // Load entry module and return exports +/******/ // This entry module is referenced by other modules so it can't be inlined +/******/ var __webpack_exports__ = __webpack_require__("./src/index.js"); +/******/ +/******/ })() +; +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/build/index.js.map b/build/index.js.map new file mode 100644 index 0000000..d62a749 --- /dev/null +++ b/build/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","mappings":";;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB,QAAQ;AACR;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,gBAAgB,SAAS;AACzB;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,IAAI;AACJ,qBAAqB,QAAQ;AAC7B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AA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;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;AC9DA;AACA;AACA;AACO;;;;;;;;;;;;;;;;;;;;;;;ACHyB;AACK;AACI;AACA;;AAEoB;;AAE7D;AACA;AACA;AACO;AACP,QAAQ;AACR,QAAQ;AACR,UAAU;AACV;;AAEO,cAAc,iEAAgB,EAAE,kDAAU;AACjD,yDAAQ;;;;;;;;;;;;;;;;;;;ACjB0C;;AAElD;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH,EAAE;AACF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,iEAAe,gEAAe;AAC9B;AACA,EAAE,CAAC,EAAC;;;;;;;;;;;;;;;;;;;;AC7EJ;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,OAAO;AACnB;AACO;AACP;AACA;;AAEA;AACA;AACA,WAAW,GAAG;AACd,YAAY,OAAO;AACnB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA,WAAW,GAAG;AACd,YAAY,QAAQ;AACpB;AACO;AACP;AACA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACO;AACP;AACA;;;;;;;;;;;;;;;;;AC/CsC;;AAIrC;;;;;;;;;;;;;;;;;;ACJ2C;;AAE5C;;AAEA;AACA;AACA,IAAI,2DAAQ;AACZ;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA,iEAAe,QAAQ,EAAC;;;;;;;;;;;;;;;;;ACjBe;;AAEvC;AACA,YAAY,sDAAQ;AACpB;;AAEA,iEAAe,QAAQ,EAAC;;;;;;;;;;;;;;;;;;;ACNxB;AACA,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC3Q;AAC/B;AACA,sBAAsB,gDAAmB;AACzC;AACA;AACA;AACA;AACA,GAAG,mCAAmC,gDAAmB;AACzD;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA;AACA;AACA;AACA,GAAG,qCAAqC,gDAAmB,4BAA4B,gDAAmB;AAC1G;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA;AACA;AACA;AACA,GAAG,iBAAiB,gDAAmB;AACvC;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA;AACA;AACA;AACA,GAAG;AACH;AACsC;AACtC,iEAAe,oBAAoB,o3BAAo3B;;;;;;;;;;;;;;;;;;ACnCv5B,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC3Q;AAC/B;AACA,sBAAsB,gDAAmB;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,uBAAuB,gDAAmB;AAC7C;AACA;AACA,KAAK;AACL;AACA,GAAG;AACH;AACmC;AACnC,iEAAe,oBAAoB,gzBAAgzB;;;;;;;;;;;;;;;;;;ACnBn1B;AACA,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC3Q;AAC/B;AACA,sBAAsB,gDAAmB;AACzC;AACA;AACA;AACA;AACA,GAAG,yCAAyC,gDAAmB;AAC/D;AACA;AACA;AACA;AACA,GAAG;AACH;AACqC;AACrC,iEAAe,oBAAoB,woEAAwoE;;;;;;;;;;;;;;;;;;ACjB3qE;AACA,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC3Q;AAC/B;AACA,sBAAsB,gDAAmB;AACzC;AACA;AACA;AACA;AACA,GAAG,yCAAyC,gDAAmB;AAC/D;AACA;AACA;AACA;AACA,GAAG,qCAAqC,gDAAmB;AAC3D;AACA;AACA;AACA;AACA;AACA,GAAG,qCAAqC,gDAAmB;AAC3D;AACA;AACA;AACA;AACA;AACA,GAAG,qCAAqC,gDAAmB;AAC3D;AACA;AACA;AACA;AACA;AACA,GAAG,mCAAmC,gDAAmB;AACzD;AACA;AACA,GAAG,mCAAmC,gDAAmB,4BAA4B,gDAAmB;AACxG;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA,GAAG,gBAAgB,gDAAmB;AACtC;AACA;AACA;AACA,GAAG,iBAAiB,gDAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA,GAAG,gBAAgB,gDAAmB;AACtC;AACA;AACA;AACA,GAAG,iBAAiB,gDAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA,GAAG,gBAAgB,gDAAmB;AACtC;AACA;AACA;AACA,GAAG,gBAAgB,gDAAmB;AACtC;AACA;AACA;AACA,GAAG,iBAAiB,gDAAmB;AACvC;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA,GAAG,gBAAgB,gDAAmB;AACtC;AACA;AACA;AACA,GAAG;AACH;AACuC;AACvC,iEAAe,oBAAoB,48DAA48D;;;;;;;;;;;;;;;;;;AC9F/+D;AACA,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC3Q;AAC/B;AACA,sBAAsB,gDAAmB;AACzC;AACA;AACA;AACA;AACA;AACA,GAAG,yCAAyC,gDAAmB;AAC/D;AACA;AACA,GAAG,mCAAmC,gDAAmB,4BAA4B,gDAAmB;AACxG;AACA;AACA;AACA;AACA,GAAG,eAAe,gDAAmB;AACrC;AACA;AACA,GAAG,iBAAiB,gDAAmB;AACvC;AACA;AACA;AACA,+BAA+B;AAC/B,GAAG;AACH;AACyC;AACzC,iEAAe,oBAAoB,4utIAA4utI;;;;;;;;;;;;;;;;;;AC7B/wtI;AACA,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC3Q;AAC/B;AACA,sBAAsB,gDAAmB;AACzC;AACA;AACA;AACA;AACA,GAAG,yCAAyC,gDAAmB;AAC/D;AACA;AACA;AACA;AACA;AACA;AACA,GAAG,mCAAmC,gDAAmB;AACzD;AACA;AACA,GAAG;AACH;AACuC;AACvC,iEAAe,oBAAoB,4sBAA4sB;;;;;;;;;;;ACtBluB;;AAEb,0BAA0B,mBAAO,CAAC,mGAA4B;;AAE9D,uBAAuB,mBAAO,CAAC,iGAAwB;AACvD,oBAAoB,mBAAO,CAAC,2FAAqB;;AAEjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,eAAe;AAC3B,YAAY,QAAQ;AACpB,YAAY,yBAAyB,mFAAmF,iBAAiB;AACzI,YAAY;AACZ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA,8BAA8B,mBAAO,CAAC,4EAAkB;;AAExD;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;;;;;;;;;;;;ACtEa;;AAEb,mBAAmB,mBAAO,CAAC,iEAAiB;AAC5C,eAAe,mBAAO,CAAC,4FAAuB;;AAE9C;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,qBAAqB;AAClD,OAAO,wBAAwB;AAC/B;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;;;;;;;;;;;ACrCa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,UAAU;AACvB,aAAa,8DAA8D;AAC3E;;AAEA,mBAAmB,mBAAO,CAAC,oGAA2B;AACtD,WAAW,mBAAO,CAAC,oFAAmB;AACtC,oBAAoB,mBAAO,CAAC,sGAA4B;;AAExD;AACA;AACA;AACA,aAAa,gBAAgB;AAC7B,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc,gBAAgB;AAC9B;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA,0BAA0B;AAC1B,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,gBAAgB;AAC7B,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc,gBAAgB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA,aAAa,gBAAgB;AAC7B,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc,gBAAgB;AAC9B;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,aAAa,gBAAgB;AAC7B,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc,gBAAgB;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;;AAEA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;;AAEA;AACA,OAAO,IAAI;;AAEX;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,gBAAgB;AAC7B,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;;;;;;;;;;;AClJa;;AAEb,YAAY,mBAAO,CAAC,sFAAoB;AACxC,mBAAmB,mBAAO,CAAC,oGAA2B;AACtD,mBAAmB,mBAAO,CAAC,oGAA2B;AACtD,WAAW,mBAAO,CAAC,oFAAmB;AACtC,kBAAkB,mBAAO,CAAC,kGAA0B;AACpD,WAAW,mBAAO,CAAC,oFAAmB;AACtC,oBAAoB,mBAAO,CAAC,sGAA4B;AACxD,uBAAuB,mBAAO,CAAC,oGAA2B;;AAE1D,qBAAqB,mBAAO,CAAC,oGAAkB;;AAE/C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,KAAK;AAChB,YAAY,KAAK;AACjB;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,aAAa,UAAU;AACvB;;AAEA;AACA;AACA;AACA,aAAa,0CAA0C;AACvD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,wCAAwC,0BAA0B;AAClE,iEAAiE;AACjE;AACA;AACA,WAAW,yBAAyB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,4IAA4I,KAAK;AACjJ;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,YAAY;AACZ;AACA;AACA;AACA,SAAS;AACT;AACA,OAAO;AACP,KAAK;AACL;AACA;;AAEA,iBAAiB;AACjB;;AAEA;AACA;AACA,WAAW,yBAAyB;AACpC;AACA,YAAY,kBAAkB;AAC9B;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA,WAAW,kBAAkB;AAC7B,WAAW,yBAAyB;AACpC,YAAY,YAAY;AACxB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,aAAa,iDAAiD;AAC9D;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,UAAU;AACvB,cAAc;AACd;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,UAAU;AACvB,cAAc;AACd;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,aAAa,mBAAmB;AAChC,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,sBAAsB;;AAEtB,6BAA6B;;AAE7B;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,UAAU;AACxB;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,UAAU;AACxB;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,UAAU;AACxB;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,UAAU;AACxB;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,MAAM;AACN;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,GAAG;AACH;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,+BAA+B;AAC7C;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc,yBAAyB;AACvC;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,uCAAuC;AACpD;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,6CAA6C,yBAAyB;AACtE;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,SAAS;;AAET;;AAEA;AACA,OAAO,IAAI;;AAEX;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc;AACd;AACA,4CAA4C;AAC5C;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;;AAEA;AACA,SAAS;AACT,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,OAAO;AACpB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,OAAO;AACpB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,OAAO;AACpB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,OAAO;AACpB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,QAAQ;AACR;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA,oDAAoD;AACpD,KAAK;AACL,GAAG;;AAEH;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc,iBAAiB;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oDAAoD;AACpD,KAAK;AACL,GAAG;;AAEH;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,iBAAiB;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oDAAoD;AACpD,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB;AACA,cAAc,SAAS;AACvB;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB;AACA,cAAc,SAAS;AACvB;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,aAAa,QAAQ;AACrB,cAAc,SAAS;AACvB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc;AACd;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,OAAO;AACpB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA,KAAK;AACL;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,OAAO;AACpB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,oDAAoD,oBAAoB;AACxE;AACA;AACA,OAAO;AACP;AACA,GAAG;AACH;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,aAAa,QAAQ;AACrB,aAAa,KAAK;AAClB;AACA,cAAc,kBAAkB;AAChC;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,kBAAkB;AAChC;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK,IAAI;;AAET;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,OAAO;AACP;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,cAAc,kBAAkB;AAChC;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,gBAAgB;AAC9B;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,wBAAwB;AACnC,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB;AACA,YAAY,SAAS;AACrB;AACA;;;;;;;;;;;;ACr+Ca;;AAEb;;AAEA,cAAc,mBAAO,CAAC,0FAAsB;AAC5C,WAAW,mBAAO,CAAC,oFAAmB;AACtC,qCAAqC,mBAAO,CAAC,gGAAyB;AACtE,SAAS,mBAAO,CAAC,4GAA+B;AAChD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA,kBAAkB,WAAW;AAC7B;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;AC3Ma;;AAEb,YAAY,mBAAO,CAAC,sFAAoB;AACxC,mBAAmB,mBAAO,CAAC,oGAA2B;AACtD,cAAc,mBAAO,CAAC,0FAAsB;AAC5C,cAAc,mBAAO,CAAC,0FAAsB;AAC5C,WAAW,mBAAO,CAAC,oFAAmB;AACtC,gBAAgB,mBAAO,CAAC,8FAAwB;AAChD,iBAAiB,mBAAO,CAAC,gGAAyB;AAClD,SAAS,mBAAO,CAAC,4GAA+B;AAChD;AACA;;AAEA,+BAA+B,mBAAO,CAAC,yHAA8B;;AAErE;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;;AAEA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB,cAAc,qBAAqB;AACnC;;AAEA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB,cAAc,SAAS;AACvB;;AAEA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB;;AAEA;AACA,WAAW,UAAU;AACrB;AACA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,aAAa,QAAQ;AACrB,cAAc,QAAQ;AACtB,cAAc,UAAU;AACxB;;AAEA;AACA,WAAW,qBAAqB;AAChC,WAAW,QAAQ;AACnB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA,IAAI,0BAA0B;AAC9B,WAAW,kBAAkB;AAC7B,WAAW,gBAAgB;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA,2BAA2B;AAC3B;AACA,GAAG;;AAEH;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,cAAc;AACd;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;;AAEA;AACA,YAAY;AACZ;AACA;AACA;AACA,QAAQ;AACR;;AAEA;;AAEA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,KAAK;AACL;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,SAAS;;AAET;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,wDAAwD;AACxD;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA,YAAY;AACZ;AACA;;AAEA;AACA,YAAY;AACZ;AACA;AACA;AACA,YAAY;AACZ;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,qBAAqB;AACjC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,eAAe;AAC1B,WAAW,QAAQ;AACnB,YAAY,cAAc;AAC1B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,WAAW,iCAAiC;AAC5C,WAAW,UAAU;AACrB,WAAW,QAAQ;AACnB;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,WAAW,UAAU;AACrB,WAAW,yBAAyB;AACpC,WAAW,UAAU;AACrB,WAAW,QAAQ;AACnB;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;AACA,8BAA8B,qBAAqB;AACnD;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV,cAAc,UAAU;AACxB,cAAc,8BAA8B;AAC5C;;AAEA;AACA;AACA,WAAW,OAAO;AAClB,WAAW,eAAe;AAC1B,aAAa;AACb;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,yBAAyB;AACzB;AACA;AACA;AACA;AACA,GAAG,IAAI;;AAEP;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA,WAAW,eAAe;AAC1B,WAAW,QAAQ;AACnB,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,SAAS;AACpB;AACA;AACA,WAAW,2BAA2B;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,0CAA0C;AACtD;AACA;AACA;AACA;AACA,2CAA2C,qBAAqB;AAChE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;;AAEA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;;AAEA;AACA;;AAEA;AACA,aAAa,QAAQ;AACrB,cAAc,QAAQ;AACtB;;AAEA;AACA,WAAW,iBAAiB;AAC5B,WAAW,QAAQ;AACnB;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,oBAAoB;AAChC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;AACA,KAAK;AACL,GAAG;;;AAGH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL,GAAG;;AAEH;AACA,cAAc,gDAAgD;AAC9D,GAAG;;AAEH;AACA;;AAEA;AACA,aAAa,QAAQ;AACrB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB;;AAEA;AACA,WAAW,GAAG;AACd,WAAW,GAAG;AACd,WAAW,QAAQ;AACnB,WAAW,GAAG;AACd,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,WAAW,GAAG;AACd,WAAW,QAAQ;AACnB,WAAW,GAAG;AACd,WAAW,SAAS;AACpB;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;AC/hCa;;AAEb,uBAAuB,mBAAO,CAAC,6FAAoB;AACnD,oBAAoB,mBAAO,CAAC,uFAAiB;AAC7C,oBAAoB,mBAAO,CAAC,uFAAiB;AAC7C,qBAAqB,mBAAO,CAAC,mFAAkB;;AAE/C,mBAAmB,mBAAO,CAAC,iEAAiB;AAC5C,eAAe,mBAAO,CAAC,2FAAsB;AAC7C,oBAAoB,mBAAO,CAAC,qGAA2B;AACvD,WAAW,mBAAO,CAAC,mFAAkB;AACrC,YAAY,mBAAO,CAAC,qFAAmB;;AAEvC,cAAc,mBAAO,CAAC,qEAAW;AACjC,uBAAuB,mJAAwD;;AAE/E;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,kBAAkB;AAChC,cAAc,eAAe;AAC7B;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,kBAAkB;AAChC,cAAc,eAAe;AAC7B;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,kBAAkB;AAChC,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,kBAAkB;AAChC;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,eAAe;AAC7B,cAAc,kBAAkB;AAChC;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,OAAO;AACrB;AACA;AACA;AACA,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,6BAA6B,wBAAwB;AACrD,OAAO,qBAAqB;AAC5B;AACA;AACA,6BAA6B,qBAAqB;AAClD,OAAO,wBAAwB;AAC/B;AACA,YAAY,eAAe;AAC3B,YAAY,QAAQ;AACpB,YAAY,2BAA2B;AACvC,kDAAkD,iBAAiB;AACnE;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA,gBAAgB,8BAA8B;AAC9C;AACA;;AAEA;AACA,gBAAgB,6BAA6B;AAC7C;AACA;;AAEA;AACA;AACA;AACA,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB;AACA,WAAW,UAAU;AACrB;AACA,YAAY,mBAAmB;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA,kCAAkC,eAAe;AACjD;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA,mCAAmC,eAAe;AAClD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA,OAAO;;AAEP;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,UAAU;AACrB,WAAW,UAAU;AACrB,WAAW,QAAQ;AACnB;AACA,YAAY,SAAS;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV,cAAc,gBAAgB;AAC9B,cAAc,QAAQ;AACtB;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB;AACA,YAAY,6BAA6B;AACzC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA,2DAA2D;AAC3D;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA,0CAA0C;AAC1C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA,yCAAyC;AACzC;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY;AACZ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,KAAK;AAChB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA,WAAW,kBAAkB;AAC7B,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,kBAAkB;AAC7B,YAAY;AACZ;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,SAAS;AACrB;AACA;AACA,mCAAmC;AACnC;AACA,mCAAmC;AACnC;AACA,mCAAmC;AACnC;AACA,mCAAmC;AACnC;AACA,sCAAsC;AACtC;AACA,sCAAsC;AACtC;AACA,wCAAwC;AACxC;AACA,wCAAwC;AACxC;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAY,SAAS;AACrB,YAAY,SAAS;AACrB;AACA,YAAY,SAAS;AACrB;AACA,qCAAqC;AACrC;AACA;AACA;AACA;AACA;AACA,qCAAqC;AACrC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;;AAEA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;;AAEA;AACA,iCAAiC;AACjC;AACA;AACA;AACA;;;AAGA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAY,QAAQ;AACpB;AACA;AACA;AACA;AACA;AACA,YAAY,QAAQ;AACpB;AACA;;AAEA;AACA;AACA;AACA,YAAY,UAAU;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY,2CAA2C;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL,IAAI;AACJ;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;;AAEA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY,yBAAyB;AACrC;AACA;AACA;AACA;;AAEA;AACA;AACA,YAAY,QAAQ;AACpB,YAAY,gBAAgB;AAC5B;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA,KAAK;;AAEL;AACA,GAAG;;AAEH;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ,sDAAsD;AACzE;AACA,WAAW,QAAQ;AACnB,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,YAAY;AACZ;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,YAAY,eAAe;AAC3B,YAAY;AACZ;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,UAAU;AACrB,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,YAAY,SAAS;AACrB;AACA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV,cAAc,UAAU;AACxB;AACA,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;;AAEA;AACA;AACA,UAAU;AACV,cAAc,QAAQ;AACtB,cAAc,QAAQ;AACtB;;AAEA;;;;;;;;;;;;ACz9Ca;;AAEb;AACA;AACA;AACA;;AAEA;AACA;;;;;;;;;;;;ACRa;;AAEb;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,GAAG,IAAI;AACP;;;;;;;;;;;;ACpBa;;AAEb;AACA;AACA;AACA,WAAW,KAAK;AAChB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,WAAW,KAAK;AAChB;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;;;;;;;;;;;AC7Ba;;AAEb;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,kBAAkB;AACpC;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACba;;AAEb;AACA;AACA;AACA;AACA;;AAEA,kBAAkB,kBAAkB;AACpC;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACda;;AAEb,WAAW,mBAAO,CAAC,yEAAQ;;AAE3B;AACA;AACA,WAAW,UAAU;AACrB,WAAW,UAAU;AACrB,YAAY,kBAAkB;AAC9B;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;;;;;;;;;;;ACrCa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;;;;;;ACba;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;;;;;;ACXa;;AAEb;AACA;AACA,gDAAgD;AAChD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,QAAQ;AACnB,WAAW,WAAW;AACtB,aAAa,QAAQ;AACrB;;AAEA;AACA;AACA;AACA;;AAEA,wCAAwC,OAAO;AAC/C;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;ACjFa;;AAEb;AACA;AACA;;AAEA;;;;;;;;;;;;ACNa;;AAEb;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc,uBAAuB;AACrC;AACA;AACA;AACA;AACA;AACA;;AAEA;;;;;;;;;;;;ACjBa;;AAEb;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,WAAW,eAAe;AAC1B,WAAW,eAAe;AAC1B,WAAW,eAAe;AAC1B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA,GAAG;AACH;;AAEA;;;;;;;;;;;;AC9Ea;;AAEb;AACA;AACA;AACA,IAAI;AACJ;AACA,IAAI;AACJ;AACA;;AAEA;AACA;;AAEA;;;;;;;;;;;;ACda;;AAEb,YAAY,mBAAO,CAAC,qFAAmB;;AAEvC;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK,IAAI;AACT;;AAEA;AACA;AACA;AACA;AACA;AACA,cAAc,UAAU;AACxB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa;AACb;;AAEA;AACA;AACA;AACA;AACA,eAAe;;AAEf;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,WAAW;;AAEX;AACA;AACA;AACA,YAAY;AACZ;AACA;;AAEA,wBAAwB,iCAAiC;AACzD,SAAS;AACT;AACA,KAAK;;AAEL;AACA,GAAG;;AAEH;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,8BAA8B;AAC9B,GAAG;;AAEH;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc,SAAS;AACvB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,8BAA8B;AAC9B,GAAG;;AAEH;AACA;AACA;AACA,aAAa,QAAQ;AACrB,cAAc,UAAU;AACxB;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;AACA,cAAc;AACd;AACA;AACA,WAAW;AACX;AACA,OAAO;AACP,KAAK;;AAEL;AACA,GAAG;;AAEH;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;;AAEA;AACA,GAAG;;;AAGH;AACA;AACA;AACA;AACA,cAAc,QAAQ;AACtB,cAAc;AACd;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;;AAEP;AACA,KAAK;;AAEL;AACA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AAI,KAAK;IAC1B,MAAMK,UAAU,GAAG,IAAIrC,6EAAU,CAAC,iBAAiB,EAAEoC,KAAK,EAAE;MAAE9C,KAAK,EAAE0C,IAAI;MAAEM,IAAI,EAAE,IAAIC,IAAI;IAAG,CAAC,CAAC;IAC9FxC,sFAAmB,CAACsC,UAAU,CAAC;EACjC;AACF,CAAC;;;;;;;;;;;AChDY;;AAEb;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;;;;;;;;;;;ACtBa;;AAEb,gBAAgB,mBAAO,CAAC,qFAAa;AACrC,YAAY,mBAAO,CAAC,6EAAS;AAC7B,cAAc,mBAAO,CAAC,iFAAW;;AAEjC;AACA;AACA;AACA;AACA;;;;;;;;;;;;ACVa;;AAEb,YAAY,mBAAO,CAAC,6EAAS;;AAE7B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,gCAAgC;AAChC;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,yCAAyC,+BAA+B;;AAExE;AACA,wCAAwC;;AAExC;AACA;AACA;AACA;AACA;AACA,wBAAwB;AACxB;;AAEA;AACA;AACA,oBAAoB,kBAAkB;AACtC;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA;AACA,kCAAkC;AAClC;AACA;AACA;;AAEA,gBAAgB,kBAAkB;AAClC;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA,mCAAmC,QAAQ;AAC3C;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA,wBAAwB;AACxB,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA,oBAAoB,iBAAiB;AACrC;AACA;AACA;AACA;;AAEA;AACA;;;;;;;;;;;;AChQa;;AAEb,YAAY,mBAAO,CAAC,6EAAS;AAC7B,cAAc,mBAAO,CAAC,iFAAW;AACjC;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,gCAAgC,wBAAwB;AACxD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,qBAAqB,gEAAgE;AACrF,MAAM;AACN;AACA,MAAM;AACN;AACA;AACA;;AAEA,oBAAoB,oBAAoB;AACxC;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA,MAAM;AACN;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA,oBAAoB,oBAAoB;AACxC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,2CAA2C;AAC3C;AACA,UAAU;AACV;AACA;AACA;AACA;;AAEA;AACA;;;;;;;;;;;;AC9Ra;;AAEb,cAAc,mBAAO,CAAC,iFAAW;;AAEjC;AACA;;AAEA;AACA;AACA,oBAAoB,SAAS;AAC7B;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;;AAEA;AACA;;AAEA,4BAA4B,gBAAgB;AAC5C;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,oBAAoB,mBAAmB;AACvC;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,UAAU;AACV;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA,cAAc;AACd;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;;AAEA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA,iDAAiD,EAAE;AACnD;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;AACN;AACA;;AAEA;AACA,kDAAkD,EAAE;AACpD;AACA,SAAS;AACT;;AAEA;AACA,oBAAoB,mBAAmB;AACvC;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,mBAAmB,OAAO,UAAU,aAAa;AACjD;;AAEA,oBAAoB,kBAAkB;AACtC;AACA;;AAEA;AACA,wBAAwB,iBAAiB;AACzC;AACA;AACA;AACA,6BAA6B,qBAAqB;AAClD;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,wBAAwB,gBAAgB;AACxC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;AC3PA;;;;;;;;;;;;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEa;;AAEb,IAAI,IAAqC;AACzC;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sBAAsB,mBAAO,CAAC,oBAAO;;AAErC;;AAEA;AACA;AACA;AACA,iGAAiG,eAAe;AAChH;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,MAAM;;;AAGN;AACA;AACA,KAAK,GAAG;;AAER,kDAAkD;AAClD;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA,wCAAwC;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;;AAGA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD,KAAK;AACrD;;;AAGA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,kCAAkC;AAClC;AACA;;;AAGA;AACA;AACA,oCAAoC;AACpC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA,OAAO;;;AAGP;AACA,GAAG;AACH;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;;AAEA,4BAA4B;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;AC9Oa;;AAEb,IAAI,KAAqC,EAAE,EAE1C,CAAC;AACF,EAAE,wLAA8E;AAChF;;;;;;;;;;;;ACNA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;ACAA;;;;;;;;;;;;;;;;;;;;ACAA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AAChR;AACoE;AAC3H,gBAAgB,wFAAmC;AACnD;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA,yCAAyC,UAAU,oBAAoB;AACvE,GAAG,IAAI;AACP;AACA;AACA,qFAAqF,qDAAI;AACzF,sFAAsF,qDAAI;AAC1F;AACA,0BAA0B,kEAAa;AACvC;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mCAAmC,0EAAqB,kBAAkB,kEAAoC;;AAE9G;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,6CAA6C;AAC5F;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,+CAA+C,+CAA+C;AAC9F;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,6CAA6C,kBAAkB;AAC/D,mDAAmD,wBAAwB;AAC3E,wDAAwD,qCAAqC;AAC7F,gCAAgC,0EAAqB,KAAK,kEAAoC,mKAAmK,kEAAoC;AACrS,aAAa;AACb,WAAW;AACX,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,eAAe,0EAAqB,YAAY,kEAAoC,+BAA+B;AACnH,OAAO;AACP;AACA,6CAA6C,cAAc;AAC3D,mDAAmD;AACnD,SAAS;AACT;AACA;AACA;AACA;AACA,iEAAe,gBAAgB;;;;;;;;;;;;;;;;;;AC7F/B,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AAClO;AACrG,gBAAgB,wFAAmC;AACnD;AACA;AACA,CAAC;AACD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sFAAsF,qDAAI;AAC1F,EAAE,mEAAc;AAChB;AACA,iCAAiC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C,6CAA6C;AAC5F;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,+CAA+C,+CAA+C;AAC9F;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,6CAA6C,kBAAkB;AAC/D;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,cAAc;AAC3D;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iEAAe,gBAAgB;;;;;;;;;;;;;;;;;;AC7F/B,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/Q;AACzC;AACP;AACA;AACA;AACA;AACA;AACA,wCAAwC;AACxC,kBAAkB,oBAAoB;AACtC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;;AAEA;AACA;AACA;AACe;AACf,EAAE,KAAsC,GAAG,4DAAO,+XAA+X,CAAM;AACvb;AACA;;;;;;;;;;;;;;;;;;;AC9B2C;AACyC;AACpF,WAAW,uDAAS;;AAEpB;AACA;AACA;AAC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AACmB;AACvB;AACpC;AACC;AAC4F;AACxG;AACnC,gBAAgB,oFAAmC;AACnD;AACA,CAAC;AACD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oEAAoE;AACpE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qEAAqE,sDAAK;AAC1E;AACA;AACA;AACA,KAAK;AACL,qEAAqE,sDAAK;AAC1E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,KAAK;AACL,4EAA4E,sDAAK;AACjF,2DAA2D;AAC3D;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,6DAA6D;AAC7D;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+DAA+D,mDAAO;AACtE;AACA,IAAI,KAAsC,GAAG,wDAAO,kYAAkY,CAAM;AAC5b;AACA;AACA;AACA,IAAI,KAAsC,GAAG,wDAAO,2RAA2R,uBAAuB,wEAAuB;AAC7X;AACA,KAAK,MAAM,CAAM;AACjB;AACA;AACA;AACA;AACA;AACA,sBAAsB,mEAAK;AAC3B;AACA,KAAK;AACL;AACA;AACA;AACA,eAAe,6DAAa;AAC5B;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,KAAsC,GAAG,wDAAO,qFAAqF,CAAM;AACjJ;AACA;AACA,gCAAgC,iDAAI;AACpC;AACA,4DAA4D;AAC5D;AACA,gBAAgB,8FAAsB;AACtC;;AAEA;AACA;AACA;AACA,+DAA+D;AAC/D;AACA,gBAAgB,mGAAwB;AACxC;AACA,QAAQ,4FAAiB;AACzB,gBAAgB,mGAAwB;AACxC;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM,KAAsC,GAAG,wDAAO,gKAAgK,CAAM;AAC5N;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,gFAAgF,aAAa;AAC7F;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,iDAAI;AACzB,mBAAmB,iDAAI;AACvB,uBAAuB,iDAAI;AAC3B,yBAAyB,iDAAI;AAC7B,SAAS;AACT;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,0FAA0F,eAAe;AACzG;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA,GAAG;AACH;AACA;AACA,MAAM,KAAsC,GAAG,wDAAO,8JAA8J,CAAM;AAC1N;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,MAAM,KAAsC,GAAG,wDAAO,0HAA0H,CAAM;AACtL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,MAAM,KAAsC,GAAG,wDAAO,gIAAgI,CAAM;AAC5L;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,0CAA0C,iDAAmB;AAC7D;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,+BAA+B,iDAAI;AACnC;AACA;AACA;AACA;AACA;AACA,qCAAqC,iDAAmB;AACxD;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,4DAA4D;AAC5D;AACA;AACA;AACA;AACA,WAAW;AACX;AACA;AACA,uBAAuB,MAAM;AAC7B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA,8BAA8B,sDAAK,CAAC,iDAAI;AACxC;AACA;AACA;AACA;AACA;AACA,QAAQ,sDAAK;AACb;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,gBAAgB,WAAW;AAC3B;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,kGAAkG;AAClG;AACA;AACA;AACA;AACA,YAAY,qEAAmB;AAC/B;AACA;AACA;AACA,SAAS;AACT,QAAQ;AACR,QAAQ,qEAAmB;AAC3B;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,+CAA+C;AAC/C;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA,CAAC,CAAC,4CAAY;AACd,iEAAe,aAAa;;;;;;;;;;;;;;;;;;;;;ACnkB5B,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACnJ;AAClH;AACnD;AACf;AACA;AACA;AACA,aAAa,8DAAa;AAC1B,KAAK;AACL;AACA;AACA;AACA,sBAAsB,6DAAU,+BAA+B,uBAAuB;AACtF;AACA,SAAS;AACT,QAAQ;AACR,wFAAwF,2DAA2D;AACnJ;AACA,KAAK;AACL;AACA;AACA;AACA,sBAAsB,6DAAiB,+BAA+B,8BAA8B;AACpG;AACA,SAAS;AACT,QAAQ;AACR,mGAAmG,2DAA2D;AAC9J;AACA,KAAK;AACL;AACA;AACA;AACA,sBAAsB,6DAAQ,+BAA+B,qBAAqB;AAClF;AACA,SAAS;AACT,QAAQ;AACR,sFAAsF,2DAA2D;AACjJ;AACA,KAAK;AACL;AACA;AACA;AACA,sBAAsB,6DAAe,+BAA+B,4BAA4B;AAChG;AACA,SAAS;AACT,QAAQ;AACR,iGAAiG,2DAA2D;AAC5J;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,sBAAsB,6DAAS;AAC/B;AACA,SAAS;AACT,QAAQ;AACR,uFAAuF,4CAA4C,wCAAwC;AAC3K;AACA;AACA;AACA;;;;;;;;;;;;;;;ACnEO;AACP;AACA;;;;;;;;;;;;;;;;;ACFA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,kDAAkD,0CAA0C;AAC5F,4CAA4C,gBAAgB,kBAAkB,OAAO,2BAA2B,wDAAwD,gCAAgC,uDAAuD;AAC/P,8DAA8D,sEAAsE,8DAA8D,kDAAkD,iBAAiB,GAAG;AACxQ,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACnT;AACmC;AACvD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,mEAAkB;AACtB;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,+BAAE;AACpB;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,MAAM,mEAAkB;AACxB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,cAAc;AACd;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,MAAM,mEAAkB;AACxB;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,kBAAkB,+BAAE;AACpB;AACA;AACA,OAAO;AACP;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,mEAAkB;AACxB;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,mBAAmB;AACnB;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,aAAa,mEAAkB;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,GAAG;AACH;AACA,CAAC;AACc;AACf,oFAAoF;AACpF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA;AACA;AACA;AACA,aAAa,mEAAkB;AAC/B;AACA;AACA,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP,MAAM;AACN;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;;;AChRA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T;AACA,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACvU,sDAAsD,+BAA+B,8DAA8D,YAAY,oCAAoC,6DAA6D,YAAY,6BAA6B,OAAO,2BAA2B,0CAA0C,wEAAwE,+BAA+B;AAC5d,2DAA2D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,6BAA6B;AACnS;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACe;AACf;AACA;AACA;AACA;AACA,6CAA6C,YAAY,oBAAoB;AAC7E,OAAO,IAAI;AACX,KAAK;AACL;AACA;AACA;AACA,6CAA6C,YAAY,oBAAoB;AAC7E,OAAO,IAAI;AACX;AACA;AACA;;;;;;;;;;;;;;;ACjCA;AACO;AACP;AACA,qFAAqF;AACrF;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;ACVO;AACP;AACA;;;;;;;;;;;;;;;;;;ACFA,mCAAmC;AACnC,gCAAgC;AAChC,kCAAkC;AAClC,mCAAmC;AACnC,kCAAkC;AAClC,8BAA8B;AAC9B,kDAAkD,gBAAgB,gEAAgE,wDAAwD,6DAA6D,sDAAsD;AAC7S,uCAAuC,uDAAuD,uCAAuC,SAAS,uBAAuB;AACrK,yCAAyC,yGAAyG,kBAAkB,iDAAiD,MAAM,8CAA8C,+BAA+B,WAAW,YAAY,6EAA6E,YAAY,cAAc,qBAAqB,UAAU,MAAM,iFAAiF,UAAU,sBAAsB;AAC5jB,gCAAgC;AACa;AACP;AACE;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,GAAG;AACH,uBAAuB,qDAAI;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA,GAAG;AACH,EAAE,KAAsC,GAAG,mDAAO;AAClD;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,4BAA4B,0DAAU;AACtC;AACA,gGAAgG;AAChG,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,4BAA4B,0DAAU;AACtC,mDAAmD,WAAW;AAC9D,GAAG,uBAAuB,uQAAuQ,CAAM;AACvS;;;;;;;;;;;;;;;;AC/ImD;AAC5C;AACP;AACA,8EAA8E,gEAAa;AAC3F;AACA;;;;;;;;;;;;;;;;ACLwD;AACjD;AACP,wBAAwB,iFAA+B;AACvD,uBAAuB,kFAAgC;AACvD;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;;;ACPA;AACO;AACP;AACA;AACA;AACA,wEAAwE,aAAa;AACrF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACjCO;AACP;AACA;AACA;AACA;AACA;AACO;AACP,yEAAyE,aAAa;AACtF;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;AChBA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,0CAA0C;AAC1C,sBAAsB,sEAAsE,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,iCAAiC,kBAAkB;AAC1S,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AAC7R;AACS;AAC5C;AACP;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,SAAS,uDAAM;AACf;AACA;AACA,MAAM,gEAAa;AACnB;AACA,2CAA2C,UAAU,oBAAoB;AACzE,KAAK,IAAI;AACT;AACA;AACA;AACA;AACA,uCAAuC,YAAY;AACnD;AACA,GAAG;AACH;AACO;AACP;AACA;AACA;AACA;AACA,2BAA2B;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACO;AACP;AACA,yCAAyC,QAAQ;AACjD;AACA,KAAK;AACL,GAAG;AACH;;;;;;;;;;;;;;;;AC1DA;AACA;AACA;AACA;;AAEA;AACA;AACA,aAAa;AACb,YAAY;AACZ,YAAY;AACZ,cAAc;AACd,aAAa;AACb;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACO;AACP;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,QAAQ;AACR,OAAO;AACP,OAAO;AACP,SAAS;AACT,QAAQ;AACR;;AAEA;AACA,8CAA8C;AAC9C;;AAEA;AACA;AACA;AACA;AACO;AACP;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;;;ACtDA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA,kBAAkB,kBAAkB;AACpC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;AChBA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA,kBAAkB,kBAAkB;AACpC;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;AChBA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI;AACJ;AACA;AACA;AACA;;;;;;;;;;;;;;;;AChB4C;AAC5C;AACO;AACP;AACA;AACA;AACA;AACA,4BAA4B,yDAAQ;AACpC;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACXwD;AACjD;AACP,yBAAyB,kFAAgC;AACzD,sBAAsB,iFAA+B;AACrD;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,GAAG;AACH;AACA;;;;;;;;;;;;;;;ACxBO;AACP;AACA;;;;;;;;;;;;;;;ACFO;AACP;AACA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;;;ACLA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,sDAAsD,0BAA0B;AAChF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;AC1BO;AACP;AACA;;;;;;;;;;;;;;;ACFA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;AClCiC;AACjC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,WAAW,0CAAI;;AAEf;AACA;AACA;AACA;AACA,eAAe,0CAAI;AACnB,IAAI,IAAsC;AAC1C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,QAAQ,KAAsC,mBAAmB,CAAM;AACvE;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM,KAAsC,mBAAmB,CAAM;AACrE;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;AC7CA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T;AACA,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACvU,sDAAsD,+BAA+B,8DAA8D,YAAY,oCAAoC,6DAA6D,YAAY,6BAA6B,OAAO,2BAA2B,0CAA0C,wEAAwE,+BAA+B;AAC5d,2DAA2D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,6BAA6B;AACxP;AACV;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,kBAAkB,wDAAS;AAC3B;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,qDAAqD;AACrD,GAAG;AACH;AACA;AACA;AACA,kDAAkD;AAClD,GAAG;AACH;AACA;AACA;AACA,gEAAgE;AAChE,GAAG;AACH;AACA;AACA;AACA,sDAAsD;AACtD,GAAG;AACH;AACA;AACA;AACA,iEAAiE;AACjE,GAAG;AACH;AACA;AACA,qBAAqB,8CAAI;AACzB;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACO;AACP,4EAA4E,aAAa;AACzF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;;;AC9GO;;;;;;;;;;;;;;;;ACAA;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;;;;;;;;;;;;;;;ACrCO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACRA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AAC9P;AAClE;AACP;AACA;AACA,GAAG;AACH;AACA,2CAA2C,WAAW;AACtD;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA,yCAAyC,WAAW;AACpD,sBAAsB,sFAAwB;AAC9C,KAAK;AACL,GAAG;AACH;;;;;;;;;;;;;;;ACtBA;;AAEA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;;;;ACrBO;AACP;AACA;AACO;AACP;AACA;;;;;;;;;;;;;;;;;ACL2D;AACR;AAC5C;AACP;AACA,MAAM,IAAsC;AAC5C,IAAI,wEAAiB;AACrB;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,GAAG;AACH,kCAAkC,4DAAa;AAC/C;AACA,GAAG;AACH;;;;;;;;;;;;;;;AChBA;AACA;AACA;AACA;AACO;;;;;;;;;;;;;;;ACJA;AACP;AACA;AACA,GAAG;AACH;;;;;;;;;;;;;;;ACJA,iEAAe,QAAQ;;;;;;;;;;;;;;;;;;;;;ACAvB,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACvU,kCAAkC;AAClC,8BAA8B;AAC9B,yCAAyC,yGAAyG,kBAAkB,iDAAiD,MAAM,8CAA8C,+BAA+B,WAAW,YAAY,6EAA6E,YAAY,cAAc,qBAAqB,UAAU,MAAM,iFAAiF,UAAU,sBAAsB;AAC5jB,gCAAgC;AAChC,mCAAmC;AACnC,gCAAgC;AAChC,kDAAkD,gBAAgB,gEAAgE,wDAAwD,6DAA6D,sDAAsD;AAC7S,kCAAkC;AAClC,mCAAmC;AACnC,uCAAuC,uDAAuD,uCAAuC,SAAS,uBAAuB;AACzF;AACuB;AACnG;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,IAAI,uEAAkB;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gFAAgF,aAAa;AAC7F;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,kDAAkD,qDAAI;AACtD;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,KAAK;AACL;AACA,6BAA6B,sEAAiB;AAC9C;AACA;AACA;;AAEA;AACA,IAAI,KAAsC,GAAG,4DAAO,gHAAgH,CAAM;AAC1K;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,yDAAI;AACtB;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;;AAEL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uFAAuF,mBAAmB;AAC1G;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yFAAyF,mBAAmB;AAC5G;AACA,WAAW;AACX;AACA;AACA;AACA;AACA,iCAAiC,wFAAqC;AACtE;AACA,gCAAgC,KAAK;AACrC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,KAAsC,GAAG,4DAAO,0PAA0P,CAAM;AAC5T,YAAY;AACZ,YAAY,KAAsC,GAAG,4DAAO,+FAA+F,CAAM;AACjK;AACA;AACA,OAAO;AACP;AACA;AACA,oDAAoD,qDAAI;AACxD;AACA,yFAAyF;AACzF;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;;;;;;;;;;;;;;;;;AChP2E;AAC3E;AACA,oBAAoB,mEAAc;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,GAAG;AACH;AACO;AACP,SAAS,uEAAkB;AAC3B;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP,oFAAoF;AACpF;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,gDAAgD;AAChD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb,WAAW;AACX;AACA;AACA,SAAS;AACT,OAAO;AACP,oCAAoC;AACpC;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;ACrFA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACjR;AACU;AAChB;AACzC;AACP;AACA;AACA,wCAAwC,mEAAa;AACrD;AACA,oDAAoD,wEAAkB;AACtE;AACA;AACA;AACA;AACA;AACA;AACA,6CAA6C,UAAU,oBAAoB;AAC3E,OAAO,qDAAqD;AAC5D;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,2BAA2B,kHAAkH;AAC7I;AACA;AACA;AACA;AACA,6CAA6C,4DAAO;AACpD;AACA;AACA;AACA,OAAO;AACP;AACA,8EAA8E;AAC9E;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;;;;;AC1DA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T;AACA,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACvU,mCAAmC;AACnC,gCAAgC;AAChC,kDAAkD,gBAAgB,gEAAgE,wDAAwD,6DAA6D,sDAAsD;AAC7S,kCAAkC;AAClC,mCAAmC;AACnC,uCAAuC,uDAAuD,uCAAuC,SAAS,uBAAuB;AACrK,sDAAsD,+BAA+B,8DAA8D,YAAY,oCAAoC,6DAA6D,YAAY,6BAA6B,OAAO,2BAA2B,0CAA0C,wEAAwE,+BAA+B;AAC5d,2DAA2D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,6BAA6B;AAC5O;AACqJ;AAC5M,gBAAgB,wFAAmC;AACnD;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,QAAQ,kEAAa;AACrB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,YAAY,kEAAa;AACzB,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,oCAAoC,8DAAa;AACjD;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,GAAG;AACH;AACA;AACA,oCAAoC,8DAAa;AACjD;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA,qEAAqE;AACrE;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,SAAS;;AAET;AACA;AACA;AACA;AACA;AACA,oHAAoH,EAAE,mEAAc;AACpI;AACA;AACA;AACA;AACA,aAAa;AACb;AACA,SAAS;AACT;AACA;AACA,wBAAwB,mEAAc;AACtC;AACA,SAAS;AACT;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,qCAAqC,kEAAoC;AACzE;AACA,SAAS;AACT,OAAO;;AAEP;AACA;AACA;AACA,eAAe,iDAAmB,GAAG;;AAErC;AACA;AACA;AACA;AACA;AACA;AACA,wEAAwE;AACxE;AACA;AACA;AACA,WAAW;;AAEX;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,4EAA2B,4BAA4B,4EAAuB;AAC7F,OAAO;AACP;AACA;AACA;AACA;AACA,0BAA0B,+DAAiC,KAAK,kEAAoC;AACpG;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,IAAsC;AAClD,UAAU,sEAAiB;AAC3B;AACA;AACA,WAAW;AACX;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA,8GAA8G,EAAE,mEAAc;AAC9H;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,OAAO;AACP;AACA,QAAQ,KAAsC,GAAG,4DAAO;AACxD;AACA;AACA,4OAA4O,CAAM;AAClP;AACA,sBAAsB,mEAAc;AACpC;AACA,OAAO;;AAEP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS,gBAAgB;;AAEzB;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8GAA8G,EAAE,qEAAgB;AAChI;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA,wBAAwB,qEAAgB;AACxC;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW;AACX;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,iCAAiC,8DAAa;AAC9C;AACA,OAAO,gCAAgC,cAAc,oBAAoB,yCAAyC;AAClH,KAAK;AACL;AACA,MAAM,KAAsC,GAAG,4DAAO,gLAAgL,CAAM;AAC5O;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA,6CAA6C,YAAY,oBAAoB;AAC7E,OAAO;AACP;AACA;AACA;AACA,iEAAe,KAAK,EAAC;AACrB;AACA;AACA;AACA;AACA;AACA,oEAAoE,wCAAwC,oBAAoB,iDAAiD;AACjL;;;;;;;;;;;;;;;;ACre6D;AACtD;AACP,EAAE,yEAAY;AACd;AACA,GAAG;AACH;AACA;;;;;;;;;;;;;;;;;;ACNA;AACA,sDAAsD,+BAA+B,8DAA8D,YAAY,oCAAoC,6DAA6D,YAAY,6BAA6B,OAAO,2BAA2B,0CAA0C,wEAAwE,+BAA+B;AAC5d,2DAA2D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,6BAA6B;AACzQ;AAC4B;AACR;AACvC;AACP;AACA;AACA,cAAc,0DAAQ;AACtB;AACA;AACA;AACA,sBAAsB,gDAAmB,CAAC,uEAAqB;AAC/D;AACA,GAAG;AACH;;;;;;;;;;;;;;;;;;;AChBA;AACA,sDAAsD,+BAA+B,8DAA8D,YAAY,oCAAoC,6DAA6D,YAAY,6BAA6B,OAAO,2BAA2B,0CAA0C,wEAAwE,+BAA+B;AAC5d,2DAA2D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,6BAA6B;AACzQ;AAC4B;AACgB;AACF;AAC7D;AACP;AACA;AACA,eAAe,gFAAmB;AAClC;AACA;AACA;AACA,sBAAsB,gDAAmB,CAAC,uFAA6B;AACvE;AACA,GAAG,eAAe,gDAAmB,CAAC,uEAAqB;AAC3D;AACA,GAAG;AACH;;;;;;;;;;;;;;;;ACnBsC;AAC/B,8CAA8C,oDAAa;AAClE,IAAI,IAAsC;AAC1C;AACA;;;;;;;;;;;;;;;;;ACJ4F;AACpC;AACjD;AACP,SAAS,oEAAY,CAAC,oGAAgB;AACtC;AACA,GAAG;AACH;;;;;;;;;;;;;;;;;ACN6F;AACrC;AACjD;AACP,SAAS,oEAAY,CAAC,qGAAgB;AACtC;;;;;;;;;;;;;;;;;;;;;;;ACJA,wBAAwB,2BAA2B,sGAAsG,qBAAqB,mBAAmB,8HAA8H;AAC/T;AACA;AACA,kCAAkC;AAClC,8BAA8B;AAC9B,kDAAkD,gBAAgB,gEAAgE,wDAAwD,6DAA6D,sDAAsD;AAC7S,uCAAuC,uDAAuD,uCAAuC,SAAS,uBAAuB;AACrK,yCAAyC,yGAAyG,kBAAkB,iDAAiD,MAAM,8CAA8C,+BAA+B,WAAW,YAAY,6EAA6E,YAAY,cAAc,qBAAqB,UAAU,MAAM,iFAAiF,UAAU,sBAAsB;AAC5jB,gCAAgC;AAChC,2CAA2C,gCAAgC,oCAAoC,oDAAoD,6DAA6D,iEAAiE,sCAAsC;AACvU,iCAAiC,gBAAgB,sBAAsB,OAAO,uDAAuD,6DAA6D,4CAA4C,oKAAoK,mFAAmF,KAAK;AAC1e,4CAA4C,2BAA2B,kBAAkB,kCAAkC,oEAAoE,KAAK,OAAO,oBAAoB;AAC/N,+BAA+B,uCAAuC;AACtE,qCAAqC,iEAAiE,sCAAsC,0BAA0B,+CAA+C,2CAA2C,uEAAuE;AACvU,sDAAsD,+BAA+B,8DAA8D,YAAY,oCAAoC,6DAA6D,YAAY,6BAA6B,OAAO,2BAA2B,0CAA0C,wEAAwE,+BAA+B;AAC5d,2DAA2D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,6BAA6B;AACjP;AACR;AAC8B;AACZ;AACgB;AACY;AAC9B;AACV;AACzC;AACP;AACA;AACA,sBAAsB,oGAA6B;AACnD,eAAe,wFAAuB;AACtC,oBAAoB,wEAAe;AACnC,oBAAoB,sEAAc;AAClC,yCAAyC,sEAAc;AACvD,0BAA0B,6CAAM;AAChC,+BAA+B,6CAAM;AACrC,eAAe,8CAAO;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,aAAa,sDAAM;AACnB;AACA,SAAS;AACT;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,KAAK;AACL,yCAAyC;AACzC,GAAG;AACH,kBAAkB,+CAAQ;AAC1B;AACA;AACA;AACA;AACA,qDAAqD;AACrD;AACA;AACA,SAAS;AACT,oCAAoC,oFAAqB;AACzD;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,aAAa;AACb;AACA;AACA,WAAW;AACX;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA,EAAE,4DAAS;AACX;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;;;;;;;;;;;;;;;;;;;AC/HoC;AACwC;AACI;AAClB;AACJ;AACnD;AACP,mFAAmF;AACnF;AACA,eAAe,wFAAuB;AACtC,wBAAwB,sEAAc;AACtC;AACA;AACA;AACA;AACA,0BAA0B,0EAAgB;AAC1C;AACA;AACA,YAAY,kDAAW;AACvB,+EAA+E,aAAa;AAC5F;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH,gBAAgB,kDAAW;AAC3B;AACA,GAAG;AACH,EAAE,4FAAyB;AAC3B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACnDsC;AAC/B,gCAAgC,oDAAa;AACpD,IAAI,IAAsC;AAC1C;AACA;;;;;;;;;;;;;;;;ACJsC;AAC/B,wCAAwC,oDAAa;AAC5D,IAAI,IAAsC;AAC1C;AACA;;;;;;;;;;;;;;;;ACJsC;AAC/B,2CAA2C,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S;AACX;AACA,GAAG;AACH,sBAAsB,6CAAM;AAC5B,EAAE,gDAAS;AACX;AACA,GAAG;AACH,wBAAwB,6CAAM;AAC9B;AACA,eAAe,oFAAuB;;AAEtC;AACA;AACA;AACA;AACA,EAAE,wFAAyB;AAC3B;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,kDAAM;;AAEhC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT,OAAO;AACP;AACA,GAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;;;;;;ACvEA;;AAEO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACO;AACP,MAAM,KAAyC,EAAE,EAE9C;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,MAAM;AACN;AACA;;;;;;;;;;;;;;;AChCA,iEAAe,QAAQ;;;;;;UCAvB;UACA;;UAEA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;UACA;;UAEA;UACA;;UAEA;UACA;UACA;;;;;WCtBA;WACA;WACA;WACA;WACA;WACA,iCAAiC,WAAW;WAC5C;WACA;;;;;WCPA;WACA;WACA;WACA;WACA,yCAAyC,wCAAwC;WACjF;WACA;WACA;;;;;WCPA;;;;;WCAA;WACA;WACA;WACA,uDAAuD,iBAAiB;WACxE;WACA,gDAAgD,aAAa;WAC7D;;;;;UENA;UACA;UACA;UACA","sources":["webpack://@newfold-labs/wp-module-help-center/./node_modules/@algolia/events/events.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/HiiveEvent.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/events/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/hiive/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/actions.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/constants.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/reducer.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/js-utility-ui-analytics/src/store/selectors.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/wp-module-ai/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/wp-module-ai/lib/core/AISearch.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/@newfold-labs/wp-module-ai/lib/moduleAI.js","webpack://@newfold-labs/wp-module-help-center/./src/icons/close.svg","webpack://@newfold-labs/wp-module-help-center/./src/icons/go.svg","webpack://@newfold-labs/wp-module-help-center/./src/icons/help.svg","webpack://@newfold-labs/wp-module-help-center/./src/icons/loader.svg","webpack://@newfold-labs/wp-module-help-center/./src/icons/no-result.svg","webpack://@newfold-labs/wp-module-help-center/./src/icons/search.svg","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/DerivedHelper/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/SearchParameters/RefinementList.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/SearchParameters/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/SearchResults/generate-hierarchical-tree.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/SearchResults/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/algoliasearch.helper.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/compact.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/defaultsPure.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/escapeFacetValue.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/find.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/findIndex.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/formatSort.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/inherits.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/intersection.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/merge.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/objectHasKeys.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/omit.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/orderBy.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/functions/valToNumber.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/requestBuilder.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/utils/isValidUserToken.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch-helper/src/version.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/algoliasearch/dist/algoliasearch.umd.js","webpack://@newfold-labs/wp-module-help-center/./src/components/AlgoliaResult.js","webpack://@newfold-labs/wp-module-help-center/./src/components/Feedback.js","webpack://@newfold-labs/wp-module-help-center/./src/components/HelpCenter.js","webpack://@newfold-labs/wp-module-help-center/./src/components/Loader.js","webpack://@newfold-labs/wp-module-help-center/./src/components/Modal.js","webpack://@newfold-labs/wp-module-help-center/./src/components/NoResults.js","webpack://@newfold-labs/wp-module-help-center/./src/components/ResultContent.js","webpack://@newfold-labs/wp-module-help-center/./src/components/SearchResults.js","webpack://@newfold-labs/wp-module-help-center/./src/index.js","webpack://@newfold-labs/wp-module-help-center/./src/utils.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/node_modules/qs/lib/formats.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/node_modules/qs/lib/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/node_modules/qs/lib/parse.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/node_modules/qs/lib/stringify.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/node_modules/qs/lib/utils.js","webpack://@newfold-labs/wp-module-help-center/./styles.scss","webpack://@newfold-labs/wp-module-help-center/./node_modules/use-sync-external-store/cjs/use-sync-external-store-shim.development.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/use-sync-external-store/shim/index.js","webpack://@newfold-labs/wp-module-help-center/external window \"React\"","webpack://@newfold-labs/wp-module-help-center/external window \"lodash\"","webpack://@newfold-labs/wp-module-help-center/external window [\"wp\",\"apiFetch\"]","webpack://@newfold-labs/wp-module-help-center/external window [\"wp\",\"data\"]","webpack://@newfold-labs/wp-module-help-center/external window [\"wp\",\"editPost\"]","webpack://@newfold-labs/wp-module-help-center/external window [\"wp\",\"element\"]","webpack://@newfold-labs/wp-module-help-center/external window [\"wp\",\"i18n\"]","webpack://@newfold-labs/wp-module-help-center/external window [\"wp\",\"plugins\"]","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/connectors/configure/connectConfigure.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/connectors/search-box/connectSearchBox.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/helpers/get-insights-anonymous-user-token.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/helpers/highlight.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/helpers/insights.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/helpers/reverseHighlight.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/helpers/reverseSnippet.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/helpers/snippet.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/InstantSearch.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/createHelpers.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/formatNumber.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/routers/history.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/stateMappings/simple.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/suit.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/capitalize.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/checkIndexUiState.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/checkRendering.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/concatHighlightedParts.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/defer.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/documentation.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/escape-highlight.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/escape-html.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/find.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/findIndex.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/getAppIdAndApiKey.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/getHighlightFromSiblings.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/getHighlightedParts.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/getObjectType.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/getPropertyByPath.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/isEqual.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/isIndexWidget.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/isPlainObject.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/logger.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/mergeSearchParameters.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/noop.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/render-args.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/resolveSearchParameters.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/reverseHighlightedParts.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/safelyRunOnBrowser.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/serializer.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/setIndexHelperState.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/typedObject.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/utils/uniq.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/lib/version.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/middlewares/createInsightsMiddleware.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/middlewares/createMetadataMiddleware.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/middlewares/createRouterMiddleware.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/instantsearch.js/es/widgets/index/index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/components/Configure.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/components/Index.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearch.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/components/InstantSearchServerContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/connectors/useConfigure.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/connectors/useSearchBox.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/hooks/useConnector.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/hooks/useInstantSearch.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/IndexContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/InstantSearchSSRContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/createSearchResults.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/dequal.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/getIndexSearchResults.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/invariant.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useForceUpdate.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useIndex.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useIndexContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchApi.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchSSRContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useInstantSearchServerContext.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useIsomorphicLayoutEffect.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchResults.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useSearchState.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useStableValue.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/useWidget.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/lib/warn.js","webpack://@newfold-labs/wp-module-help-center/./node_modules/react-instantsearch-hooks/dist/es/version.js","webpack://@newfold-labs/wp-module-help-center/webpack/bootstrap","webpack://@newfold-labs/wp-module-help-center/webpack/runtime/compat get default export","webpack://@newfold-labs/wp-module-help-center/webpack/runtime/define property getters","webpack://@newfold-labs/wp-module-help-center/webpack/runtime/hasOwnProperty shorthand","webpack://@newfold-labs/wp-module-help-center/webpack/runtime/make namespace object","webpack://@newfold-labs/wp-module-help-center/webpack/before-startup","webpack://@newfold-labs/wp-module-help-center/webpack/startup","webpack://@newfold-labs/wp-module-help-center/webpack/after-startup"],"sourcesContent":["// 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\nfunction EventEmitter() {\n this._events = this._events || {};\n this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\n// EventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\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.\nEventEmitter.defaultMaxListeners = 10;\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(n) {\n if (!isNumber(n) || n < 0 || isNaN(n))\n throw TypeError('n must be a positive number');\n this._maxListeners = n;\n return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n var er, handler, len, args, i, listeners;\n\n if (!this._events)\n this._events = {};\n\n // If there is no 'error' event listener then throw.\n if (type === 'error') {\n if (!this._events.error ||\n (isObject(this._events.error) && !this._events.error.length)) {\n er = arguments[1];\n if (er instanceof Error) {\n throw er; // Unhandled 'error' event\n } else {\n // At least give some kind of context to the user\n var err = new Error('Uncaught, unspecified \"error\" event. (' + er + ')');\n err.context = er;\n throw err;\n }\n }\n }\n\n handler = this._events[type];\n\n if (isUndefined(handler))\n return false;\n\n if (isFunction(handler)) {\n switch (arguments.length) {\n // fast cases\n case 1:\n handler.call(this);\n break;\n case 2:\n handler.call(this, arguments[1]);\n break;\n case 3:\n handler.call(this, arguments[1], arguments[2]);\n break;\n // slower\n default:\n args = Array.prototype.slice.call(arguments, 1);\n handler.apply(this, args);\n }\n } else if (isObject(handler)) {\n args = Array.prototype.slice.call(arguments, 1);\n listeners = handler.slice();\n len = listeners.length;\n for (i = 0; i < len; i++)\n listeners[i].apply(this, args);\n }\n\n return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n var m;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events)\n this._events = {};\n\n // To avoid recursion in the case that type === \"newListener\"! Before\n // adding it to the listeners, first emit \"newListener\".\n if (this._events.newListener)\n this.emit('newListener', type,\n isFunction(listener.listener) ?\n listener.listener : listener);\n\n if (!this._events[type])\n // Optimize the case of one listener. Don't need the extra array object.\n this._events[type] = listener;\n else if (isObject(this._events[type]))\n // If we've already got an array, just append.\n this._events[type].push(listener);\n else\n // Adding the second element, need to change to array.\n this._events[type] = [this._events[type], listener];\n\n // Check for listener leak\n if (isObject(this._events[type]) && !this._events[type].warned) {\n if (!isUndefined(this._maxListeners)) {\n m = this._maxListeners;\n } else {\n m = EventEmitter.defaultMaxListeners;\n }\n\n if (m && m > 0 && this._events[type].length > m) {\n this._events[type].warned = true;\n console.error('(node) warning: possible EventEmitter memory ' +\n 'leak detected. %d listeners added. ' +\n 'Use emitter.setMaxListeners() to increase limit.',\n this._events[type].length);\n if (typeof console.trace === 'function') {\n // not supported in IE 10\n console.trace();\n }\n }\n }\n\n return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n var fired = false;\n\n function g() {\n this.removeListener(type, g);\n\n if (!fired) {\n fired = true;\n listener.apply(this, arguments);\n }\n }\n\n g.listener = listener;\n this.on(type, g);\n\n return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n var list, position, length, i;\n\n if (!isFunction(listener))\n throw TypeError('listener must be a function');\n\n if (!this._events || !this._events[type])\n return this;\n\n list = this._events[type];\n length = list.length;\n position = -1;\n\n if (list === listener ||\n (isFunction(list.listener) && list.listener === listener)) {\n delete this._events[type];\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n\n } else if (isObject(list)) {\n for (i = length; i-- > 0;) {\n if (list[i] === listener ||\n (list[i].listener && list[i].listener === listener)) {\n position = i;\n break;\n }\n }\n\n if (position < 0)\n return this;\n\n if (list.length === 1) {\n list.length = 0;\n delete this._events[type];\n } else {\n list.splice(position, 1);\n }\n\n if (this._events.removeListener)\n this.emit('removeListener', type, listener);\n }\n\n return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n var key, listeners;\n\n if (!this._events)\n return this;\n\n // not listening for removeListener, no need to emit\n if (!this._events.removeListener) {\n if (arguments.length === 0)\n this._events = {};\n else if (this._events[type])\n delete this._events[type];\n return this;\n }\n\n // emit removeListener for all listeners on all events\n if (arguments.length === 0) {\n for (key in this._events) {\n if (key === 'removeListener') continue;\n this.removeAllListeners(key);\n }\n this.removeAllListeners('removeListener');\n this._events = {};\n return this;\n }\n\n listeners = this._events[type];\n\n if (isFunction(listeners)) {\n this.removeListener(type, listeners);\n } else if (listeners) {\n // LIFO order\n while (listeners.length)\n this.removeListener(type, listeners[listeners.length - 1]);\n }\n delete this._events[type];\n\n return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n var ret;\n if (!this._events || !this._events[type])\n ret = [];\n else if (isFunction(this._events[type]))\n ret = [this._events[type]];\n else\n ret = this._events[type].slice();\n return ret;\n};\n\nEventEmitter.prototype.listenerCount = function(type) {\n if (this._events) {\n var evlistener = this._events[type];\n\n if (isFunction(evlistener))\n return 1;\n else if (evlistener)\n return evlistener.length;\n }\n return 0;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n return emitter.listenerCount(type);\n};\n\nfunction isFunction(arg) {\n return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n return arg === void 0;\n}\n","/**\n * Defines the structure of a Hiive analytics event.\n *\n * @class HiiveEvent\n */\nexport class HiiveEvent {\n\t/**\n\t * Constructor for the HiiveEvent class.\n\t *\n\t * @param {string} category The category of the event (This actual value will depend on the URL you are reporting to).\n\t * @param {string} action The action that triggered the event (The actual value will depend on the URL you are reporting to).\n\t * @param {Object} data Data related to the event.\n\t */\n\tconstructor( category, action, data ) {\n\t\tthis.category = category;\n\t\tthis.action = action;\n\t\tthis.data = data;\n\t}\n}\n","// Exports related to Hiive events.\nexport * from './HiiveEvent';\n","import { dispatch, select } from '@wordpress/data';\nimport { HiiveEvent } from './events';\nimport { store } from '../store';\nimport apiFetch from '@wordpress/api-fetch';\n\n/**\n * Determines whether Hiive analytics have been initialized or not.\n *\n * @return {boolean} whether Hiive analytics have been initialized or not.\n */\nconst initialized = () => {\n\tif ( true === window?.nfdUIAnalytics?.hiive ) {\n\t\treturn true;\n\t}\n\treturn false;\n};\n\n/**\n * Validates that the parameter is an instance of HiiveEvent.\n *\n * @param {Object} event Any valid JS Object.\n * @return {boolean} whether the param is a valid HiiveEvent instance or not.\n */\nconst validate = ( event ) => {\n\tif ( ! ( event instanceof HiiveEvent ) ) {\n\t\treturn false;\n\t}\n\n\treturn true;\n};\n\n/**\n * Initializes the module to send out Hiive analytics events.\n *\n * @param {Object} param0 Data to initialize Hiive analytics.\n * @param {Object} param0.settings Settings that define the behavior of HiiveAnalytics.\n * @param {Object} param0.settings.debounce Settings related to the debounce.\n * @param {number} param0.settings.debounce.time The interval that must pass once an event has been tracked after which a batch request gets placed automatically to the batch URL.\n * @param {Object} param0.settings.queue Settings related to the Hiive events queue.\n * @param {number} param0.settings.queue.threshold The limit that the number of events in the queue must cross after which a batch request gets placed automatically to the batch URL.\n * @param {Object} param0.urls Contains URL's to report analytics.\n * @param {string} param0.urls.single The URL that can handle a single event.\n * @param {string} param0.urls.batch The URL that can handle an array of events.\n * @return {boolean} Whether the module was initialized or not.\n */\nconst initialize = ( {\n\turls: { single, batch } = {},\n\tsettings: { debounce: { time } = {}, queue: { threshold = 100 } = {} } = {},\n} ) => {\n\t// If the module is already initialized then skip initialization.\n\tif ( initialized() ) {\n\t\treturn true;\n\t}\n\n\t// If no reporting URL's are defined then fail initialization.\n\tif ( ! ( single || batch ) ) {\n\t\treturn false;\n\t}\n\n\t// Update Redux store with all the required data.\n\tdispatch( store ).updateHiiveUrls( {\n\t\tsingle,\n\t\tbatch,\n\t} );\n\tdispatch( store ).updateHiiveDebounceTime( time );\n\tdispatch( store ).updateHiiveEventsQueueThreshold( threshold );\n\n\t// This helps us quickly determine whether Hiive analytics have been enabled.\n\twindow.nfdUIAnalytics = {\n\t\thiive: true,\n\t};\n\n\treturn true;\n};\n\n/**\n * Tracks the event by putting it in a queue.\n *\n * @param {HiiveEvent} event The event object to track.\n * @return {boolean} whether the event has been successfully queued for tracking or not.\n */\nconst track = ( event ) => {\n\t// Do not perform any activity if the module has not been initialized or the event is not valid.\n\tif ( ! ( initialized() && validate( event ) ) ) {\n\t\treturn false;\n\t}\n\n\t// Add the event to a queue of tracked events.\n\tconst events = select( store ).getHiiveEventsQueue();\n\tevents.push( event );\n\tdispatch( store ).updateHiiveEventsQueue( events );\n\n\t// If the number of events in the queue have crossed the threshold then dispatch all of them.\n\tconst threshold = select( store ).getHiiveEventsQueueThreshold();\n\tif ( threshold && threshold < events.length ) {\n\t\tdispatchEvents();\n\t}\n\n\t// Reset the debounce setTimeout instance.\n\tresetDebounceInstance();\n\n\treturn true;\n};\n\n/**\n * Reports the event to urls.single defined during initialization.\n *\n * @param {HiiveEvent} event The event object to send.\n * @return {Promise} whether the event has been successfully sent or not.\n */\nconst send = async ( event ) => {\n\t// Do not perform any activity if the module has not been initialized or the event is not valid.\n\tif ( ! ( initialized() && validate( event ) ) ) {\n\t\treturn false;\n\t}\n\n\tconst url = select( store ).getHiiveSingleUrl();\n\tif ( ! url ) {\n\t\treturn false;\n\t}\n\n\ttry {\n\t\tawait apiFetch( {\n\t\t\turl,\n\t\t\tmethod: 'POST',\n\t\t\tdata: event,\n\t\t} );\n\t} catch ( error ) {\n\t\tconsole.error( error );\n\t\treturn false;\n\t}\n};\n\n/**\n * Reports all the queued events to urls.batch defined during initialization.\n *\n * @return {Promise} whether or not all the events were sent to the batchUrl successfully.\n */\nconst dispatchEvents = async () => {\n\tif ( ! initialized() ) {\n\t\treturn false;\n\t}\n\n\tconst url = select( store ).getHiiveBatchUrl();\n\tif ( ! url ) {\n\t\treturn false;\n\t}\n\n\t// If there are no events to report then return.\n\tconst events = select( store ).getHiiveEventsQueue();\n\tif ( 0 === events.length ) {\n\t\treturn true;\n\t}\n\n\t// Rare case: Do this so that any other dispatchEvents calls do not dispatch redundant data.\n\tdispatch( store ).updateHiiveEventsQueue( [] );\n\n\ttry {\n\t\tawait apiFetch( {\n\t\t\turl,\n\t\t\tmethod: 'POST',\n\t\t\tdata: events,\n\t\t} );\n\t} catch ( error ) {\n\t\t// [TODO] Figure out a better error handling method and clear the queue.\n\t\tconsole.error( error );\n\t\tdispatch( store ).updateHiiveEventsQueue( events );\n\t}\n\n\treturn true;\n};\n\n/**\n * Resets the debounce instance countdown.\n *\n * @return {boolean} whether the reset occurred successfully or not.\n */\nconst resetDebounceInstance = () => {\n\tconst debounce = select( store ).getHiiveDebounce();\n\n\tif ( ! debounce.time ) {\n\t\treturn false;\n\t}\n\n\tclearInterval( debounce.instance );\n\tdispatch( store ).updateHiiveDebounceInstance(\n\t\tsetTimeout( () => {\n\t\t\tdispatchEvents();\n\t\t\tdispatch( store ).updateHiiveDebounceInstance( undefined );\n\t\t}, debounce.time )\n\t);\n\treturn true;\n};\n\n/**\n * Disables the debounce.\n *\n * @return {boolean} whether the debounce has been successfully disabled or not.\n */\nconst disableDebounce = () => {\n\tconst debounce = select( store ).getHiiveDebounce();\n\tif ( debounce.instance ) {\n\t\tclearInterval( debounce.instance );\n\t\tdispatch( store ).updateHiiveDebounceInstance( undefined );\n\t\tdispatch( store ).updateHiiveDebounceTime( undefined );\n\t}\n\treturn true;\n};\n\nexport const HiiveAnalytics = {\n\tinitialize,\n\tinitialized,\n\tvalidate,\n\ttrack,\n\tsend,\n\tdispatchEvents,\n\tdisableDebounce,\n};\nexport { HiiveEvent };\n","// Exports for the Hiive Platform.\nexport * from './hiive';\n","/**\n * Update the Hiive URLs.\n *\n * @param {Object} urls The Hiive URLs.\n * @return {Object} Type of action to perform with data.\n */\nexport function updateHiiveUrls( urls ) {\n\treturn {\n\t\ttype: 'UPDATE_HIIVE_URLS',\n\t\turls,\n\t};\n}\n\n/**\n * Update the Hiive events queue.\n *\n * @param {Array} events An array of events to be queued.\n * @return {Object} Type of action to perform with data.\n */\nexport function updateHiiveEventsQueue( events ) {\n\treturn {\n\t\ttype: 'UPDATE_HIIVE_EVENTS_QUEUE',\n\t\tevents,\n\t};\n}\n\n/**\n *\n * @param {number} threshold The threshold for the queue.\n * @return {Object} Type of action to perform with data.\n */\nexport function updateHiiveEventsQueueThreshold( threshold ) {\n\treturn {\n\t\ttype: 'UPDATE_HIIVE_EVENTS_QUEUE_THRESHOLD',\n\t\tthreshold,\n\t};\n}\n\n/**\n * Update the Hiive events dispatch debounce time.\n *\n * @param {number} debounceTime The time to wait.\n * @return {Object} Type of action to perform with data.\n */\nexport function updateHiiveDebounceTime( debounceTime ) {\n\treturn {\n\t\ttype: 'UPDATE_HIIVE_DEBOUNCE_TIME',\n\t\tdebounceTime,\n\t};\n}\n\n/**\n * Updates the Hiive debounce instance.\n *\n * @param {Object} instance A setTimeout instance of the debounce.\n * @return {Object} Type of action to perform with data.\n */\nexport function updateHiiveDebounceInstance( instance ) {\n\treturn {\n\t\ttype: 'UPDATE_HIIVE_DEBOUNCE_INSTANCE',\n\t\tinstance,\n\t};\n}\n","/**\n * The name for the Redux store of this package.\n */\nexport const STORE_NAME = 'newfold/ui-analytics';\n","import reducer from './reducer';\nimport * as actions from './actions';\nimport * as selectors from './selectors';\nimport { STORE_NAME } from './constants';\n\nimport { createReduxStore, register } from '@wordpress/data';\n\n/**\n * The Redux store configuration.\n */\nexport const nfdUIAnalyticsStoreConfig = {\n\treducer,\n\tactions,\n\tselectors,\n};\n\nexport const store = createReduxStore( STORE_NAME, nfdUIAnalyticsStoreConfig );\nregister( store );\n","import { combineReducers } from '@wordpress/data';\n\n/**\n * A reducer for Hiive related actions.\n *\n * @param {Object} state The current state of the store.\n * @param {Object} action The action to be performed to change the state.\n * @return {Object} state The new state of the store after the action is performed.\n */\nexport function hiive(\n\tstate = {\n\t\turls: {\n\t\t\tsingle: undefined,\n\t\t\tbatch: undefined,\n\t\t},\n\t\tqueue: {\n\t\t\tevents: [],\n\t\t\tthreshold: 100,\n\t\t},\n\t\tdebounce: {\n\t\t\ttime: undefined,\n\t\t\tinstance: undefined,\n\t\t},\n\t},\n\taction\n) {\n\tswitch ( action.type ) {\n\t\tcase 'UPDATE_HIIVE_URLS':\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\turls: {\n\t\t\t\t\tsingle: action.urls.single,\n\t\t\t\t\tbatch: action.urls.batch,\n\t\t\t\t},\n\t\t\t};\n\t\tcase 'UPDATE_HIIVE_EVENTS_QUEUE':\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tqueue: {\n\t\t\t\t\tevents: action.events,\n\t\t\t\t\tthreshold: state.queue.threshold,\n\t\t\t\t},\n\t\t\t};\n\t\tcase 'UPDATE_HIIVE_EVENTS_QUEUE_THRESHOLD': {\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tqueue: {\n\t\t\t\t\tevents: state.queue.events,\n\t\t\t\t\tthreshold: action.threshold,\n\t\t\t\t},\n\t\t\t};\n\t\t}\n\t\tcase 'UPDATE_HIIVE_DEBOUNCE_TIME':\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tdebounce: {\n\t\t\t\t\ttime: action.debounceTime,\n\t\t\t\t\tinstance: state.debounce.instance,\n\t\t\t\t},\n\t\t\t};\n\t\tcase 'UPDATE_HIIVE_DEBOUNCE_INSTANCE':\n\t\t\treturn {\n\t\t\t\t...state,\n\t\t\t\tdebounce: {\n\t\t\t\t\ttime: state.debounce.time,\n\t\t\t\t\tinstance: action.instance,\n\t\t\t\t},\n\t\t\t};\n\t}\n\treturn state;\n}\n\n/**\n * Combines all the reducers in this file.\n */\nexport default combineReducers( {\n\thiive,\n} );\n","/**\n * Retrieves all the queued Hiive events.\n *\n * @param {Object} state The current state of the redux store.\n * @return {Array} events An array of events that are queued.\n */\nexport function getHiiveEventsQueue( state ) {\n\treturn state.hiive.queue.events;\n}\n\n/**\n *\n * @param {*} state The current state of the redux store.\n * @return {Array} threshold Threshold of the queue.\n */\nexport function getHiiveEventsQueueThreshold( state ) {\n\treturn state.hiive.queue.threshold;\n}\n\n/**\n * Retrieves the default Hiive URL.\n *\n * @param {Object} state The current state of the redux store.\n * @return {string} The default URL in the store.\n */\nexport function getHiiveSingleUrl( state ) {\n\treturn state.hiive.urls.single;\n}\n\n/**\n * Retrieves the batch Hiive URL.\n *\n * @param {*} state The current state of the redux store.\n * @return {string} The batch URL in the store.\n */\nexport function getHiiveBatchUrl( state ) {\n\treturn state.hiive.urls.batch;\n}\n\n/**\n * Retrieves debounce data.\n *\n * @param {Object} state The current state of the redux store.\n * @return {Object} The debounce data.\n */\nexport function getHiiveDebounce( state ) {\n\treturn state.hiive.debounce;\n}\n","import moduleAI from \"./lib/moduleAI\";\n\nexport {\n moduleAI as default\n}\n","import apiFetch from \"@wordpress/api-fetch\";\n\nconst base = \"newfold-ai/v1\";\n\nconst AISearch = {\n getSearchResult: (userPrompt, identifier, extra) =>\n apiFetch({\n path: base + \"/search\",\n method: \"POST\",\n data: {\n user_prompt: userPrompt,\n identifier: identifier,\n extra: extra,\n },\n }),\n};\n\nexport default AISearch;\n","import AISearch from \"./core/AISearch\";\n\nconst moduleAI = {\n search: AISearch,\n}\n\nexport default moduleAI;\n","var _g, _defs;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nvar SvgClose = function SvgClose(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 24,\n height: 24,\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _g || (_g = /*#__PURE__*/React.createElement(\"g\", {\n clipPath: \"url(#close_svg__a)\"\n }, /*#__PURE__*/React.createElement(\"g\", {\n clipPath: \"url(#close_svg__b)\"\n }, /*#__PURE__*/React.createElement(\"path\", {\n fillRule: \"evenodd\",\n clipRule: \"evenodd\",\n d: \"m12 13.06 3.712 3.713 1.06-1.06L13.06 12l3.713-3.712-1.061-1.06-3.713 3.711-3.712-3.712-1.06 1.06L10.939 12l-3.712 3.712 1.06 1.061L12 13.061Z\",\n fill: \"#1E1E1E\"\n })))), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"clipPath\", {\n id: \"close_svg__a\"\n }, /*#__PURE__*/React.createElement(\"rect\", {\n width: 24,\n height: 24,\n rx: 2,\n fill: \"#fff\"\n })), /*#__PURE__*/React.createElement(\"clipPath\", {\n id: \"close_svg__b\"\n }, /*#__PURE__*/React.createElement(\"rect\", {\n width: 24,\n height: 24,\n rx: 2,\n fill: \"#fff\"\n })))));\n};\nexport { SvgClose as ReactComponent };\nexport default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPGcgY2xpcC1wYXRoPSJ1cmwoI2NsaXAwXzYwNF8zMDE3KSI+CjxnIGNsaXAtcGF0aD0idXJsKCNjbGlwMV82MDRfMzAxNykiPgo8cGF0aCBmaWxsLXJ1bGU9ImV2ZW5vZGQiIGNsaXAtcnVsZT0iZXZlbm9kZCIgZD0iTTExLjk5OTUgMTMuMDYwN0wxNS43MTE4IDE2Ljc3M0wxNi43NzI1IDE1LjcxMjNMMTMuMDYwMiAxMkwxNi43NzI1IDguMjg3NzJMMTUuNzExOSA3LjIyNzA2TDExLjk5OTUgMTAuOTM5NEw4LjI4NzIyIDcuMjI3MDVMNy4yMjY1NiA4LjI4NzcxTDEwLjkzODkgMTJMNy4yMjY1NyAxNS43MTIzTDguMjg3MjMgMTYuNzczTDExLjk5OTUgMTMuMDYwN1oiIGZpbGw9IiMxRTFFMUUiLz4KPC9nPgo8L2c+CjxkZWZzPgo8Y2xpcFBhdGggaWQ9ImNsaXAwXzYwNF8zMDE3Ij4KPHJlY3Qgd2lkdGg9IjI0IiBoZWlnaHQ9IjI0IiByeD0iMiIgZmlsbD0id2hpdGUiLz4KPC9jbGlwUGF0aD4KPGNsaXBQYXRoIGlkPSJjbGlwMV82MDRfMzAxNyI+CjxyZWN0IHdpZHRoPSIyNCIgaGVpZ2h0PSIyNCIgcng9IjIiIGZpbGw9IndoaXRlIi8+CjwvY2xpcFBhdGg+CjwvZGVmcz4KPC9zdmc+Cg==\";","function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nvar SvgGo = function SvgGo(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n height: 12,\n width: 12,\n xmlns: \"http://www.w3.org/2000/svg\",\n viewBox: \"-13.63 -13.63 254.36 254.36\",\n xmlSpace: \"preserve\",\n fill: \"#1D1D1F\",\n stroke: \"#394150\"\n }, props), /*#__PURE__*/React.createElement(\"path\", {\n style: {\n fill: \"#010002\"\n },\n d: \"m152.835 39.285-5.902 5.898 64.18 64.19H0v8.35h211.124l-64.191 64.179 5.902 5.909 74.261-74.261z\"\n }));\n};\nexport { SvgGo as ReactComponent };\nexport default \"data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjEycHgiIHdpZHRoPSIxMnB4IiB2ZXJzaW9uPSIxLjEiIGlkPSJDYXBhXzEiCiAgICB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciCiAgICB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgdmlld0JveD0iLTEzLjYzIC0xMy42MyAyNTQuMzYgMjU0LjM2IgogICAgeG1sOnNwYWNlPSJwcmVzZXJ2ZSIgZmlsbD0iIzFEMUQxRiIgc3Ryb2tlPSIjMzk0MTUwIj48ZyBpZD0iU1ZHUmVwb19iZ0NhcnJpZXIiIHN0cm9rZS13aWR0aD0iMCI+PC9nPjxnIGlkPSJTVkdSZXBvX3RyYWNlckNhcnJpZXIiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCI+PC9nPjxnIGlkPSJTVkdSZXBvX2ljb25DYXJyaWVyIj4gPGc+IDxnPiA8cG9seWdvbiBzdHlsZT0iZmlsbDojMDEwMDAyOyIgcG9pbnRzPSIxNTIuODM1LDM5LjI4NSAxNDYuOTMzLDQ1LjE4MyAyMTEuMTEzLDEwOS4zNzMgMCwxMDkuMzczIDAsMTE3LjcyMyAyMTEuMTI0LDExNy43MjMgMTQ2LjkzMywxODEuOTAyIDE1Mi44MzUsMTg3LjgxMSAyMjcuMDk2LDExMy41NSAiPjwvcG9seWdvbj4gPC9nPiA8L2c+IDwvZz48L3N2Zz4=\";","var _path;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nvar SvgHelp = function SvgHelp(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 36,\n height: 37,\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n fillRule: \"evenodd\",\n clipRule: \"evenodd\",\n d: \"M18 .902c-9.941 0-18 8.059-18 18s8.059 18 18 18h15.366A2.634 2.634 0 0 0 36 34.268V18.902c0-9.941-8.059-18-18-18Zm-.913 17.877c-.336.588-.504 1.286-.504 2.092v.832h3.326v-.404c0-.587.101-1.075.303-1.461.218-.387.613-.849 1.184-1.386.723-.689 1.269-1.344 1.638-1.966.37-.621.555-1.369.555-2.243 0-.89-.236-1.696-.706-2.419-.454-.739-1.092-1.319-1.915-1.739-.823-.42-1.764-.63-2.823-.63-1.41 0-2.587.395-3.528 1.185-.924.773-1.545 1.697-1.864 2.772l2.898 1.21a3.278 3.278 0 0 1 .907-1.462c.437-.403.991-.605 1.663-.605.638 0 1.15.185 1.537.555.387.352.58.79.58 1.31 0 .437-.118.823-.353 1.16-.218.335-.58.73-1.084 1.184-.856.756-1.461 1.428-1.814 2.015Zm-.428 8.644c.436.42.957.63 1.562.63.605 0 1.117-.21 1.537-.63.42-.437.63-.957.63-1.562 0-.605-.21-1.117-.63-1.538-.42-.42-.932-.63-1.537-.63-.605 0-1.126.21-1.562.63-.42.42-.63.933-.63 1.538 0 .604.21 1.125.63 1.562Z\",\n fill: \"#196BDE\"\n })));\n};\nexport { SvgHelp as ReactComponent };\nexport default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzYiIGhlaWdodD0iMzciIHZpZXdCb3g9IjAgMCAzNiAzNyIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxwYXRoIGZpbGwtcnVsZT0iZXZlbm9kZCIgY2xpcC1ydWxlPSJldmVub2RkIgogICAgICAgIGQ9Ik0xOCAwLjkwMTg1NUM4LjA1ODg4IDAuOTAxODU1IDAgOC45NjA3MyAwIDE4LjkwMTlDMCAyOC44NDMgOC4wNTg4OCAzNi45MDE5IDE4IDM2LjkwMTlIMzMuMzY1OUMzNC44MjA3IDM2LjkwMTkgMzYgMzUuNzIyNSAzNiAzNC4yNjc3VjE4LjkwMTlDMzYgOC45NjA3MyAyNy45NDExIDAuOTAxODU1IDE4IDAuOTAxODU1Wk0xNy4wODcgMTguNzc5NUMxNi43NTEgMTkuMzY3NSAxNi41ODMgMjAuMDY0NyAxNi41ODMgMjAuODcxMVYyMS43MDI3SDE5LjkwOTRWMjEuMjk5NUMxOS45MDk0IDIwLjcxMTUgMjAuMDEwMiAyMC4yMjQzIDIwLjIxMTggMTkuODM3OUMyMC40MzAyIDE5LjQ1MTUgMjAuODI1IDE4Ljk4OTUgMjEuMzk2MiAxOC40NTE5QzIyLjExODYgMTcuNzYzMSAyMi42NjQ2IDE3LjEwNzkgMjMuMDM0MiAxNi40ODYzQzIzLjQwMzggMTUuODY0NyAyMy41ODg2IDE1LjExNzEgMjMuNTg4NiAxNC4yNDM1QzIzLjU4ODYgMTMuMzUzMSAyMy4zNTM0IDEyLjU0NjcgMjIuODgzIDExLjgyNDNDMjIuNDI5NCAxMS4wODUxIDIxLjc5MSAxMC41MDU1IDIwLjk2NzggMTAuMDg1NUMyMC4xNDQ2IDkuNjY1NDggMTkuMjAzOCA5LjQ1NTQ4IDE4LjE0NTQgOS40NTU0OEMxNi43MzQyIDkuNDU1NDggMTUuNTU4MiA5Ljg1MDI4IDE0LjYxNzQgMTAuNjM5OUMxMy42OTM0IDExLjQxMjcgMTMuMDcxOCAxMi4zMzY3IDEyLjc1MjYgMTMuNDExOUwxNS42NTA2IDE0LjYyMTVDMTUuODM1NCAxNC4wMzM1IDE2LjEzNzggMTMuNTQ2MyAxNi41NTc4IDEzLjE1OTlDMTYuOTk0NiAxMi43NTY3IDE3LjU0OSAxMi41NTUxIDE4LjIyMSAxMi41NTUxQzE4Ljg1OTQgMTIuNTU1MSAxOS4zNzE4IDEyLjczOTkgMTkuNzU4MiAxMy4xMDk1QzIwLjE0NDYgMTMuNDYyMyAyMC4zMzc4IDEzLjg5OTEgMjAuMzM3OCAxNC40MTk5QzIwLjMzNzggMTQuODU2NyAyMC4yMjAyIDE1LjI0MzEgMTkuOTg1IDE1LjU3OTFDMTkuNzY2NiAxNS45MTUxIDE5LjQwNTQgMTYuMzA5OSAxOC45MDE0IDE2Ljc2MzVDMTguMDQ0NiAxNy41MTk1IDE3LjQzOTggMTguMTkxNSAxNy4wODcgMTguNzc5NVpNMTYuNjU4NiAyNy40MjMxQzE3LjA5NTQgMjcuODQzMSAxNy42MTYyIDI4LjA1MzEgMTguMjIxIDI4LjA1MzFDMTguODI1OCAyOC4wNTMxIDE5LjMzODIgMjcuODQzMSAxOS43NTgyIDI3LjQyMzFDMjAuMTc4MiAyNi45ODYzIDIwLjM4ODIgMjYuNDY1NSAyMC4zODgyIDI1Ljg2MDdDMjAuMzg4MiAyNS4yNTU5IDIwLjE3ODIgMjQuNzQzNSAxOS43NTgyIDI0LjMyMzVDMTkuMzM4MiAyMy45MDM1IDE4LjgyNTggMjMuNjkzNSAxOC4yMjEgMjMuNjkzNUMxNy42MTYyIDIzLjY5MzUgMTcuMDk1NCAyMy45MDM1IDE2LjY1ODYgMjQuMzIzNUMxNi4yMzg2IDI0Ljc0MzUgMTYuMDI4NiAyNS4yNTU5IDE2LjAyODYgMjUuODYwN0MxNi4wMjg2IDI2LjQ2NTUgMTYuMjM4NiAyNi45ODYzIDE2LjY1ODYgMjcuNDIzMVoiCiAgICAgICAgZmlsbD0iIzE5NkJERSIgLz4KPC9zdmc+\";","var _rect, _rect2, _rect3, _rect4, _path, _defs;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nvar SvgLoader = function SvgLoader(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 248,\n height: 72,\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _rect || (_rect = /*#__PURE__*/React.createElement(\"rect\", {\n width: 89,\n height: 14,\n rx: 7,\n fill: \"url(#loader_svg__a)\"\n })), _rect2 || (_rect2 = /*#__PURE__*/React.createElement(\"rect\", {\n y: 22,\n width: 233,\n height: 10,\n rx: 5,\n fill: \"url(#loader_svg__b)\"\n })), _rect3 || (_rect3 = /*#__PURE__*/React.createElement(\"rect\", {\n y: 38,\n width: 248,\n height: 10,\n rx: 5,\n fill: \"url(#loader_svg__c)\"\n })), _rect4 || (_rect4 = /*#__PURE__*/React.createElement(\"rect\", {\n y: 54,\n width: 140,\n height: 10,\n rx: 5,\n fill: \"url(#loader_svg__d)\"\n })), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n stroke: \"#EEE\",\n d: \"M0 71.5h248\"\n })), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"linearGradient\", {\n id: \"loader_svg__a\",\n x1: 89,\n y1: 7,\n x2: 0,\n y2: 7,\n gradientUnits: \"userSpaceOnUse\"\n }, /*#__PURE__*/React.createElement(\"stop\", {\n stopColor: \"#D9D9D9\"\n }), /*#__PURE__*/React.createElement(\"stop\", {\n offset: 1,\n stopColor: \"#D9D9D9\",\n stopOpacity: 0.3\n })), /*#__PURE__*/React.createElement(\"linearGradient\", {\n id: \"loader_svg__b\",\n x1: 0,\n y1: 27,\n x2: 233,\n y2: 27,\n gradientUnits: \"userSpaceOnUse\"\n }, /*#__PURE__*/React.createElement(\"stop\", {\n stopColor: \"#D9D9D9\"\n }), /*#__PURE__*/React.createElement(\"stop\", {\n offset: 1,\n stopColor: \"#D9D9D9\",\n stopOpacity: 0.3\n })), /*#__PURE__*/React.createElement(\"linearGradient\", {\n id: \"loader_svg__c\",\n x1: 0,\n y1: 43,\n x2: 266.243,\n y2: 43,\n gradientUnits: \"userSpaceOnUse\"\n }, /*#__PURE__*/React.createElement(\"stop\", {\n stopColor: \"#D9D9D9\"\n }), /*#__PURE__*/React.createElement(\"stop\", {\n offset: 0.516,\n stopColor: \"#D9D9D9\",\n stopOpacity: 0.2\n }), /*#__PURE__*/React.createElement(\"stop\", {\n offset: 1,\n stopColor: \"#D9D9D9\",\n stopOpacity: 0.8\n })), /*#__PURE__*/React.createElement(\"linearGradient\", {\n id: \"loader_svg__d\",\n x1: 138.754,\n y1: 59,\n x2: 1.495,\n y2: 59,\n gradientUnits: \"userSpaceOnUse\"\n }, /*#__PURE__*/React.createElement(\"stop\", {\n stopColor: \"#D9D9D9\"\n }), /*#__PURE__*/React.createElement(\"stop\", {\n offset: 1,\n stopColor: \"#D9D9D9\",\n stopOpacity: 0.3\n })))));\n};\nexport { SvgLoader as ReactComponent };\nexport default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQ4IiBoZWlnaHQ9IjcyIiB2aWV3Qm94PSIwIDAgMjQ4IDcyIiBmaWxsPSJub25lIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgo8cmVjdCB3aWR0aD0iODkiIGhlaWdodD0iMTQiIHJ4PSI3IiBmaWxsPSJ1cmwoI3BhaW50MF9saW5lYXJfNjA0XzMwNDMpIi8+CjxyZWN0IHk9IjIyIiB3aWR0aD0iMjMzIiBoZWlnaHQ9IjEwIiByeD0iNSIgZmlsbD0idXJsKCNwYWludDFfbGluZWFyXzYwNF8zMDQzKSIvPgo8cmVjdCB5PSIzOCIgd2lkdGg9IjI0OCIgaGVpZ2h0PSIxMCIgcng9IjUiIGZpbGw9InVybCgjcGFpbnQyX2xpbmVhcl82MDRfMzA0MykiLz4KPHJlY3QgeT0iNTQiIHdpZHRoPSIxNDAiIGhlaWdodD0iMTAiIHJ4PSI1IiBmaWxsPSJ1cmwoI3BhaW50M19saW5lYXJfNjA0XzMwNDMpIi8+CjxsaW5lIHkxPSI3MS41IiB4Mj0iMjQ4IiB5Mj0iNzEuNSIgc3Ryb2tlPSIjRUVFRUVFIi8+CjxkZWZzPgo8bGluZWFyR3JhZGllbnQgaWQ9InBhaW50MF9saW5lYXJfNjA0XzMwNDMiIHgxPSI4OSIgeTE9IjcuMDAwMDEiIHgyPSIyLjQ2OTQ5ZS0wNyIgeTI9IjcuMDAwMDEiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agc3RvcC1jb2xvcj0iI0Q5RDlEOSIvPgo8c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiNEOUQ5RDkiIHN0b3Atb3BhY2l0eT0iMC4zIi8+CjwvbGluZWFyR3JhZGllbnQ+CjxsaW5lYXJHcmFkaWVudCBpZD0icGFpbnQxX2xpbmVhcl82MDRfMzA0MyIgeDE9IjEuNDM3NjJlLTA2IiB5MT0iMjYuOTk5OSIgeDI9IjIzMyIgeTI9IjI2Ljk5OTkiIGdyYWRpZW50VW5pdHM9InVzZXJTcGFjZU9uVXNlIj4KPHN0b3Agc3RvcC1jb2xvcj0iI0Q5RDlEOSIvPgo8c3RvcCBvZmZzZXQ9IjEiIHN0b3AtY29sb3I9IiNEOUQ5RDkiIHN0b3Atb3BhY2l0eT0iMC4zIi8+CjwvbGluZWFyR3JhZGllbnQ+CjxsaW5lYXJHcmFkaWVudCBpZD0icGFpbnQyX2xpbmVhcl82MDRfMzA0MyIgeDE9Ii0xLjU3NTU4ZS0wNiIgeTE9IjQyLjk5OTkiIHgyPSIyNjYuMjQzIiB5Mj0iNDIuOTk5OSIgZ3JhZGllbnRVbml0cz0idXNlclNwYWNlT25Vc2UiPgo8c3RvcCBzdG9wLWNvbG9yPSIjRDlEOUQ5Ii8+CjxzdG9wIG9mZnNldD0iMC41MTU2MjUiIHN0b3AtY29sb3I9IiNEOUQ5RDkiIHN0b3Atb3BhY2l0eT0iMC4yIi8+CjxzdG9wIG9mZnNldD0iMSIgc3RvcC1jb2xvcj0iI0Q5RDlEOSIgc3RvcC1vcGFjaXR5PSIwLjgiLz4KPC9saW5lYXJHcmFkaWVudD4KPGxpbmVhckdyYWRpZW50IGlkPSJwYWludDNfbGluZWFyXzYwNF8zMDQzIiB4MT0iMTM4Ljc1NCIgeTE9IjU5IiB4Mj0iMS40OTQ2NiIgeTI9IjU5IiBncmFkaWVudFVuaXRzPSJ1c2VyU3BhY2VPblVzZSI+CjxzdG9wIHN0b3AtY29sb3I9IiNEOUQ5RDkiLz4KPHN0b3Agb2Zmc2V0PSIxIiBzdG9wLWNvbG9yPSIjRDlEOUQ5IiBzdG9wLW9wYWNpdHk9IjAuMyIvPgo8L2xpbmVhckdyYWRpZW50Pgo8L2RlZnM+Cjwvc3ZnPg==\";","var _path, _defs;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nvar SvgNoResult = function SvgNoResult(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 302,\n height: 186,\n fill: \"none\",\n xmlns: \"http://www.w3.org/2000/svg\",\n xmlnsXlink: \"http://www.w3.org/1999/xlink\"\n }, props), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n fill: \"url(#no-result_svg__a)\",\n d: \"M0 0h302v186H0z\"\n })), _defs || (_defs = /*#__PURE__*/React.createElement(\"defs\", null, /*#__PURE__*/React.createElement(\"pattern\", {\n id: \"no-result_svg__a\",\n patternContentUnits: \"objectBoundingBox\",\n width: 1,\n height: 1\n }, /*#__PURE__*/React.createElement(\"use\", {\n xlinkHref: \"#no-result_svg__b\",\n transform: \"matrix(.0009 0 0 .00145 0 0)\"\n })), /*#__PURE__*/React.createElement(\"image\", {\n id: \"no-result_svg__b\",\n width: 1121,\n height: 690,\n xlinkHref: \"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAABGEAAAKyCAYAAAB16sOJAAAACXBIWXMAAAsTAAALEwEAmpwYAABFUGlUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNy4yLWMwMDAgNzkuMWI2NWE3OWI0LCAyMDIyLzA2LzEzLTIyOjAxOjAxICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczpkYz0iaHR0cDovL3B1cmwub3JnL2RjL2VsZW1lbnRzLzEuMS8iIHhtbG5zOnhtcD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wLyIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczpzdEV2dD0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlRXZlbnQjIiB4bWxuczppbGx1c3RyYXRvcj0iaHR0cDovL25zLmFkb2JlLmNvbS9pbGx1c3RyYXRvci8xLjAvIiB4bWxuczp4bXBUUGc9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC90L3BnLyIgeG1sbnM6c3REaW09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9EaW1lbnNpb25zIyIgeG1sbnM6c3RGbnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9Gb250IyIgeG1sbnM6eG1wRz0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL2cvIiB4bWxuczpwZGY9Imh0dHA6Ly9ucy5hZG9iZS5jb20vcGRmLzEuMy8iIHhtbG5zOnBob3Rvc2hvcD0iaHR0cDovL25zLmFkb2JlLmNvbS9waG90b3Nob3AvMS4wLyIgZGM6Zm9ybWF0PSJpbWFnZS9wbmciIHhtcDpNZXRhZGF0YURhdGU9IjIwMjItMTEtMTRUMTY6MTY6MTItMDc6MDAiIHhtcDpNb2RpZnlEYXRlPSIyMDIyLTExLTE0VDE2OjE2OjEyLTA3OjAwIiB4bXA6Q3JlYXRlRGF0ZT0iMjAyMS0wMi0yMlQxMzoxMDowMi0wNzowMCIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBJbGx1c3RyYXRvciAyNS4yIChNYWNpbnRvc2gpIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOmNiMDdhMjNiLWJhNjgtNGQzMi1hN2RmLTMwYjRkYTk3YTE2MyIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDo1NjViZDYxOC1kMzU3LTRjMDMtODI0MS1jMDA2YjI0OWM1YzciIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0idXVpZDo1RDIwODkyNDkzQkZEQjExOTE0QTg1OTBEMzE1MDhDOCIgeG1wTU06UmVuZGl0aW9uQ2xhc3M9InByb29mOnBkZiIgaWxsdXN0cmF0b3I6U3RhcnR1cFByb2ZpbGU9IlByaW50IiBpbGx1c3RyYXRvcjpDcmVhdG9yU3ViVG9vbD0iQUlSb2JpbiIgaWxsdXN0cmF0b3I6VHlwZT0iRG9jdW1lbnQiIHhtcFRQZzpIYXNWaXNpYmxlT3ZlcnByaW50PSJGYWxzZSIgeG1wVFBnOkhhc1Zpc2libGVUcmFuc3BhcmVuY3k9IlRydWUiIHhtcFRQZzpOUGFnZXM9IjEiIHBkZjpQcm9kdWNlcj0iQWRvYmUgUERGIGxpYnJhcnkgMTUuMDAiIHBob3Rvc2hvcDpDb2xvck1vZGU9IjMiPiA8ZGM6dGl0bGU+IDxyZGY6QWx0PiA8cmRmOmxpIHhtbDpsYW5nPSJ4LWRlZmF1bHQiPn5haS1hMzliYTc1MC04NzBjLTQ3NTgtYWZjNC02NzM5ZmJlNWNjMjJfPC9yZGY6bGk+IDwvcmRmOkFsdD4gPC9kYzp0aXRsZT4gPHhtcE1NOkRlcml2ZWRGcm9tIHN0UmVmOmluc3RhbmNlSUQ9InV1aWQ6NWVmYTMxODktY2NmNS1mMzRhLWI5ZGUtMjU5YmY4ODYxNDUzIiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOjU2NWJkNjE4LWQzNTctNGMwMy04MjQxLWMwMDZiMjQ5YzVjNyIgc3RSZWY6b3JpZ2luYWxEb2N1bWVudElEPSJ1dWlkOjVEMjA4OTI0OTNCRkRCMTE5MTRBODU5MEQzMTUwOEM4IiBzdFJlZjpyZW5kaXRpb25DbGFzcz0icHJvb2Y6cGRmIi8+IDx4bXBNTTpIaXN0b3J5PiA8cmRmOlNlcT4gPHJkZjpsaSBzdEV2dDphY3Rpb249InNhdmVkIiBzdEV2dDppbnN0YW5jZUlEPSJ4bXAuaWlkOjA1YjRlZDM3LThkMzItNGM0Ni05N2YwLTdiNjFlMzZhZmQ1MyIgc3RFdnQ6d2hlbj0iMjAxOC0xMC0zMFQxNjoyMzoyMi0wNjowMCIgc3RFdnQ6c29mdHdhcmVBZ2VudD0iQWRvYmUgSWxsdXN0cmF0b3IgQ0MgMjIuMSAoTWFjaW50b3NoKSIgc3RFdnQ6Y2hhbmdlZD0iLyIvPiA8cmRmOmxpIHN0RXZ0OmFjdGlvbj0ic2F2ZWQiIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6NTY1YmQ2MTgtZDM1Ny00YzAzLTgyNDEtYzAwNmIyNDljNWM3IiBzdEV2dDp3aGVuPSIyMDIwLTA5LTE0VDE2OjIxOjQyLTA2OjAwIiBzdEV2dDpzb2Z0d2FyZUFnZW50PSJBZG9iZSBJbGx1c3RyYXRvciAyNC4zIChNYWNpbnRvc2gpIiBzdEV2dDpjaGFuZ2VkPSIvIi8+IDxyZGY6bGkgc3RFdnQ6YWN0aW9uPSJjb252ZXJ0ZWQiIHN0RXZ0OnBhcmFtZXRlcnM9ImZyb20gYXBwbGljYXRpb24vcGRmIHRvIGFwcGxpY2F0aW9uL3ZuZC5hZG9iZS5waG90b3Nob3AiLz4gPHJkZjpsaSBzdEV2dDphY3Rpb249ImRlcml2ZWQiIHN0RXZ0OnBhcmFtZXRlcnM9ImNvbnZlcnRlZCBmcm9tIGFwcGxpY2F0aW9uL3ZuZC5hZG9iZS5waG90b3Nob3AgdG8gaW1hZ2UvcG5nIi8+IDxyZGY6bGkgc3RFdnQ6YWN0aW9uPSJzYXZlZCIgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDpjNzg0MDY0NC1iZTAwLTQ0NGItYTdmZC1iYjUxMmQ4NTBlMTAiIHN0RXZ0OndoZW49IjIwMjItMTEtMTRUMTY6MTI6MjEtMDc6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCAyMy41IChNYWNpbnRvc2gpIiBzdEV2dDpjaGFuZ2VkPSIvIi8+IDxyZGY6bGkgc3RFdnQ6YWN0aW9uPSJzYXZlZCIgc3RFdnQ6aW5zdGFuY2VJRD0ieG1wLmlpZDpjYjA3YTIzYi1iYTY4LTRkMzItYTdkZi0zMGI0ZGE5N2ExNjMiIHN0RXZ0OndoZW49IjIwMjItMTEtMTRUMTY6MTY6MTItMDc6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlbnQ9IkFkb2JlIFBob3Rvc2hvcCAyMy41IChNYWNpbnRvc2gpIiBzdEV2dDpjaGFuZ2VkPSIvIi8+IDwvcmRmOlNlcT4gPC94bXBNTTpIaXN0b3J5PiA8eG1wVFBnOk1heFBhZ2VTaXplIHN0RGltOnc9IjEyMjQuMDAwMDAwIiBzdERpbTpoPSI4OTcuNDg2NTY0IiBzdERpbTp1bml0PSJQb2ludHMiLz4gPHhtcFRQZzpGb250cz4gPHJkZjpCYWc+IDxyZGY6bGkgc3RGbnQ6Zm9udE5hbWU9Ik15cmlhZFByby1SZWd1bGFyIiBzdEZudDpmb250RmFtaWx5PSJNeXJpYWQgUHJvIiBzdEZudDpmb250RmFjZT0iUmVndWxhciIgc3RGbnQ6Zm9udFR5cGU9Ik9wZW4gVHlwZSIgc3RGbnQ6dmVyc2lvblN0cmluZz0iVmVyc2lvbiAyLjExNTtQUyAyLjAwMDtob3Rjb252IDEuMC44MTttYWtlb3RmLmxpYjIuNS42MzQwNiIgc3RGbnQ6Y29tcG9zaXRlPSJGYWxzZSIgc3RGbnQ6Zm9udEZpbGVOYW1lPSIuNjg1MS5vdGYiLz4gPHJkZjpsaSBzdEZudDpmb250TmFtZT0iT3BlblNhbnMtQm9sZCIgc3RGbnQ6Zm9udEZhbWlseT0iT3BlbiBTYW5zIiBzdEZudDpmb250RmFjZT0iQm9sZCIgc3RGbnQ6Zm9udFR5cGU9Ik9wZW4gVHlwZSIgc3RGbnQ6dmVyc2lvblN0cmluZz0iVmVyc2lvbiAxLjEwIiBzdEZudDpjb21wb3NpdGU9IkZhbHNlIiBzdEZudDpmb250RmlsZU5hbWU9Ik9wZW5TYW5zLUJvbGQudHRmIi8+IDwvcmRmOkJhZz4gPC94bXBUUGc6Rm9udHM+IDx4bXBUUGc6UGxhdGVOYW1lcz4gPHJkZjpTZXE+IDxyZGY6bGk+Q3lhbjwvcmRmOmxpPiA8cmRmOmxpPk1hZ2VudGE8L3JkZjpsaT4gPHJkZjpsaT5ZZWxsb3c8L3JkZjpsaT4gPHJkZjpsaT5CbGFjazwvcmRmOmxpPiA8L3JkZjpTZXE+IDwveG1wVFBnOlBsYXRlTmFtZXM+IDx4bXBUUGc6U3dhdGNoR3JvdXBzPiA8cmRmOlNlcT4gPHJkZjpsaT4gPHJkZjpEZXNjcmlwdGlvbiB4bXBHOmdyb3VwTmFtZT0iRGVmYXVsdCBTd2F0Y2ggR3JvdXAiIHhtcEc6Z3JvdXBUeXBlPSIwIj4gPHhtcEc6Q29sb3JhbnRzPiA8cmRmOlNlcT4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IldoaXRlIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjU1IiB4bXBHOmdyZWVuPSIyNTUiIHhtcEc6Ymx1ZT0iMjU1Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJCbGFjayIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjM1IiB4bXBHOmdyZWVuPSIzMSIgeG1wRzpibHVlPSIzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQ01ZSyBSZWQiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIyMzYiIHhtcEc6Z3JlZW49IjI4IiB4bXBHOmJsdWU9IjM2Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDTVlLIFllbGxvdyIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI1NSIgeG1wRzpncmVlbj0iMjQxIiB4bXBHOmJsdWU9IjAiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgR3JlZW4iIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSIxNjUiIHhtcEc6Ymx1ZT0iODEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgQ3lhbiIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjAiIHhtcEc6Z3JlZW49IjE3MyIgeG1wRzpibHVlPSIyMzgiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgQmx1ZSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjQ2IiB4bXBHOmdyZWVuPSI0OSIgeG1wRzpibHVlPSIxNDUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkNNWUsgTWFnZW50YSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIzNSIgeG1wRzpncmVlbj0iMCIgeG1wRzpibHVlPSIxMzkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTUgTT0xMDAgWT05MCBLPTEwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMTkwIiB4bXBHOmdyZWVuPSIzMCIgeG1wRzpibHVlPSI0NSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09OTAgWT04NSBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIyMzgiIHhtcEc6Z3JlZW49IjY0IiB4bXBHOmJsdWU9IjU0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT04MCBZPTk1IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI0MCIgeG1wRzpncmVlbj0iOTAiIHhtcEc6Ymx1ZT0iNDAiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MCBNPTUwIFk9MTAwIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI0NiIgeG1wRzpncmVlbj0iMTQ2IiB4bXBHOmJsdWU9IjMwIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT0zNSBZPTg1IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjI1MCIgeG1wRzpncmVlbj0iMTc1IiB4bXBHOmJsdWU9IjY0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTUgTT0wIFk9OTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjQ5IiB4bXBHOmdyZWVuPSIyMzYiIHhtcEc6Ymx1ZT0iNDkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MjAgTT0wIFk9MTAwIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIxNCIgeG1wRzpncmVlbj0iMjIyIiB4bXBHOmJsdWU9IjM1Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTUwIE09MCBZPTEwMCBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxMzkiIHhtcEc6Z3JlZW49IjE5NyIgeG1wRzpibHVlPSI2MyIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz03NSBNPTAgWT0xMDAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iNTUiIHhtcEc6Z3JlZW49IjE3OSIgeG1wRzpibHVlPSI3NCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz04NSBNPTEwIFk9MTAwIEs9MTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSIxNDciIHhtcEc6Ymx1ZT0iNjkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9OTAgTT0zMCBZPTk1IEs9MzAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSIxMDQiIHhtcEc6Ymx1ZT0iNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NzUgTT0wIFk9NzUgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iNDEiIHhtcEc6Z3JlZW49IjE4MCIgeG1wRzpibHVlPSIxMTUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9ODAgTT0xMCBZPTQ1IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjAiIHhtcEc6Z3JlZW49IjE2NiIgeG1wRzpibHVlPSIxNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NzAgTT0xNSBZPTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMzgiIHhtcEc6Z3JlZW49IjE2OSIgeG1wRzpibHVlPSIyMjQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9ODUgTT01MCBZPTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjciIHhtcEc6Z3JlZW49IjExNyIgeG1wRzpibHVlPSIxODciLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTAwIE09OTUgWT01IEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjQzIiB4bXBHOmdyZWVuPSI1NiIgeG1wRzpibHVlPSIxNDMiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTAwIE09MTAwIFk9MjUgSz0yNSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjM4IiB4bXBHOmdyZWVuPSIzNCIgeG1wRzpibHVlPSI5NyIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz03NSBNPTEwMCBZPTAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMTAxIiB4bXBHOmdyZWVuPSI0NSIgeG1wRzpibHVlPSIxNDQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NTAgTT0xMDAgWT0wIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE0NCIgeG1wRzpncmVlbj0iMzkiIHhtcEc6Ymx1ZT0iMTQyIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTM1IE09MTAwIFk9MzUgSz0xMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE1OCIgeG1wRzpncmVlbj0iMzEiIHhtcEc6Ymx1ZT0iOTkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MTAgTT0xMDAgWT01MCBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIyMTciIHhtcEc6Z3JlZW49IjI4IiB4bXBHOmJsdWU9IjkyIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT05NSBZPTIwIEs9MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIzNiIgeG1wRzpncmVlbj0iNDEiIHhtcEc6Ymx1ZT0iMTIzIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTI1IE09MjUgWT00MCBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxOTMiIHhtcEc6Z3JlZW49IjE4MCIgeG1wRzpibHVlPSIxNTQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NDAgTT00NSBZPTUwIEs9NSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE1NCIgeG1wRzpncmVlbj0iMTMyIiB4bXBHOmJsdWU9IjEyMSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz01MCBNPTUwIFk9NjAgSz0yNSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjExMyIgeG1wRzpncmVlbj0iMTAxIiB4bXBHOmJsdWU9Ijg4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTU1IE09NjAgWT02NSBLPTQwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iOTAiIHhtcEc6Z3JlZW49Ijc0IiB4bXBHOmJsdWU9IjY2Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTI1IE09NDAgWT02NSBLPTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxOTUiIHhtcEc6Z3JlZW49IjE1MyIgeG1wRzpibHVlPSIxMDciLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9MzAgTT01MCBZPTc1IEs9MTAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxNjgiIHhtcEc6Z3JlZW49IjEyNCIgeG1wRzpibHVlPSI3OSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0zNSBNPTYwIFk9ODAgSz0yNSIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjEzOCIgeG1wRzpncmVlbj0iOTMiIHhtcEc6Ymx1ZT0iNTkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IkM9NDAgTT02NSBZPTkwIEs9MzUiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6cmVkPSIxMTciIHhtcEc6Z3JlZW49Ijc2IiB4bXBHOmJsdWU9IjQwIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTQwIE09NzAgWT0xMDAgSz01MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9Ijk2IiB4bXBHOmdyZWVuPSI1NiIgeG1wRzpibHVlPSIxOSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz01MCBNPTcwIFk9ODAgSz03MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjU5IiB4bXBHOmdyZWVuPSIzNSIgeG1wRzpibHVlPSIyMCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz03MyBNPTQwIFk9MCBLPTAiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjcwIiB4bXBHOmdyZWVuPSIxMzQiIHhtcEc6Ymx1ZT0iMTk4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTYwIEc9ODEgQj0xMzMiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjYwIiB4bXBHOmdyZWVuPSI4MSIgeG1wRzpibHVlPSIxMzMiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTI2IEc9MTY3IEI9MjIzIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIxMjYiIHhtcEc6Z3JlZW49IjE2NSIgeG1wRzpibHVlPSIyMTUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTY1IEc9MjAzIEI9MjM5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIxNjYiIHhtcEc6Z3JlZW49IjIwMiIgeG1wRzpibHVlPSIyMzUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjA5IEc9MjI1IEI9MjQyIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyMDgiIHhtcEc6Z3JlZW49IjIyNSIgeG1wRzpibHVlPSIyNDEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjQ1IEc9MjQ3IEI9MjQ5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDQiIHhtcEc6Z3JlZW49IjI0NiIgeG1wRzpibHVlPSIyNDgiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjQ3IEc9MTY2IEI9MTA2IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDciIHhtcEc6Z3JlZW49IjE2NiIgeG1wRzpibHVlPSIxMDYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjUgRz0yOCBCPTYwIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNCIgeG1wRzpncmVlbj0iMjciIHhtcEc6Ymx1ZT0iNTkiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9NzQgRz0xMDEgQj0xNjMiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9Ijc0IiB4bXBHOmdyZWVuPSIxMDEiIHhtcEc6Ymx1ZT0iMTYzIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTkzIEc9MTI1IEI9MTkwIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI5MyIgeG1wRzpncmVlbj0iMTI1IiB4bXBHOmJsdWU9IjE5MCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNTUgRz0yMDUgQj0zMyIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjU1IiB4bXBHOmdyZWVuPSIyMDUiIHhtcEc6Ymx1ZT0iMzIiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjA5IEc9MjExIEI9MjEyIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyMDkiIHhtcEc6Z3JlZW49IjIxMSIgeG1wRzpibHVlPSIyMTEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9Ikdsb2JhbCBDb2xvciIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjUxIiB4bXBHOmdyZWVuPSIyMDgiIHhtcEc6Ymx1ZT0iMjQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MCBHPTc2IEI9MTE3IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIwIiB4bXBHOmdyZWVuPSI3NiIgeG1wRzpibHVlPSIxMTciLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTA0IEc9MjA0IEI9MjI5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIxMDUiIHhtcEc6Z3JlZW49IjIwMyIgeG1wRzpibHVlPSIyMjgiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MjUyIEc9MTc4IEI9MzEiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjI1MSIgeG1wRzpncmVlbj0iMTc4IiB4bXBHOmJsdWU9IjI4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJQQU5UT05FIDI4MiBDIiB4bXBHOnR5cGU9IlNQT1QiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJMQUIiIHhtcEc6TD0iMTAuOTgwMzkyIiB4bXBHOkE9IjIiIHhtcEc6Qj0iLTI2Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJibHVzaCBjb3B5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDIiIHhtcEc6Z3JlZW49IjE1NiIgeG1wRzpibHVlPSIxNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MTA1IEc9MjA5IEI9NTIiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjEwNSIgeG1wRzpncmVlbj0iMjA5IiB4bXBHOmJsdWU9IjUyIi8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTUgRz0xNjAgQj02OSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNSIgeG1wRzpncmVlbj0iMTYwIiB4bXBHOmJsdWU9IjY4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTU1IEc9MTg4IEI9MTU1IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI1NCIgeG1wRzpncmVlbj0iMTg4IiB4bXBHOmJsdWU9IjE1NCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj00MSBHPTQxIEI9MTA1IGNvcHkiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjQwIiB4bXBHOmdyZWVuPSI0MCIgeG1wRzpibHVlPSIxMDUiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9NSBHPTE5NyBCPTIxOSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNSIgeG1wRzpncmVlbj0iMTk2IiB4bXBHOmJsdWU9IjIxOSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNTUgRz03MyBCPTk5IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNTUiIHhtcEc6Z3JlZW49IjczIiB4bXBHOmJsdWU9Ijk4Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTI1NSBHPTIwMyBCPTEzOCIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjU1IiB4bXBHOmdyZWVuPSIyMDIiIHhtcEc6Ymx1ZT0iMTM3Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTYxIEc9MTA2IEI9MjA0IDQiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjYxIiB4bXBHOmdyZWVuPSIxMDUiIHhtcEc6Ymx1ZT0iMjA0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJza2luIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDQiIHhtcEc6Z3JlZW49IjIwNyIgeG1wRzpibHVlPSIxOTEiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9NDEgRz00MSBCPTEwNSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNDAiIHhtcEc6Z3JlZW49IjQwIiB4bXBHOmJsdWU9IjEwNSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yMTQgRz0xODQgQj0xNDEiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjIxNCIgeG1wRzpncmVlbj0iMTg0IiB4bXBHOmJsdWU9IjE0MCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNDAgRz0xOTUgQj0xNjgiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjIzOSIgeG1wRzpncmVlbj0iMTk0IiB4bXBHOmJsdWU9IjE2NyIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj02MSBHPTEwNiBCPTIwNCIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNjEiIHhtcEc6Z3JlZW49IjEwNSIgeG1wRzpibHVlPSIyMDQiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9ImJsdXNoIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSIyNDIiIHhtcEc6Z3JlZW49IjE1NiIgeG1wRzpibHVlPSIxNTYiLz4gPHJkZjpsaSB4bXBHOnN3YXRjaE5hbWU9IlI9MyBHPTIyNCBCPTE5NyIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMyIgeG1wRzpncmVlbj0iMjIzIiB4bXBHOmJsdWU9IjE5NiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj01IEc9MTkzIEI9MjE0IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI0IiB4bXBHOmdyZWVuPSIxOTIiIHhtcEc6Ymx1ZT0iMjE0Ii8+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJSPTcwIEc9MTcyIEI9MTk1IiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI3MCIgeG1wRzpncmVlbj0iMTcyIiB4bXBHOmJsdWU9IjE5NSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yMyBHPTIzIEI9NTEiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzp0aW50PSIxMDAuMDAwMDAwIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzpyZWQ9IjIyIiB4bXBHOmdyZWVuPSIyMiIgeG1wRzpibHVlPSI1MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj02MSBHPTEwNiBCPTIwNCAyIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI3MSIgeG1wRzpncmVlbj0iMTA1IiB4bXBHOmJsdWU9IjE3OCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj02MSBHPTEwNiBCPTIwNCAzIiB4bXBHOnR5cGU9IlBST0NFU1MiIHhtcEc6dGludD0iMTAwLjAwMDAwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6cmVkPSI3MSIgeG1wRzpncmVlbj0iMTA1IiB4bXBHOmJsdWU9IjE3OCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj00MSBHPTQxIEI9MTA1IGNvcHkgMiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iNDEiIHhtcEc6Z3JlZW49IjQyIiB4bXBHOmJsdWU9IjEwNCIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iUj0yNTAgRz0xNzYgQj0yOSIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnRpbnQ9IjEwMC4wMDAwMDAiIHhtcEc6bW9kZT0iUkdCIiB4bXBHOnJlZD0iMjUwIiB4bXBHOmdyZWVuPSIxNzYiIHhtcEc6Ymx1ZT0iMjkiLz4gPC9yZGY6U2VxPiA8L3htcEc6Q29sb3JhbnRzPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6bGk+IDxyZGY6bGk+IDxyZGY6RGVzY3JpcHRpb24geG1wRzpncm91cE5hbWU9IkdyYXlzIiB4bXBHOmdyb3VwVHlwZT0iMSI+IDx4bXBHOkNvbG9yYW50cz4gPHJkZjpTZXE+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT0wIFk9MCBLPTEwMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjM1IiB4bXBHOmdyZWVuPSIzMSIgeG1wRzpibHVlPSIzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz05MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjY0IiB4bXBHOmdyZWVuPSI2NCIgeG1wRzpibHVlPSI2NSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz04MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9Ijg4IiB4bXBHOmdyZWVuPSI4OSIgeG1wRzpibHVlPSI5MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz03MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjEwOSIgeG1wRzpncmVlbj0iMTEwIiB4bXBHOmJsdWU9IjExMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz02MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjEyOCIgeG1wRzpncmVlbj0iMTI5IiB4bXBHOmJsdWU9IjEzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz01MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE0NiIgeG1wRzpncmVlbj0iMTQ4IiB4bXBHOmJsdWU9IjE1MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz00MCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE2NiIgeG1wRzpncmVlbj0iMTY4IiB4bXBHOmJsdWU9IjE3MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz0zMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjE4NyIgeG1wRzpncmVlbj0iMTg5IiB4bXBHOmJsdWU9IjE5MSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz0yMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIwOCIgeG1wRzpncmVlbj0iMjEwIiB4bXBHOmJsdWU9IjIxMSIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz0xMCIgeG1wRzptb2RlPSJSR0IiIHhtcEc6dHlwZT0iUFJPQ0VTUyIgeG1wRzpyZWQ9IjIzMCIgeG1wRzpncmVlbj0iMjMxIiB4bXBHOmJsdWU9IjIzMiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09MCBZPTAgSz01IiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjQxIiB4bXBHOmdyZWVuPSIyNDEiIHhtcEc6Ymx1ZT0iMjQyIi8+IDwvcmRmOlNlcT4gPC94bXBHOkNvbG9yYW50cz4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOmxpPiA8cmRmOmxpPiA8cmRmOkRlc2NyaXB0aW9uIHhtcEc6Z3JvdXBOYW1lPSJCcmlnaHRzIiB4bXBHOmdyb3VwVHlwZT0iMSI+IDx4bXBHOkNvbG9yYW50cz4gPHJkZjpTZXE+IDxyZGY6bGkgeG1wRzpzd2F0Y2hOYW1lPSJDPTAgTT0xMDAgWT0xMDAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjM2IiB4bXBHOmdyZWVuPSIyOCIgeG1wRzpibHVlPSIzNiIvPiA8cmRmOmxpIHhtcEc6c3dhdGNoTmFtZT0iQz0wIE09NzUgWT0xMDAgSz0wIiB4bXBHOm1vZGU9IlJHQiIgeG1wRzp0eXBlPSJQUk9DRVNTIiB4bXBHOnJlZD0iMjQx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\"\n }))));\n};\nexport { SvgNoResult as ReactComponent };\nexport default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMzAyIiBoZWlnaHQ9IjE4NiIgdmlld0JveD0iMCAwIDMwMiAxODYiIGZpbGw9Im5vbmUiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPgo8cmVjdCB3aWR0aD0iMzAyIiBoZWlnaHQ9IjE4NiIgZmlsbD0idXJsKCNwYXR0ZXJuMCkiLz4KPGRlZnM+CjxwYXR0ZXJuIGlkPSJwYXR0ZXJuMCIgcGF0dGVybkNvbnRlbnRVbml0cz0ib2JqZWN0Qm91bmRpbmdCb3giIHdpZHRoPSIxIiBoZWlnaHQ9IjEiPgo8dXNlIHhsaW5rOmhyZWY9IiNpbWFnZTBfMzEzXzIwNDgiIHRyYW5zZm9ybT0idHJhbnNsYXRlKC0wLjAwMDMwMjMzMikgc2NhbGUoMC4wMDA4OTI2IDAuMDAxNDQ5MjgpIi8+CjwvcGF0dGVybj4KPGltYWdlIGlkPSJpbWFnZTBfMzEzXzIwNDgiIHdpZHRoPSIxMTIxIiBoZWlnaHQ9IjY5MCIgeGxpbms6aHJlZj0iZGF0YTppbWFnZS9wbmc7YmFzZTY0LGlWQk9SdzBLR2dvQUFBQU5TVWhFVWdBQUJHRUFBQUt5Q0FZQUFBQjE2c09KQUFBQUNYQklXWE1BQUFzVEFBQUxFd0VBbXB3WUFBQkZVR2xVV0hSWVRVdzZZMjl0TG1Ga2IySmxMbmh0Y0FBQUFBQUFQRDk0Y0dGamEyVjBJR0psWjJsdVBTTHZ1NzhpSUdsa1BTSlhOVTB3VFhCRFpXaHBTSHB5WlZONlRsUmplbXRqT1dRaVB6NGdQSGc2ZUcxd2JXVjBZU0I0Yld4dWN6cDRQU0poWkc5aVpUcHVjenB0WlhSaEx5SWdlRHA0YlhCMGF6MGlRV1J2WW1VZ1dFMVFJRU52Y21VZ055NHlMV013TURBZ056a3VNV0kyTldFM09XSTBMQ0F5TURJeUx6QTJMekV6TFRJeU9qQXhPakF4SUNBZ0lDQWdJQ0FpUGlBOGNtUm1PbEpFUmlCNGJXeHVjenB5WkdZOUltaDBkSEE2THk5M2QzY3Vkek11YjNKbkx6RTVPVGt2TURJdk1qSXRjbVJtTFhONWJuUmhlQzF1Y3lNaVBpQThjbVJtT2tSbGMyTnlhWEIwYVc5dUlISmtaanBoWW05MWREMGlJaUI0Yld4dWN6cGtZejBpYUhSMGNEb3ZMM0IxY213dWIzSm5MMlJqTDJWc1pXMWxiblJ6THpFdU1TOGlJSGh0Ykc1ek9uaHRjRDBpYUhSMGNEb3ZMMjV6TG1Ga2IySmxMbU52YlM5NFlYQXZNUzR3THlJZ2VHMXNibk02ZUcxd1RVMDlJbWgwZEhBNkx5OXVjeTVoWkc5aVpTNWpiMjB2ZUdGd0x6RXVNQzl0YlM4aUlIaHRiRzV6T25OMFVtVm1QU0pvZEhSd09pOHZibk11WVdSdlltVXVZMjl0TDNoaGNDOHhMakF2YzFSNWNHVXZVbVZ6YjNWeVkyVlNaV1lqSWlCNGJXeHVjenB6ZEVWMmREMGlhSFIwY0RvdkwyNXpMbUZrYjJKbExtTnZiUzk0WVhBdk1TNHdMM05VZVhCbEwxSmxjMjkxY21ObFJYWmxiblFqSWlCNGJXeHVjenBwYkd4MWMzUnlZWFJ2Y2owaWFIUjBjRG92TDI1ekxtRmtiMkpsTG1OdmJTOXBiR3gxYzNSeVlYUnZjaTh4TGpBdklpQjRiV3h1Y3pwNGJYQlVVR2M5SW1oMGRIQTZMeTl1Y3k1aFpHOWlaUzVqYjIwdmVHRndMekV1TUM5MEwzQm5MeUlnZUcxc2JuTTZjM1JFYVcwOUltaDBkSEE2THk5dWN5NWhaRzlpWlM1amIyMHZlR0Z3THpFdU1DOXpWSGx3WlM5RWFXMWxibk5wYjI1ekl5SWdlRzFzYm5NNmMzUkdiblE5SW1oMGRIQTZMeTl1Y3k1aFpHOWlaUzVqYjIwdmVHRndMekV1TUM5elZIbHdaUzlHYjI1MEl5SWdlRzFzYm5NNmVHMXdSejBpYUhSMGNEb3ZMMjV6TG1Ga2IySmxMbU52YlM5NFlYQXZNUzR3TDJjdklpQjRiV3h1Y3pwd1pHWTlJbWgwZEhBNkx5OXVjeTVoWkc5aVpTNWpiMjB2Y0dSbUx6RXVNeThpSUhodGJHNXpPbkJvYjNSdmMyaHZjRDBpYUhSMGNEb3ZMMjV6TG1Ga2IySmxMbU52YlM5d2FHOTBiM05vYjNBdk1TNHdMeUlnWkdNNlptOXliV0YwUFNKcGJXRm5aUzl3Ym1jaUlIaHRjRHBOWlhSaFpHRjBZVVJoZEdVOUlqSXdNakl0TVRFdE1UUlVNVFk2TVRZNk1USXRNRGM2TURBaUlIaHRjRHBOYjJScFpubEVZWFJsUFNJeU1ESXlMVEV4TFRFMFZERTJPakUyT2pFeUxUQTNPakF3SWlCNGJYQTZRM0psWVhSbFJHRjBaVDBpTWpBeU1TMHdNaTB5TWxReE16b3hNRG93TWkwd056b3dNQ0lnZUcxd09rTnlaV0YwYjNKVWIyOXNQU0pCWkc5aVpTQkpiR3gxYzNSeVlYUnZjaUF5TlM0eUlDaE5ZV05wYm5SdmMyZ3BJaUI0YlhCTlRUcEpibk4wWVc1alpVbEVQU0o0YlhBdWFXbGtPbU5pTURkaE1qTmlMV0poTmpndE5HUXpNaTFoTjJSbUxUTXdZalJrWVRrM1lURTJNeUlnZUcxd1RVMDZSRzlqZFcxbGJuUkpSRDBpZUcxd0xtUnBaRG8xTmpWaVpEWXhPQzFrTXpVM0xUUmpNRE10T0RJME1TMWpNREEyWWpJME9XTTFZemNpSUhodGNFMU5Pazl5YVdkcGJtRnNSRzlqZFcxbGJuUkpSRDBpZFhWcFpEbzFSREl3T0RreU5Ea3pRa1pFUWpFeE9URTBRVGcxT1RCRU16RTFNRGhET0NJZ2VHMXdUVTA2VW1WdVpHbDBhVzl1UTJ4aGMzTTlJbkJ5YjI5bU9uQmtaaUlnYVd4c2RYTjBjbUYwYjNJNlUzUmhjblIxY0ZCeWIyWnBiR1U5SWxCeWFXNTBJaUJwYkd4MWMzUnlZWFJ2Y2pwRGNtVmhkRzl5VTNWaVZHOXZiRDBpUVVsU2IySnBiaUlnYVd4c2RYTjBjbUYwYjNJNlZIbHdaVDBpUkc5amRXMWxiblFpSUhodGNGUlFaenBJWVhOV2FYTnBZbXhsVDNabGNuQnlhVzUwUFNKR1lXeHpaU0lnZUcxd1ZGQm5Pa2hoYzFacGMybGliR1ZVY21GdWMzQmhjbVZ1WTNrOUlsUnlkV1VpSUhodGNGUlFaenBPVUdGblpYTTlJakVpSUhCa1pqcFFjbTlrZFdObGNqMGlRV1J2WW1VZ1VFUkdJR3hwWW5KaGNua2dNVFV1TURBaUlIQm9iM1J2YzJodmNEcERiMnh2Y2sxdlpHVTlJak1pUGlBOFpHTTZkR2wwYkdVK0lEeHlaR1k2UVd4MFBpQThjbVJtT214cElIaHRiRHBzWVc1blBTSjRMV1JsWm1GMWJIUWlQbjVoYVMxaE16bGlZVGMxTUMwNE56QmpMVFEzTlRndFlXWmpOQzAyTnpNNVptSmxOV05qTWpKZlBDOXlaR1k2YkdrK0lEd3ZjbVJtT2tGc2RENGdQQzlrWXpwMGFYUnNaVDRnUEhodGNFMU5Pa1JsY21sMlpXUkdjbTl0SUhOMFVtVm1PbWx1YzNSaGJtTmxTVVE5SW5WMWFXUTZOV1ZtWVRNeE9Ea3RZMk5tTlMxbU16UmhMV0k1WkdVdE1qVTVZbVk0T0RZeE5EVXpJaUJ6ZEZKbFpqcGtiMk4xYldWdWRFbEVQU0o0YlhBdVpHbGtPalUyTldKa05qRTRMV1F6TlRjdE5HTXdNeTA0TWpReExXTXdNRFppTWpRNVl6VmpOeUlnYzNSU1pXWTZiM0pwWjJsdVlXeEViMk4xYldWdWRFbEVQU0oxZFdsa09qVkVNakE0T1RJME9UTkNSa1JDTVRFNU1UUkJPRFU1TUVRek1UVXdPRU00SWlCemRGSmxaanB5Wlc1a2FYUnBiMjVEYkdGemN6MGljSEp2YjJZNmNHUm1JaTgrSUR4NGJYQk5UVHBJYVhOMGIzSjVQaUE4Y21SbU9sTmxjVDRnUEhKa1pqcHNhU0J6ZEVWMmREcGhZM1JwYjI0OUluTmhkbVZrSWlCemRFVjJkRHBwYm5OMFlXNWpaVWxFUFNKNGJYQXVhV2xrT2pBMVlqUmxaRE0zTFRoa016SXROR00wTmkwNU4yWXdMVGRpTmpGbE16WmhabVExTXlJZ2MzUkZkblE2ZDJobGJqMGlNakF4T0MweE1DMHpNRlF4TmpveU16b3lNaTB3Tmpvd01DSWdjM1JGZG5RNmMyOW1kSGRoY21WQloyVnVkRDBpUVdSdlltVWdTV3hzZFhOMGNtRjBiM0lnUTBNZ01qSXVNU0FvVFdGamFXNTBiM05vS1NJZ2MzUkZkblE2WTJoaGJtZGxaRDBpTHlJdlBpQThjbVJtT214cElITjBSWFowT21GamRHbHZiajBpYzJGMlpXUWlJSE4wUlhaME9tbHVjM1JoYm1ObFNVUTlJbmh0Y0M1cGFXUTZOVFkxWW1RMk1UZ3RaRE0xTnkwMFl6QXpMVGd5TkRFdFl6QXdObUl5TkRsak5XTTNJaUJ6ZEVWMmREcDNhR1Z1UFNJeU1ESXdMVEE1TFRFMFZERTJPakl4T2pReUxUQTJPakF3SWlCemRFVjJkRHB6YjJaMGQyRnlaVUZuWlc1MFBTSkJaRzlpWlNCSmJHeDFjM1J5WVhSdmNpQXlOQzR6SUNoTllXTnBiblJ2YzJncElpQnpkRVYyZERwamFHRnVaMlZrUFNJdklpOCtJRHh5WkdZNmJHa2djM1JGZG5RNllXTjBhVzl1UFNKamIyNTJaWEowWldRaUlITjBSWFowT25CaGNtRnRaWFJsY25NOUltWnliMjBnWVhCd2JHbGpZWFJwYjI0dmNHUm1JSFJ2SUdGd2NHeHBZMkYwYVc5dUwzWnVaQzVoWkc5aVpTNXdhRzkwYjNOb2IzQWlMejRnUEhKa1pqcHNhU0J6ZEVWMmREcGhZM1JwYjI0OUltUmxjbWwyWldRaUlITjBSWFowT25CaGNtRnRaWFJsY25NOUltTnZiblpsY25SbFpDQm1jbTl0SUdGd2NHeHBZMkYwYVc5dUwzWnVaQzVoWkc5aVpTNXdhRzkwYjNOb2IzQWdkRzhnYVcxaFoyVXZjRzVuSWk4K0lEeHlaR1k2YkdrZ2MzUkZkblE2WVdOMGFXOXVQU0p6WVhabFpDSWdjM1JGZG5RNmFXNXpkR0Z1WTJWSlJEMGllRzF3TG1scFpEcGpOemcwTURZME5DMWlaVEF3TFRRME5HSXRZVGRtWkMxaVlqVXhNbVE0TlRCbE1UQWlJSE4wUlhaME9uZG9aVzQ5SWpJd01qSXRNVEV0TVRSVU1UWTZNVEk2TWpFdE1EYzZNREFpSUhOMFJYWjBPbk52Wm5SM1lYSmxRV2RsYm5ROUlrRmtiMkpsSUZCb2IzUnZjMmh2Y0NBeU15NDFJQ2hOWVdOcGJuUnZjMmdwSWlCemRFVjJkRHBqYUdGdVoyVmtQU0l2SWk4K0lEeHlaR1k2YkdrZ2MzUkZkblE2WVdOMGFXOXVQU0p6WVhabFpDSWdjM1JGZG5RNmFXNXpkR0Z1WTJWSlJEMGllRzF3TG1scFpEcGpZakEzWVRJellpMWlZVFk0TFRSa016SXRZVGRrWmkwek1HSTBaR0U1TjJFeE5qTWlJSE4wUlhaME9uZG9aVzQ5SWpJd01qSXRNVEV0TVRSVU1UWTZNVFk2TVRJdE1EYzZNREFpSUhOMFJYWjBPbk52Wm5SM1lYSmxRV2RsYm5ROUlrRmtiMkpsSUZCb2IzUnZjMmh2Y0NBeU15NDFJQ2hOWVdOcGJuUnZjMmdwSWlCemRFVjJkRHBqYUdGdVoyVmtQU0l2SWk4K0lEd3ZjbVJtT2xObGNUNGdQQzk0YlhCTlRUcElhWE4wYjNKNVBpQThlRzF3VkZCbk9rMWhlRkJoWjJWVGFYcGxJSE4wUkdsdE9uYzlJakV5TWpRdU1EQXdNREF3SWlCemRFUnBiVHBvUFNJNE9UY3VORGcyTlRZMElpQnpkRVJwYlRwMWJtbDBQU0pRYjJsdWRITWlMejRnUEhodGNGUlFaenBHYjI1MGN6NGdQSEprWmpwQ1lXYytJRHh5WkdZNmJHa2djM1JHYm5RNlptOXVkRTVoYldVOUlrMTVjbWxoWkZCeWJ5MVNaV2QxYkdGeUlpQnpkRVp1ZERwbWIyNTBSbUZ0YVd4NVBTSk5lWEpwWVdRZ1VISnZJaUJ6ZEVadWREcG1iMjUwUm1GalpUMGlVbVZuZFd4aGNpSWdjM1JHYm5RNlptOXVkRlI1Y0dVOUlrOXdaVzRnVkhsd1pTSWdjM1JHYm5RNmRtVnljMmx2YmxOMGNtbHVaejBpVm1WeWMybHZiaUF5TGpFeE5UdFFVeUF5TGpBd01EdG9iM1JqYjI1MklERXVNQzQ0TVR0dFlXdGxiM1JtTG14cFlqSXVOUzQyTXpRd05pSWdjM1JHYm5RNlkyOXRjRzl6YVhSbFBTSkdZV3h6WlNJZ2MzUkdiblE2Wm05dWRFWnBiR1ZPWVcxbFBTSXVOamcxTVM1dmRHWWlMejRnUEhKa1pqcHNhU0J6ZEVadWREcG1iMjUwVG1GdFpUMGlUM0JsYmxOaGJuTXRRbTlzWkNJZ2MzUkdiblE2Wm05dWRFWmhiV2xzZVQwaVQzQmxiaUJUWVc1eklpQnpkRVp1ZERwbWIyNTBSbUZqWlQwaVFtOXNaQ0lnYzNSR2JuUTZabTl1ZEZSNWNHVTlJazl3Wlc0Z1ZIbHdaU0lnYzNSR2JuUTZkbVZ5YzJsdmJsTjBjbWx1WnowaVZtVnljMmx2YmlBeExqRXdJaUJ6ZEVadWREcGpiMjF3YjNOcGRHVTlJa1poYkhObElpQnpkRVp1ZERwbWIyNTBSbWxzWlU1aGJXVTlJazl3Wlc1VFlXNXpMVUp2YkdRdWRIUm1JaTgrSUR3dmNtUm1Pa0poWno0Z1BDOTRiWEJVVUdjNlJtOXVkSE0rSUR4NGJYQlVVR2M2VUd4aGRHVk9ZVzFsY3o0Z1BISmtaanBUWlhFK0lEeHlaR1k2YkdrK1EzbGhiand2Y21SbU9teHBQaUE4Y21SbU9teHBQazFoWjJWdWRHRThMM0prWmpwc2FUNGdQSEprWmpwc2FUNVpaV3hzYjNjOEwzSmtaanBzYVQ0Z1BISmtaanBzYVQ1Q2JHRmphend2Y21SbU9teHBQaUE4TDNKa1pqcFRaWEUrSUR3dmVHMXdWRkJuT2xCc1lYUmxUbUZ0WlhNK0lEeDRiWEJVVUdjNlUzZGhkR05vUjNKdmRYQnpQaUE4Y21SbU9sTmxjVDRnUEhKa1pqcHNhVDRnUEhKa1pqcEVaWE5qY21sd2RHbHZiaUI0YlhCSE9tZHliM1Z3VG1GdFpUMGlSR1ZtWVhWc2RDQlRkMkYwWTJnZ1IzSnZkWEFpSUhodGNFYzZaM0p2ZFhCVWVYQmxQU0l3SWo0Z1BIaHRjRWM2UTI5c2IzSmhiblJ6UGlBOGNtUm1PbE5sY1Q0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxkb2FYUmxJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTWpVMUlpQjRiWEJIT21keVpXVnVQU0l5TlRVaUlIaHRjRWM2WW14MVpUMGlNalUxSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKQ2JHRmpheUlnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpNMUlpQjRiWEJIT21keVpXVnVQU0l6TVNJZ2VHMXdSenBpYkhWbFBTSXpNaUl2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUTAxWlN5QlNaV1FpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeU16WWlJSGh0Y0VjNlozSmxaVzQ5SWpJNElpQjRiWEJIT21Kc2RXVTlJak0ySWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFRWbExJRmxsYkd4dmR5SWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakkxTlNJZ2VHMXdSenBuY21WbGJqMGlNalF4SWlCNGJYQkhPbUpzZFdVOUlqQWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa05OV1VzZ1IzSmxaVzRpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJd0lpQjRiWEJIT21keVpXVnVQU0l4TmpVaUlIaHRjRWM2WW14MVpUMGlPREVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtOTldVc2dRM2xoYmlJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqQWlJSGh0Y0VjNlozSmxaVzQ5SWpFM015SWdlRzF3UnpwaWJIVmxQU0l5TXpnaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTk5XVXNnUW14MVpTSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJalEySWlCNGJYQkhPbWR5WldWdVBTSTBPU0lnZUcxd1J6cGliSFZsUFNJeE5EVWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa05OV1VzZ1RXRm5aVzUwWVNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqSXpOU0lnZUcxd1J6cG5jbVZsYmowaU1DSWdlRzF3UnpwaWJIVmxQU0l4TXpraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNVFVnVFQweE1EQWdXVDA1TUNCTFBURXdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTVRrd0lpQjRiWEJIT21keVpXVnVQU0l6TUNJZ2VHMXdSenBpYkhWbFBTSTBOU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowd0lFMDlPVEFnV1QwNE5TQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeU16Z2lJSGh0Y0VjNlozSmxaVzQ5SWpZMElpQjRiWEJIT21Kc2RXVTlJalUwSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUQWdUVDA0TUNCWlBUazFJRXM5TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqSTBNQ0lnZUcxd1J6cG5jbVZsYmowaU9UQWlJSGh0Y0VjNllteDFaVDBpTkRBaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNQ0JOUFRVd0lGazlNVEF3SUVzOU1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakkwTmlJZ2VHMXdSenBuY21WbGJqMGlNVFEySWlCNGJYQkhPbUpzZFdVOUlqTXdJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRBZ1RUMHpOU0JaUFRnMUlFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpJMU1DSWdlRzF3UnpwbmNtVmxiajBpTVRjMUlpQjRiWEJIT21Kc2RXVTlJalkwSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUVWdUVDB3SUZrOU9UQWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU1qUTVJaUI0YlhCSE9tZHlaV1Z1UFNJeU16WWlJSGh0Y0VjNllteDFaVDBpTkRraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNakFnVFQwd0lGazlNVEF3SUVzOU1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakl4TkNJZ2VHMXdSenBuY21WbGJqMGlNakl5SWlCNGJYQkhPbUpzZFdVOUlqTTFJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRVd0lFMDlNQ0JaUFRFd01DQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeE16a2lJSGh0Y0VjNlozSmxaVzQ5SWpFNU55SWdlRzF3UnpwaWJIVmxQU0kyTXlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MDNOU0JOUFRBZ1dUMHhNREFnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlOVFVpSUhodGNFYzZaM0psWlc0OUlqRTNPU0lnZUcxd1J6cGliSFZsUFNJM05DSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejA0TlNCTlBURXdJRms5TVRBd0lFczlNVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJd0lpQjRiWEJIT21keVpXVnVQU0l4TkRjaUlIaHRjRWM2WW14MVpUMGlOamtpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU9UQWdUVDB6TUNCWlBUazFJRXM5TXpBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2Y21Wa1BTSXdJaUI0YlhCSE9tZHlaV1Z1UFNJeE1EUWlJSGh0Y0VjNllteDFaVDBpTlRZaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlOelVnVFQwd0lGazlOelVnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlOREVpSUhodGNFYzZaM0psWlc0OUlqRTRNQ0lnZUcxd1J6cGliSFZsUFNJeE1UVWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa005T0RBZ1RUMHhNQ0JaUFRRMUlFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpBaUlIaHRjRWM2WjNKbFpXNDlJakUyTmlJZ2VHMXdSenBpYkhWbFBTSXhOVFlpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU56QWdUVDB4TlNCWlBUQWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU16Z2lJSGh0Y0VjNlozSmxaVzQ5SWpFMk9TSWdlRzF3UnpwaWJIVmxQU0l5TWpRaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlPRFVnVFQwMU1DQlpQVEFnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlNamNpSUhodGNFYzZaM0psWlc0OUlqRXhOeUlnZUcxd1J6cGliSFZsUFNJeE9EY2lMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa005TVRBd0lFMDlPVFVnV1QwMUlFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpReklpQjRiWEJIT21keVpXVnVQU0kxTmlJZ2VHMXdSenBpYkhWbFBTSXhORE1pTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU1UQXdJRTA5TVRBd0lGazlNalVnU3oweU5TSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJak00SWlCNGJYQkhPbWR5WldWdVBTSXpOQ0lnZUcxd1J6cGliSFZsUFNJNU55SXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejAzTlNCTlBURXdNQ0JaUFRBZ1N6MHdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTVRBeElpQjRiWEJIT21keVpXVnVQU0kwTlNJZ2VHMXdSenBpYkhWbFBTSXhORFFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU5UQWdUVDB4TURBZ1dUMHdJRXM5TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRTBOQ0lnZUcxd1J6cG5jbVZsYmowaU16a2lJSGh0Y0VjNllteDFaVDBpTVRReUlpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSkRQVE0xSUUwOU1UQXdJRms5TXpVZ1N6MHhNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpFMU9DSWdlRzF3UnpwbmNtVmxiajBpTXpFaUlIaHRjRWM2WW14MVpUMGlPVGtpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU1UQWdUVDB4TURBZ1dUMDFNQ0JMUFRBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2Y21Wa1BTSXlNVGNpSUhodGNFYzZaM0psWlc0OUlqSTRJaUI0YlhCSE9tSnNkV1U5SWpreUlpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSkRQVEFnVFQwNU5TQlpQVEl3SUVzOU1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakl6TmlJZ2VHMXdSenBuY21WbGJqMGlOREVpSUhodGNFYzZZbXgxWlQwaU1USXpJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRJMUlFMDlNalVnV1QwME1DQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeE9UTWlJSGh0Y0VjNlozSmxaVzQ5SWpFNE1DSWdlRzF3UnpwaWJIVmxQU0l4TlRRaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlOREFnVFQwME5TQlpQVFV3SUVzOU5TSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakUxTkNJZ2VHMXdSenBuY21WbGJqMGlNVE15SWlCNGJYQkhPbUpzZFdVOUlqRXlNU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowMU1DQk5QVFV3SUZrOU5qQWdTejB5TlNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRXhNeUlnZUcxd1J6cG5jbVZsYmowaU1UQXhJaUI0YlhCSE9tSnNkV1U5SWpnNElpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSkRQVFUxSUUwOU5qQWdXVDAyTlNCTFBUUXdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpT1RBaUlIaHRjRWM2WjNKbFpXNDlJamMwSWlCNGJYQkhPbUpzZFdVOUlqWTJJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRJMUlFMDlOREFnV1QwMk5TQkxQVEFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZjbVZrUFNJeE9UVWlJSGh0Y0VjNlozSmxaVzQ5SWpFMU15SWdlRzF3UnpwaWJIVmxQU0l4TURjaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlNekFnVFQwMU1DQlpQVGMxSUVzOU1UQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmNtVmtQU0l4TmpnaUlIaHRjRWM2WjNKbFpXNDlJakV5TkNJZ2VHMXdSenBpYkhWbFBTSTNPU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowek5TQk5QVFl3SUZrOU9EQWdTejB5TlNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRXpPQ0lnZUcxd1J6cG5jbVZsYmowaU9UTWlJSGh0Y0VjNllteDFaVDBpTlRraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlOREFnVFQwMk5TQlpQVGt3SUVzOU16VWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmNtVmtQU0l4TVRjaUlIaHRjRWM2WjNKbFpXNDlJamMySWlCNGJYQkhPbUpzZFdVOUlqUXdJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pEUFRRd0lFMDlOekFnV1QweE1EQWdTejAxTUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqazJJaUI0YlhCSE9tZHlaV1Z1UFNJMU5pSWdlRzF3UnpwaWJIVmxQU0l4T1NJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MDFNQ0JOUFRjd0lGazlPREFnU3owM01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJalU1SWlCNGJYQkhPbWR5WldWdVBTSXpOU0lnZUcxd1J6cGliSFZsUFNJeU1DSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejAzTXlCTlBUUXdJRms5TUNCTFBUQWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cDBhVzUwUFNJeE1EQXVNREF3TURBd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenB5WldROUlqY3dJaUI0YlhCSE9tZHlaV1Z1UFNJeE16UWlJSGh0Y0VjNllteDFaVDBpTVRrNElpOCtJRHh5WkdZNmJHa2dlRzF3UnpwemQyRjBZMmhPWVcxbFBTSlNQVFl3SUVjOU9ERWdRajB4TXpNaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpZd0lpQjRiWEJIT21keVpXVnVQU0k0TVNJZ2VHMXdSenBpYkhWbFBTSXhNek1pTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1USTJJRWM5TVRZM0lFSTlNakl6SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l4TWpZaUlIaHRjRWM2WjNKbFpXNDlJakUyTlNJZ2VHMXdSenBpYkhWbFBTSXlNVFVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1UWTFJRWM5TWpBeklFSTlNak01SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l4TmpZaUlIaHRjRWM2WjNKbFpXNDlJakl3TWlJZ2VHMXdSenBpYkhWbFBTSXlNelVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qQTVJRWM5TWpJMUlFSTlNalF5SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TURnaUlIaHRjRWM2WjNKbFpXNDlJakl5TlNJZ2VHMXdSenBpYkhWbFBTSXlOREVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qUTFJRWM5TWpRM0lFSTlNalE1SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TkRRaUlIaHRjRWM2WjNKbFpXNDlJakkwTmlJZ2VHMXdSenBpYkhWbFBTSXlORGdpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qUTNJRWM5TVRZMklFSTlNVEEySWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TkRjaUlIaHRjRWM2WjNKbFpXNDlJakUyTmlJZ2VHMXdSenBpYkhWbFBTSXhNRFlpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1qVWdSejB5T0NCQ1BUWXdJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlOQ0lnZUcxd1J6cG5jbVZsYmowaU1qY2lJSGh0Y0VjNllteDFaVDBpTlRraUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlsSTlOelFnUnoweE1ERWdRajB4TmpNaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpjMElpQjRiWEJIT21keVpXVnVQU0l4TURFaUlIaHRjRWM2WW14MVpUMGlNVFl6SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUa3pJRWM5TVRJMUlFSTlNVGt3SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0k1TXlJZ2VHMXdSenBuY21WbGJqMGlNVEkxSWlCNGJYQkhPbUpzZFdVOUlqRTVNQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWoweU5UVWdSejB5TURVZ1FqMHpNeUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPblJwYm5ROUlqRXdNQzR3TURBd01EQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25KbFpEMGlNalUxSWlCNGJYQkhPbWR5WldWdVBTSXlNRFVpSUhodGNFYzZZbXgxWlQwaU16SWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJbEk5TWpBNUlFYzlNakV4SUVJOU1qRXlJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlNRGtpSUhodGNFYzZaM0psWlc0OUlqSXhNU0lnZUcxd1J6cGliSFZsUFNJeU1URWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa2RzYjJKaGJDQkRiMnh2Y2lJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTWpVeElpQjRiWEJIT21keVpXVnVQU0l5TURnaUlIaHRjRWM2WW14MVpUMGlNalFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1DQkhQVGMySUVJOU1URTNJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXdJaUI0YlhCSE9tZHlaV1Z1UFNJM05pSWdlRzF3UnpwaWJIVmxQU0l4TVRjaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlsSTlNVEEwSUVjOU1qQTBJRUk5TWpJNUlpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmRHbHVkRDBpTVRBd0xqQXdNREF3TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZjbVZrUFNJeE1EVWlJSGh0Y0VjNlozSmxaVzQ5SWpJd015SWdlRzF3UnpwaWJIVmxQU0l5TWpnaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlsSTlNalV5SUVjOU1UYzRJRUk5TXpFaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJMU1TSWdlRzF3UnpwbmNtVmxiajBpTVRjNElpQjRiWEJIT21Kc2RXVTlJakk0SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKUVFVNVVUMDVGSURJNE1pQkRJaUI0YlhCSE9uUjVjR1U5SWxOUVQxUWlJSGh0Y0VjNmRHbHVkRDBpTVRBd0xqQXdNREF3TUNJZ2VHMXdSenB0YjJSbFBTSk1RVUlpSUhodGNFYzZURDBpTVRBdU9UZ3dNemt5SWlCNGJYQkhPa0U5SWpJaUlIaHRjRWM2UWowaUxUSTJJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0ppYkhWemFDQmpiM0I1SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0l5TkRJaUlIaHRjRWM2WjNKbFpXNDlJakUxTmlJZ2VHMXdSenBpYkhWbFBTSXhOVFlpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU1UQTFJRWM5TWpBNUlFSTlOVElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenAwYVc1MFBTSXhNREF1TURBd01EQXdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpweVpXUTlJakV3TlNJZ2VHMXdSenBuY21WbGJqMGlNakE1SWlCNGJYQkhPbUpzZFdVOUlqVXlJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pTUFRVZ1J6MHhOakFnUWowMk9TSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU5TSWdlRzF3UnpwbmNtVmxiajBpTVRZd0lpQjRiWEJIT21Kc2RXVTlJalk0SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUVTFJRWM5TVRnNElFSTlNVFUxSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kxTkNJZ2VHMXdSenBuY21WbGJqMGlNVGc0SWlCNGJYQkhPbUpzZFdVOUlqRTFOQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowME1TQkhQVFF4SUVJOU1UQTFJR052Y0hraUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpRd0lpQjRiWEJIT21keVpXVnVQU0kwTUNJZ2VHMXdSenBpYkhWbFBTSXhNRFVpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWxJOU5TQkhQVEU1TnlCQ1BUSXhPU0lnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPblJwYm5ROUlqRXdNQzR3TURBd01EQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25KbFpEMGlOU0lnZUcxd1J6cG5jbVZsYmowaU1UazJJaUI0YlhCSE9tSnNkV1U5SWpJeE9TSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlVajB5TlRVZ1J6MDNNeUJDUFRrNUlpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmRHbHVkRDBpTVRBd0xqQXdNREF3TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZjbVZrUFNJeU5UVWlJSGh0Y0VjNlozSmxaVzQ5SWpjeklpQjRiWEJIT21Kc2RXVTlJams0SWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUSTFOU0JIUFRJd015QkNQVEV6T0NJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTWpVMUlpQjRiWEJIT21keVpXVnVQU0l5TURJaUlIaHRjRWM2WW14MVpUMGlNVE0zSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKU1BUWXhJRWM5TVRBMklFSTlNakEwSURRaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpZeElpQjRiWEJIT21keVpXVnVQU0l4TURVaUlIaHRjRWM2WW14MVpUMGlNakEwSWk4K0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKemEybHVJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlORFFpSUhodGNFYzZaM0psWlc0OUlqSXdOeUlnZUcxd1J6cGliSFZsUFNJeE9URWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJbEk5TkRFZ1J6MDBNU0JDUFRFd05TSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU5EQWlJSGh0Y0VjNlozSmxaVzQ5SWpRd0lpQjRiWEJIT21Kc2RXVTlJakV3TlNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMHlNVFFnUnoweE9EUWdRajB4TkRFaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJeE5DSWdlRzF3UnpwbmNtVmxiajBpTVRnMElpQjRiWEJIT21Kc2RXVTlJakUwTUNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMHlOREFnUnoweE9UVWdRajB4TmpnaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJek9TSWdlRzF3UnpwbmNtVmxiajBpTVRrMElpQjRiWEJIT21Kc2RXVTlJakUyTnlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMDJNU0JIUFRFd05pQkNQVEl3TkNJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTmpFaUlIaHRjRWM2WjNKbFpXNDlJakV3TlNJZ2VHMXdSenBpYkhWbFBTSXlNRFFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SW1Kc2RYTm9JaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSXlORElpSUhodGNFYzZaM0psWlc0OUlqRTFOaUlnZUcxd1J6cGliSFZsUFNJeE5UWWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJbEk5TXlCSFBUSXlOQ0JDUFRFNU55SWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU15SWdlRzF3UnpwbmNtVmxiajBpTWpJeklpQjRiWEJIT21Kc2RXVTlJakU1TmlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMDFJRWM5TVRreklFSTlNakUwSWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kwSWlCNGJYQkhPbWR5WldWdVBTSXhPVElpSUhodGNFYzZZbXgxWlQwaU1qRTBJaTgrSUR4eVpHWTZiR2tnZUcxd1J6cHpkMkYwWTJoT1lXMWxQU0pTUFRjd0lFYzlNVGN5SUVJOU1UazFJaUI0YlhCSE9uUjVjR1U5SWxCU1QwTkZVMU1pSUhodGNFYzZkR2x1ZEQwaU1UQXdMakF3TURBd01DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2Y21Wa1BTSTNNQ0lnZUcxd1J6cG5jbVZsYmowaU1UY3lJaUI0YlhCSE9tSnNkV1U5SWpFNU5TSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlVajB5TXlCSFBUSXpJRUk5TlRFaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpwMGFXNTBQU0l4TURBdU1EQXdNREF3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cHlaV1E5SWpJeUlpQjRiWEJIT21keVpXVnVQU0l5TWlJZ2VHMXdSenBpYkhWbFBTSTFNU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowMk1TQkhQVEV3TmlCQ1BUSXdOQ0F5SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kzTVNJZ2VHMXdSenBuY21WbGJqMGlNVEExSWlCNGJYQkhPbUpzZFdVOUlqRTNPQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowMk1TQkhQVEV3TmlCQ1BUSXdOQ0F6SWlCNGJYQkhPblI1Y0dVOUlsQlNUME5GVTFNaUlIaHRjRWM2ZEdsdWREMGlNVEF3TGpBd01EQXdNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmNtVmtQU0kzTVNJZ2VHMXdSenBuY21WbGJqMGlNVEExSWlCNGJYQkhPbUpzZFdVOUlqRTNPQ0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpVWowME1TQkhQVFF4SUVJOU1UQTFJR052Y0hrZ01pSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uUnBiblE5SWpFd01DNHdNREF3TURBaUlIaHRjRWM2Ylc5a1pUMGlVa2RDSWlCNGJYQkhPbkpsWkQwaU5ERWlJSGh0Y0VjNlozSmxaVzQ5SWpReUlpQjRiWEJIT21Kc2RXVTlJakV3TkNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVVqMHlOVEFnUnoweE56WWdRajB5T1NJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25ScGJuUTlJakV3TUM0d01EQXdNREFpSUhodGNFYzZiVzlrWlQwaVVrZENJaUI0YlhCSE9uSmxaRDBpTWpVd0lpQjRiWEJIT21keVpXVnVQU0l4TnpZaUlIaHRjRWM2WW14MVpUMGlNamtpTHo0Z1BDOXlaR1k2VTJWeFBpQThMM2h0Y0VjNlEyOXNiM0poYm5SelBpQThMM0prWmpwRVpYTmpjbWx3ZEdsdmJqNGdQQzl5WkdZNmJHaytJRHh5WkdZNmJHaytJRHh5WkdZNlJHVnpZM0pwY0hScGIyNGdlRzF3UnpwbmNtOTFjRTVoYldVOUlrZHlZWGx6SWlCNGJYQkhPbWR5YjNWd1ZIbHdaVDBpTVNJK0lEeDRiWEJIT2tOdmJHOXlZVzUwY3o0Z1BISmtaanBUWlhFK0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUQWdUVDB3SUZrOU1DQkxQVEV3TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqTTFJaUI0YlhCSE9tZHlaV1Z1UFNJek1TSWdlRzF3UnpwaWJIVmxQU0l6TWlJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejA1TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqWTBJaUI0YlhCSE9tZHlaV1Z1UFNJMk5DSWdlRzF3UnpwaWJIVmxQU0kyTlNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejA0TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqZzRJaUI0YlhCSE9tZHlaV1Z1UFNJNE9TSWdlRzF3UnpwaWJIVmxQU0k1TVNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejAzTUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRXdPU0lnZUcxd1J6cG5jbVZsYmowaU1URXdJaUI0YlhCSE9tSnNkV1U5SWpFeE1pSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU1DQlpQVEFnU3owMk1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakV5T0NJZ2VHMXdSenBuY21WbGJqMGlNVEk1SWlCNGJYQkhPbUpzZFdVOUlqRXpNaUl2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowd0lFMDlNQ0JaUFRBZ1N6MDFNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpFME5pSWdlRzF3UnpwbmNtVmxiajBpTVRRNElpQjRiWEJIT21Kc2RXVTlJakUxTVNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejAwTUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqRTJOaUlnZUcxd1J6cG5jbVZsYmowaU1UWTRJaUI0YlhCSE9tSnNkV1U5SWpFM01TSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU1DQlpQVEFnU3owek1DSWdlRzF3UnpwdGIyUmxQU0pTUjBJaUlIaHRjRWM2ZEhsd1pUMGlVRkpQUTBWVFV5SWdlRzF3UnpweVpXUTlJakU0TnlJZ2VHMXdSenBuY21WbGJqMGlNVGc1SWlCNGJYQkhPbUpzZFdVOUlqRTVNU0l2UGlBOGNtUm1PbXhwSUhodGNFYzZjM2RoZEdOb1RtRnRaVDBpUXowd0lFMDlNQ0JaUFRBZ1N6MHlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpJd09DSWdlRzF3UnpwbmNtVmxiajBpTWpFd0lpQjRiWEJIT21Kc2RXVTlJakl4TVNJdlBpQThjbVJtT214cElIaHRjRWM2YzNkaGRHTm9UbUZ0WlQwaVF6MHdJRTA5TUNCWlBUQWdTejB4TUNJZ2VHMXdSenB0YjJSbFBTSlNSMElpSUhodGNFYzZkSGx3WlQwaVVGSlBRMFZUVXlJZ2VHMXdSenB5WldROUlqSXpNQ0lnZUcxd1J6cG5jbVZsYmowaU1qTXhJaUI0YlhCSE9tSnNkV1U5SWpJek1pSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU1DQlpQVEFnU3owMUlpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlNalF4SWlCNGJYQkhPbWR5WldWdVBTSXlOREVpSUhodGNFYzZZbXgxWlQwaU1qUXlJaTgrSUR3dmNtUm1PbE5sY1Q0Z1BDOTRiWEJIT2tOdmJHOXlZVzUwY3o0Z1BDOXlaR1k2UkdWelkzSnBjSFJwYjI0K0lEd3ZjbVJtT214cFBpQThjbVJtT214cFBpQThjbVJtT2tSbGMyTnlhWEIwYVc5dUlIaHRjRWM2WjNKdmRYQk9ZVzFsUFNKQ2NtbG5hSFJ6SWlCNGJYQkhPbWR5YjNWd1ZIbHdaVDBpTVNJK0lEeDRiWEJIT2tOdmJHOXlZVzUwY3o0Z1BISmtaanBUWlhFK0lEeHlaR1k2YkdrZ2VHMXdSenB6ZDJGMFkyaE9ZVzFsUFNKRFBUQWdUVDB4TURBZ1dUMHhNREFnU3owd0lpQjRiWEJIT20xdlpHVTlJbEpIUWlJZ2VHMXdSenAwZVhCbFBTSlFVazlEUlZOVElpQjRiWEJIT25KbFpEMGlNak0ySWlCNGJYQkhPbWR5WldWdVBTSXlPQ0lnZUcxd1J6cGliSFZsUFNJek5pSXZQaUE4Y21SbU9teHBJSGh0Y0VjNmMzZGhkR05vVG1GdFpUMGlRejB3SUUwOU56VWdXVDB4TURBZ1N6MHdJaUI0YlhCSE9tMXZaR1U5SWxKSFFpSWdlRzF3UnpwMGVYQmxQU0pRVWs5RFJWTlRJaUI0YlhCSE9uSmxaRDBpTWpReElpQjRiWEJIT21keVpXVnVQU0l4TURFaUlIaHRjRWM2WW14MVpUMGlNelFpTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU1DQk5QVEV3SUZrOU9UVWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU1qVTFJaUI0YlhCSE9tZHlaV1Z1UFNJeU1qRWlJSGh0Y0VjNllteDFaVDBpTWpFaUx6NGdQSEprWmpwc2FTQjRiWEJIT25OM1lYUmphRTVoYldVOUlrTTlPRFVnVFQweE1DQlpQVEV3TUNCTFBUQWlJSGh0Y0VjNmJXOWtaVDBpVWtkQ0lpQjRiWEJIT25SNWNHVTlJbEJTVDBORlUxTWlJSGh0Y0VjNmNtVmtQU0l3SWlCNGJYQkhPbWR5WldWdVBTSXhOakVpSUhodGNFYzZZbXgxWlQwaU56VWlMejRnUEhKa1pqcHNhU0I0YlhCSE9uTjNZWFJqYUU1aGJXVTlJa005TVRBd0lFMDlPVEFnV1Qwd0lFczlNQ0lnZUcxd1J6cHRiMlJsUFNKU1IwSWlJSGh0Y0VjNmRIbHdaVDBpVUZKUFEwVlRVeUlnZUcxd1J6cHlaV1E5SWpNMElpQjRiWEJIT21keVpXVnVQU0kyTXlJZ2VHMXdSenBpYkhWbFBTSXhOVE1pTHo0Z1BISmtaanBzYVNCNGJYQkhPbk4zWVhSamFFNWhiV1U5SWtNOU5qQWdUVDA1TUNCWlBUQWdTejB3SWlCNGJYQkhPbTF2WkdVOUlsSkhRaUlnZUcxd1J6cDBlWEJsUFNKUVVrOURSVk5USWlCNGJYQkhPbkpsWkQwaU1USTNJaUI0YlhCSE9tZHlaV1Z1UFNJMk15SWdlRzF3UnpwaWJIVmxQU0l4TlRFaUx6NGdQQzl5WkdZNlUyVnhQaUE4TDNodGNFYzZRMjlzYjNKaGJuUnpQaUE4TDNKa1pqcEVaWE5qY21sd2RHbHZiajRnUEM5eVpHWTZiR2srSUR3dmNtUm1PbE5sY1Q0Z1BDOTRiWEJVVUdjNlUzZGhkR05vUjNKdmRYQnpQaUE4TDNKa1pqcEVaWE5qY21sd2RHbHZiajRnUEM5eVpHWTZVa1JHUGlBOEwzZzZlRzF3YldWMFlUNGdQRDk0Y0dGamEyVjBJR1Z1WkQwaWNpSS9QcmVTYWlRQUFPZjNTVVJCVkhqYTdOMTVmQnQ1WWZmeDcyZ2syWkx2SzNZYzU4NG0yZnZDQzNqWlpZRnR1TUpWZURpNmZUamJSNVJDb1MwRmFsb29GTEt3UUV0TGFURXRCUW90eDVhamtIS1lMTHZMN21ZUHNmZm12aDNaam84NDhXM0xPcDQvUnQ0NGlROUpIa2tqNmZQZWx6YUpMWTFtZnZNYnpjeFh2OE9JeCtNQ0FBQUFBQUJBWnJrb0FnQUFBQUFBZ013amhBRUFBQUFBQU1nQ1FoZ0FBQUFBQUlBc0lJUUJBQUFBQUFESUFrSVlBQUFBQUFDQUxDQ0VBUUFBQUFBQXlBSkNHQUFBQUFBQWdDd2doQUVBQUFBQUFNZ0NRaGdBQUFBQUFJQXNJSVFCQUFBQUFBRElBa0lZQUFBQUFBQ0FMQ0NFQVFBQUFBQUF5QUpDR0FBQUFBQUFnQ3dnaEFFQUFBQUFBTWdDUWhnQUFBQUFBSUFzSUlRQkFBQUFBQURJQWtJWUFBQUFBQUNBTERBb0FnQUFBS0R3QklLaGF5WDlqcVFySmRWTGlrZ2FrclJYMHFPUzd1dG9iWm1tcEFBZ2V3aGhBQUFBZ0FJU0NJWmVKZWtUa3E1ZDRxbGprbjRoNlJ1U2Z0N1IyaEtqOUFBZ3N3aGhBQUFBZ0FJUUNJWXFKZjJicFArVHhzc1BTL3FDcEgvdmFHMEpVNW9Ba0JtRU1BQUFBSUFEQllLaEd5Vk5kTFMyUEo3RWMxc2s3WkswWlpsdmUwVFNuM1cwdHZ5RVBRQUE5aU9FQVFBQUFCd2tFQXg1SlgxSDB1L08vcWlqdGVXcml6eS9SZEo5a3RiWnVCci9JK2tQTzFwYkJ0Z2pBR0FmWmtjQ0FBQUFuT1ZiT2hmQVNOSVhBc0ZRM1h4UERBUkR0YkxHZFZsbjh6cThSdExUZ1dEb0ZuWUhBTmlIRUFZQUFBQndpRUF3OUU1SmI3emd4K1dTZm4rZTU1WksrcW1reXpPME9vMlNkZ1dDb1hlelp3REFIb1F3QUFBQWdBTUVncUVHU1o5ZjROZmJMM2l1SVd0V283WU1yNVlwNlY4Q3dkREgyVU1Bc0h5RU1BQUFBSUF6L0xXa21nVitkM01nR1BMTitmZm5KYjBwaSt2Mk40Rmc2QlBzSWdCWUhrSVlBQUFBSU1jQ3dkQWFTWXQxKy9GS3VqTHgzRTlJK3JNY3JPYkhBc0hRZTlsYkFKQStRaGdBQUFBZzl6NGl5YlBFYzE0YUNJYnVsUFN4SEs3blB3U0NvWmV3dXdBZ1BVeFJEUUFBQU9SUUlCaHFrblJNVW1tZXJISy9wR3M3V2x0NjJIc0FrQnBhd2dBQUFBQzU5VWZLbndCR2tsWkkrcy9FNE1BQWdCUVF3Z0FBQUFBNUVnaUdybEZ1eG5kWnJsc2t2WXM5Q0FDcEliMEdBQUFBc2lnUURHMlU5RTVKYjVHMFBvODM1WXlrclIydExmM3NWUUJJanBzaUFBQUFBREl2RUF5MVNQcWNyS21sQytITDBCcEo3Wkkrd040RmdPVFFFZ1lBQUFESXNFQXc5RkpKZDBxcUtMQk5DMHU2cEtPMXBZdTlEQUJMWTB3WUFBQUFJSU1Dd2RBR1NUOVU0UVV3a3VTVjlFSDJNZ0FraHhBR0FBQUF5S3cva09RdjRPMTdleUFZS21jM0E4RFNDR0VBQUFDQXpHb3U4TzJya0RYSU1BQmdDWVF3QUFBQVFHWWRLWUp0ZkRPN0dRQ1dSZ2dEQUFBQVpOWi9Tb29YK0RiZUhBaUdhdG5WQUxBNFFoZ0FBQUFnZ3pwYVc0NUsrbGFCYjZaYjBpM3NiUUJZSENFTUFBQUFrSGwvSnFtM3dMZXhqZDBNQUlzamhBRUFBQUF5cktPMTViU2s3WkltQ25nenIyRlBBOERpQ0dFQUFBQ0FMT2hvYlhsTTBrY0tlQlBYc1pjQllIR0VNQUFBQUVEMnJDbmdiYXRuOXdMQTRnaGhBQUFBZ094NU5VVUFBTVdMRUFZQUFBRElna0F3dEZIUzVnTGV4R24yTWdBc3prMFJBQUFBQUZueG9nTGZ2a09aZm9QV1c3ZWJrdFpMdWt6U1ZrbnJYQzVYbzlzMEt5VVpzWGg4TUJLSjlFaTZWOUwvQm5mdGpGRHRBRGdKSVF3QUFBQ1FIYmNVK1BiOXpPNEZ0dDY2dlZIU2paS2U3L1Y0WGhTSlJLNk14ZU5lU2FxcHJwcHBhVjdwV2xGZmI1YVdsaWdlajJ0MGRFeTkvZjJSSThkT2ZNRGpkbmUzM3JyOUxjRmRPKytuNmdGd0NrSVlJRWNDd1pBaHlTUEpUQnlMcHF3dWdyTi96bkpKaXMzNWQweFNkTTZma2NTZk14MnRMWEZLRmdBQXg3cXBnTGR0U05MWGxydVExbHUzbHlUSzZhVmVyL2RWNFhCNGl5U3RYdFVjdmZhcXk4MHJ0bTdScHZYcnRIN3RhcFg1L1o2RjduRjYrL3AxeDVlK3N1ckJSMzU3VCt1dDIxOGUzTFh6VjFRL0FFNWdVQVJBNWlVQ0Y1K2tVa2tsaVQ4OUdYaXJHVm45c2FkbUh4MnRMVEgyQUFBQU9iOFdXQ2ZwV0RxdjlabUdKcU9PL3A2bFg5TExFMU53cDZ6MTF1M2xrbDdxY2J2ZkdJdkh0MGVqVVgvVGlvYklqYzl0ZFQvMyttdDAzVlZYcUxLaUl1WGx4dUp4dGYvdForSy9lZkNSc1Vna2NrbHcxODYrVkpjUi92SHErbUd6L3NZN3EvNjg0VW5mTGRXSmE2MkhPbHBiSHFaV0EwZ0hJUXh5ZVRGeTRjRFE4VUpxeVJFSWhyeVN5aVdWeVFwZGNuVzhUVXFha0RUZTBkb3lSYzBEQUNBbjF3WC9WOUovcFBvNmx5Rjk5dW9tSFJnSmEvZmdoUGFPT081VS9vQ2syenBhVzA2azhxSkU4UElhcjhkeld5UWF2VFVlajNzdTNid3A5dUtiMmx3dmVrR2JWcTlxdG1YbHhpY205THEzL21GMFpIVHNYeC91L01rZkxmYmM4STlYRzVJMlNMcEswcldTdHA1eXI5djAxYnJQYlJod3QxUmQ4UFJISlAxQlIydkwwOVJ1QUtrZ2hFRW1MelpNV2EwK1NpUjVaYlg4Y0NjZUM4M01GZGU1TGpZek90ZXlZN3FqdFNXY0I5dnNsVlFwcVVLWmFlbXlYQkZKbzVKR09scGJtTUVBQUlEc1hTUDh2YVFQcFBxNlRlVmVmWEJydzdQL1BoT082cmREazNyazlMaE9UdVp1ek5uSXhIamM3Zk8vWDRieHp4MnRMZEZVWHZ1OGw3N21VNUkrR0l2RnZOZGRmV1g4SlRmZDZIcmhqYzlUUTExdGVpc1RqeWcrK0tCRyt4N1JiMTFYNnlGZG9ZbW9vWVlTVTlmWCtIVHMzbC9weS8vNjlYQXNGbHNSM0xWeldKTENQMTVkSlN0c3VWTFMxWFArWHBhNDl1dzVYSEx0Mlgrcy8vSzE4WVZ2bWNZbHZicWp0ZVhYMUhBQXlTS0VnWjBYRjRZa2YrTGs1WmNWdk5ncEtxdFZ4N2lzVmgwUkIyMTNoYVJxV1MxZThzVzBwR0ZaZ1F4ZGxnQUF5T3oxd2oyU1hwanE2N1kzVjJoN2MrVzh2enNUanVySnMxTjY4c3lFRG81T0s1cUZTM3QvTkt3am5UdlYvL0J2RkoyZTJoemN0VE9sR1pGYWI5M3VkcnZkSTl1M3ZjUVhlTnR0cXF1dFNmSHE1YlRpSS9zVkg5bW4rUEJleFVjUFNQR1lCc3htZmE3MHc1b3d5aTU2U1pNN3FzbnZmbEJ2WFBmMEQ2OWFPZTZSRmJpc1hlUmQ5bzY3cWp6dEszOTJTV3pCN3cyZk5TYXB0YU8xWlQrMUhFQXlHSmdYZGx4VStHVzEvaWlYbGo1VExZT1plSS95eFB0T1NSckpWWWlRNkU1Vkl5dDhNZk53MTVWSVdpR3BQaEFNRFVzNjQ1UmdDd0NBQW5UTmZELzB1Z3k5cnFWU045VDY1WFlaZXVyc2xPNDhlVllqTTlhbHpkYktoYi9mcWZHYXVtVkZtVzVaVWFaSVBLN2o0ek02TkRxdG82TlRPam82cmZHNFBhRk1neXVtSyt2SzFGcGZyblZsWHIzMUc0ZlZPejAxdTAycFRrdTlNUktKK0Y3N2lwY3VIc0RFSW9xUEhrd0VMbnV0UDRmM1NkTUQ1ejNOS04rb0ljOXEvYTN2YjdSUVlISXFZcXI2ZGUxYU5mRHUzMVYwZktuMWUwYlNwZjljOS9jRHNlUXVhOHNsZlRjUURMVjJ0TGJNVU0wQkxJVVFCc3NKSUNvVElVU3V1dDJVSmg0TmdXQm9KQkVpaExPMDdUV0poNnNBZHVlellWSWdHRG9yd2hnQUFPeStkbGd2cWVxaUMzSEQwQWMyMTJ0RCtibkd3NjIxUHEwcjgrZ3ord1kwSFkxclhWbHlsMWx1dzlDbWNxODJsWHVsbGRZZ3R1T1JtSHFuSXVxYmltaG9PcUl6TTFHTnpNUTBHWTFwTWhyWFZDU211T0p5dTF3cU5RMzVUSmNxUEM3VmVFelZsN2kxeXVkV2k5OGpuM24rNWM2V1RSdDE0UEJSeVdwUmNtZUt4VkVuU1RYVjU0b2pQdFVuamV4VGZIamZ1ZEJsOUlnVVgveHl4S2krVXJIeGsvcjd5bi9VVW9ISldiTkJYNjI3UXg4Y2VLYzg4VVV2Rnh0Q25zMVBkbmt2dlM2RmJicGEwbnNrL1FPMUhjQ1NuOWNVQVZLOGlEQmt0ZnlvbFhOYWZ4aUpDNXVxUURBMEt1bDBKc0tZeExaWEpTNGV6QUxjdlliT2hURkRrb2FZOGhvQUFGdGNQdDhQWDcycThyd0E1dGtVb01TdE42MnUwcjBENDNJYjZiZG1LWE83emdVek5sclQ4dXlndVJ0U2ZlMXJyemhkTVJNMTVEdjZPVVVPbjFSOFpKOFVQcFA2U25ockZSL2Vxd2VxMzZvemhqV1dUUFBNRVVVTlV5V3hTZlY1MW1yYThKLzNraDdQUnYyODRsMTY5Y2kvTExUVS9aSzIvcmpxZmVtMGFQbUxRREQwWmI3SUFyQVVRaGlrRWtKVVNHcHdlTDJwa0ZTUmFORnhPdFdCNGhiWmRwK2tSdGsvem8wVEdiS0NwcXBBTURUUTBkb3lTdTBIQUdCWkxnb3JhcnltWHRKWXR1QUxicWp6YXpUaXpDSGJWcTFzV25DN0ZwS1llZWh2NGdxMUc1TFUvejB0NTV1ZVdPbEt4V016K20vZk81NzlXVnlHK3R6ckpFbmUrSlJXemh4VnIrZjhWZngxK1Z0MDAvZ1BWUk9kZDdicXNiaGN3d2RMcm10SnAxZ2t2VWJTRDZqdUFCYmpvZ2lRUkFEaENRUkRMWkpXS24rQ3UycEo2eExCMFhLMjNSVUloaG9sclZaeEJEQnp1U1d0REFSRHpZRmdpTUFXQUlEMHJidndCeTlzS0pPNVJDdVhxNnVkT2Q3L25CQm1Vd292KzZTa2p4azJYRXZHSlVYT0hOQVJZN09paGlkeFV4UFRLYy82WjU4VE5rclY2OW1nbFpGajU3MDJhbmgwZC9sYkZscDBTNTk3N2RGNEdyZEk4V2hNWTZHQjkxTFZBU1J6a3dVc0ZrSlV5aHE4TlI4RE96TVJJcFJMNmsrMVZVeGl3T0VtamhPVlMvSUhncUUrV3NVQUFKQ1dpMXFNWEZ2alcvSkZ0VjVuWG9JMHJuaDJ5dXo2MWx1M2U0SzdkczVJVXV0THRwZExxazg4YWhPUHV1ZXRIYTJYanJiYjlmNzlFeFZxOUkvcXliSnprMDNWUmJvMTRGNTkzdk5LWStNNjQxcHgwZXNmOGI5TXJ4MytSN2wwWGt1akdVbE54N3hYZEtXNlBtTTlnenI5MUJISlpkd1VDSVpjekRvSllER0VNRmdvZ0RCa2RiK3BMSUROcVpEa0N3UkRQUjJ0TFZOSmJ2L3N4UU1zTGxtQlZwbXNRSXVMQ3dBQWtyZHU3ajlxdktZYVM1ZStESGNaemxqNVl5ZE9hdStCZ3hvNmMxWm5SMFkxUERLcU9YMkpubWw5eWZaS1dWMlo1eDFGK0pybXNhZGs0eGQ2STlNZXJmQWJlc1QvaW1kLzVvOWQvRDFSVlhSUWZaN3paNktPeCtQcVBqcXFwM3pYNnhvRjUvNXFRRkp6bjJkdDBpMmZ3eU1UR256cXNDYjZueDNUeGh6ckhuaU9wRWVvOGdBV1FnaUQrUUlJajZSbVdWTVlGMUpkWHgwSWh2bzdXbHVHRjlsMlUxYTNLejgxWVY2Vmtrb1RnVmFZNGdBQUlDa05jLy9SNHZQa3hVb2ZQSEpVbi9uaVArdVpmUWNXZTlybXhYNXBTR052dkdid1Nqdlh5Nldvb25KcnlqZzNwazdjT0Qvam1XODhtTW4rTXhwNDZyRENJeE82NzhybjZSci9lU0hNc0tUbVFiT2xiS24zajgxRU5MVHZoSWFQZENzZVAzOWttNW5SeVRZUndnQlk0c1lVbUJ0Q2xNZ2FXS3dRNjRZaHFURVFESGs2V2xzR2kyemI3ZVNWdENZUURQVjJ0TGFNVXh3QUFDeXBadTQvNmt1Y2Y2bHgrT2h4L2VIN1A2ekpxYWxsTGFlbGV2cHdpVHQyalozclZ1cU9hTVoxL25nNTAwYnBuQXUrdUVaZDV4bzB6MHhNNmZSVFJ6VFdjKzd5NzlEb3lndS9jbHU2bFc5Y0dqbHhTcWYzSEZWMGV2NEpsS0l6TTFkUTNaRXZMZ3dSOCtLR3pqRHl2dHdabUJkelF3aS9yQUZvQ3oyRXFBMEVRMDBYYkh0WmtXeTduWjhkcXdMQlVEVkZBUURBb3RkWEpaTE9Hd0Ntek8zc200aG9OS3EvL052UExEdUFrYVRuckI2YnNYdjl5cjFSelZ3d1gwSjBUaytvbHBsREdqT3JGWS9HTkxUdnVMcCtGVHd2Z0pHa00xTVhqY25qbGFUUytOaThMWDJuaGtZVXV1Y3g5VDkyWU1FQXhycXJGZGRHQUJiRkRTZG1MeEQ4c2xxQkdFV3l5WldKY1c5T3lSb3pwb2xha0pZVmdXRElQVi9MSWdBQUlPbUNWakNTNUhVNSszdlFYZmZlcnhNbnUyMVoxdnJhS2R1N3QwOUhYU3BUNUx5ZlJZeHpJY3l3V2F1eDdnRU5QbjFVa1luNWc2U0pxWXYyUWFra2xjZk9ucGV3UktmRE92M01NWTJjT0pYY3loa0c5MWNBRnNXSEJJb3hnSmxWSWV0Ymp4SnF3YkxVQm9JaHM2TzFwWStpQUFCQTg5N2N6eFdPT2JzTHdLL3V1YysyWmEyc0RKZlp2WDZ4V0Z4elJ3YVdKSGZjeWs3OFowOW8zOU5uTlRsd2R2RmxYTHdMbWlTcFplWlFXSkxpc2JpR2ozUnJhUDl4eFdaU21tQnpoaW9QWURHRU1FVXUwVVMyV2NVWHdNd2lnTEZIVldKS3hsNktBZ0NBeFkxSG5EM0o0SUZEUjJ4YjF1U015L1pRWW13cXJ2cUt5Zk4rWm9Rbk5MajNjR0t3M0tXWEVZOWU5Q1NQcEltVk0wZk5pYjR6R256cXNNS2pFeW12bTh0dG5xQ0dBMWowYzRJaUtGNkJZTWd0cXdVTTlRQjJxQWdFUTQwVUF3QUFpK3ViaWpoNi9RWk9EOW0yck5GcDAvWVFabUk2Sm5kOFJtWThZZzJXZTd4WGovNzZsTTRlVGk2QWtTU1hPZStQand3T2FXUFBBMCtsRmNCSWtydlUrelExSE1DaW56OFVRWEZLaklmU0xGcER3VjVWZ1dDb25tSUFBR0Job1VsbjkxaHgyVGhtelpIQjBpbmIxOCt3V2hJMTlBVjE4cDdIMVAvWVFZWERxYlV1S2l1ZDkvbmhTOHVPVjd0Y1Jscjl4VXl2Ui83RzJwOVF3d0VzK2hsR0VSU3RGWnFuanpKZ2c5cEFNRlJGTVFBQUlFbTZxRW5GeUV4VTNRNE9ZbGJVMTltMnJIMzlmdHU3dkxkVVcyTzBkRDB6b09rem8rbGRySlJPenZmalRWN1hUSHhMYlg5YVRZRkthaXFHdnZiQ2pXZW84Z0FXUXdoVGhBTEJVSVVrYnBLUjBldTN4SURQQUFBVXUzbHZ5aDg1UGVuWUZiNTA4eWJibG5Wb3dMZkc3dldyOXNkMWV0eWw1MVU5bGZZeXJxcVlkOXliS2tsUHZYUEZENzNwTExPa3V2d1hWSGNBU3lHRUtUS0pjV0JXVUJMSU1FTlNjeUFZOGxBVUFJQmkxdEhhTWlOcC9NS2Yzejg0cnFtb00yZEpldEZOYmJZdEt4SXpWandXS3UrMmV4Mjd6eGg2WmQzdXRLOVNYbEoyNzBLL3JidWk0bGpGbXByeGtWUVc2ZmFWeE11YWF2K0NHZzlnS1lRd3hXZUZKSk5pUUpZK1g1b1Q0dzhCQUZETVRsLzRnL0ZJVEQ4SURjLzc1RnpQWVAyU20yL1V1dFV0dGkzdm54NW83ck43SGJjMkc2cjNEdXY2aHE2VVg5dlE0Tlk2TFRnRFZJdWt4LzltN1QrN1hXYnlZOE5VckY2eDg1c3Z1N3lIcWc0Z21ac2tGSWxBTUZRbXFaeVNRQmFWaUpaWEFBQWNuKytIOXcyTXEvUFUySGsvbTRuRjlaT2VrWnl1ckdtYSt0UmYvWVhLL1BiMExEN1E3N3QyN3lsL3I1M3I2SFZGWk5aY29VRHpqNVRxT01LdlgzbmZVays1Y21YSjZZSDNyUC9wcVdTVzUydW9IcXZhMVBKbXFqbUFaREF6VHBGSXRFWm9vQ1NRQTFXQllHaWlvN1ZsbEtJQUFCU3BvNUp1bnU4WFB3d042L0V6azdxeXVsVFQwYmlDUXhNeURVT3ZYVldaMHhYZXZIR0QvdTBmNzlBWHZ2eFYvZmJ4UmNkZTJTdHBRTktncENGWnJYNkdFbytCMlg5NzNiRkxKUDNBenZ1UCtQQWVyYWxwMEp2WFA2Ny9Pbkp0VXE5WnNjTFVhMHIvSjVsN3BMcFgxdDEvZGlSYTN2T3Q0eTlxamk4dzkzVkpkWG00ZXVPcW03NTIwNFlKcWptQVpOQk5vRWdrWnF0cHBDU1FJMUZKSnpwYVd5Sno2cVFwcTJ1Y0lhdFZucEY0eEJPUHFLU1lwR2hIYTB1Y0lnUUE1UEYxMkVjbGZTclo1NXVHb1M5ZDF5eVhRNjdVend3UGEyRFE2bEZWVlZtcHJsQzMvdmhEZnlWSko0TzdkaVk5OEc3NHg2di9yNlN2eTg2dThTVjFpa2VuMVg3a2ovWEVxWnBGbitvdWNjZi81b3J2ZmU5NmQzQlUwdXpndTI2ZDMxSzhVdWQ2QzdnbFRUMDVkc25sbis5K1I5WGdXWmR2OWtrdWo2bnk1b1k5NWF0WHZPSmJyN3l5aTFxT2ZMUlF1T2pvQU1QSS93aURsakRGY2VJM0pOVlNFc2doVTlLcVFEQVVrZVJKUEl3VTZuQkUwb3lrc0tScFNWT1NwZ2xuQUFCNTRwbFVuaHlOeDlVek9hTVd2elBHdDYrcHFsSk4xYm1KTlo5NGVzL3NYNCtuc2h6dmEwOStLL3pqMVFjbC9aV2tsMGp5TFh2bHBrL0xWZHFvVDEzeWRYM0s5ZnQ2cUdmK1h0Qm1pVWNsNWNhN24vK0dIMzQxMWJjSS8xaXJ2cldsL1FXL0NkKzgrYituM3VBKzQxNTUwdGRROWIvZitKMUxlNm5hQUZKRkNGTWNLaE0zdlVBdWxTUWU2WDVXdVMrNFdJc0hncUVwU1JPU3hqdGFXNllvWWdDQVF6MlM2Z3YyalV4bkxZU1ppc1lWamNmUG02M0pheHJ5R0laS3pZdS9NK25wZTNhYzNlT3B2cGYzdFNjZmx2UXFTUXIvZUhXVnJDOWxURWtWa3ZUbDNTczNQOUpWOVl1M3YrWDF4dSs4OEFWU0xDeEZaMC94Y2NWbjV2UnVqazVJTWF1UnJUYzZxVStzUHFGNzloN1I5MExYNi9oUWlXS3h1SHpsUGpYVmwyci9MNzg3MWZuRC8vaHFPdVhqZmUzSmJrbmZrLzVUMWdNQTBrY0lVOEFDd1pCUFVyM3MrSllCY0I0alViZDlrdW9Dd2RDTXBGRkpJeDJ0TFdHS0J3RGdGQjJ0TGIyQllDZ2thK2FkcER3d09LNWJtOHJUSGp0Z0poYlg2WEJVcDZjakdncEhOUlNPYW5RbXByTXpVWTFGWWhxWmlXb3lHdGRrTkxib2NseUdWTzUycWFIRXJjWlN0OWFYZVhXMC84enNyNDhzcDF5OHJ6MDVkM3FveEF4U0o0OC9kOXVydjNuSE4rNzl2ODkvOGUrYkZWVmxGNTM4Ri9PU0s2d21Odkc0Tk50cjRUUC84R1h0bXhwN2hwb0l3QWtJWVFwUUlCanl5QnFFbDVtUVVFdzhzcnJkMVFhQ29VbEpaeGtNR0FEZ0lQZExTbm9HblZOVEVmM3kxS2hlMWxTeDRITmljYWwvT3FLK3FkbkhqUHFubytxYmltaGtKbXJMU3NmaTBzaE1UQ016WVIwWkMydjM0SVIwNDNadGF0aWcwNDg5T0tCZE8yMHZxRmdzOXBIeGlZazNmZTNiMy9GOTROMS9rTll5NWc0YnNmZkFvV2c0SEg2UUtnakFDUWhoQ2toaTdKY2FTWFZpMEdVVU41OGtYeUFZcXBmMXpkb280OGNBQUhMczUwb2hoSkdrSDRkR2RHWTZxdWZYKzFYaWNta3dIRkh2WkVUZGt6UHFtWnhSNzJSRWtSd05yRm01K1RLVnJtamFvaTk4M1BabEIzZnQ3R3U5ZGZ2SHZ2dWpuOTd4dWxlKzNGaTdlbFhheTRwRUlqcDg3SVJMMGhOVVFRQk9RQWhUSUFMQlVJbWtKcVUvNWdaUWlEeUo0Nkl1RUF3TmRMUzJqRkVrQUlBYytabXMyZjlTK3FMczNvRngzVHN3N3NnTjhsYlZuTTNnNHYvUmJacnYvZnlYTzlaODZUT2ZUUHZMeGNQSFRpZ1NpUmlTZmtzVkJPQUVMb29nL3dXQ29ScEphMFFBQXl6RUk2azVFQXkxSkxyckFRQ1FWUjJ0TFlPU2RoZlVSaGxHeHJyOUJuZnRESWRuWmdJUFAvcTRjZGR2SGtoN09RY09INUhMNVpxUnRKZGFDTUFKQ0dIeVdDQVljZ1dDb1daWjQ3L1EvUWpGeGtoOGhwbnpQR1puVTdydzV4V1NOZ1NDSWFac0J3RGt3amNMYkh1R003bnc0SzZkdnpSTjg0ZGYrUEpYb3hNVGsya3RZOS9CUS9KNDNIdUN1M1pHcUg0QW5JRHVTSGtxOFczK0trbGVTZ01GeHBEVmNzV2o4d09WMlZERnBlV0hqbXNUMDF2M1NacVdGSm56bUVrOHdoMnRMVnl3QVFEczlEMUovNkRDbWJseU9OTnZFSTFHM3pkMDl1d3IvKzNiM3pILzVQKzlNK1hYUC9iVW5zajBkUGdlcWg0QXB5Q0V5VU9CWUtoVVZnQmpVaHJJYzZhc2JuUWxPaGU4Wkt1N1VLbWsxWklHSkUwdWNLekZKSVVUajZuRVk1cEJmZ0VBNmVob2JSa0pCRVBmbGZTT0F0bWtvU3k4UjFVc0Zpdlp0R0Y5eWkrY25nN3J4TW1RVzFLUTJnZkFLUWhoOGt3Z0dDcVQxQ3k2SHlFL2VXV0ZIeVdKUDNNZEpMb2tOU1l1SWtjVytIMXA0bEdaK0ZrOEVBeE55d3BrSmlSTmRyUzJSTm0xQUlBa2ZVN1Myd3ZrV3U1RUZ0N2o5eHZxNnlJdmU4a3RLZCszbEpSNDVmRjRvdUZ3dUp4cUI4QXBHQk1tandTQ29YSVJ3Q0MvbUpMS1pZMWJ0Q1pSZjJzbGxjbFpMYmxxWlUzdG5neERWaWhUbmRpZWpZRmdhRTBnR0dvSUJFTitkamtBWURFZHJTMzdKUDFQQVd4S1hGSlhwdCtrcE1UNzVoZmYxT1oyR2VsZC9qWTNOY1lrYmFUbUFYQUtXc0xraVVRTG1KVWlnRUYrZks3NFpZVXYrVFJtVVlXc1lIb3djV0daaXRuV01qV0JZQ2dxYVZ6U21LUnh1aTR0KzdQUExhdUwydHlCbG1jSFpKWXUvakloTnVmUG1LVG9uTWVNcEVoSGEwdU1rZ1dRWXg5VFBQNWFHWGw5V1hlMG83VmxPcE52MEhycjlvYnA2ZkNHNTE1M2JkckxXTnZTN09rS2RXK2l5Z0Z3MHMwU25IOFQ0aGN0WU9Cc3BxeldMZmtXdkZ5b0xIRlQzNi9VZzVpNVpWR1plTVFDd2RDWXBKR08xcFlKcXNtaW4zTmVuUnNmYVBidm5neTlWMVRueHZxWlRqeW1DTXdBWk10amYvbnU0VFcvKy91cWIzMUJQbS9HVTFsNGp4c2s2Zkt0bTlOZVFITlRrN3dlejFacUhRQ25JSVRKanhzVEFoZzRrU0ZyZG9meXhKK0ZVa2Q5c3JwUDlkdXdMSmNTZ1V3Z0dJcklHbmRtdUtPMVpZYlB0bENwckJaVFBtVi9mQ0F6OGI2K0M5WnBXdFlnelJPU0ptZ3hBeUNEWHQvYitSUFZYLzBjeVZ1YWxUZGM0L2RvcGMranZxbUloc0pSVFVaam1vbFoyYlBQZEtuR2E2clo1OWJXaWhKTngrSzY4K1NTRXg4OW5vWFZmazU5Ylcya3Byb3E3WHVXNXFaR1JhTFJGcW9jQUtjZ2hISDJUWW9wYXhZa3h1NkJrNWl5dXU1VXFIQm42UEpMcXBmVk5jbk96OXRhU2JXSjFqRm5pNmwxVENBWWN1bGNheW0vUSt2T2JFdWM2c1E2VDhucVZqYlcwZG9TNXRBSFlLUGZuUmtiMFphUmJoMm96ODV3SmMrcDlXdGJVM0xqMC9aTlJaSUpZZTdMOURxN1hLN0xONjVmdTZ6elJkT0tCa1Vpa2NyV1c3ZVhCWGZ0SEtmcUFjZzFRaGhuYTFiMnB1c0ZsdUtSVkpXNGtTNkdsbG5sc3NZUUdjN1Fzc3NEd1ZCWTBobFozWlVLcml0TUlCZ3lFdldsTWsvcnpleFlQL1dKVmpLamlYMFY0ZU1BUUxwYWI5M2VJS2xOa3Q1NDlXYjl6N2hIVDUyZHl2ajdUa1dUYjl4WFgyTEswS0w5Y3FjbFBaVHhHeFczKzRwMWExcVdkZTVvWE5Fdys5YzFrdlpSQXdIa0dpR01jMjllNm5WQlUza2dSN3l5V2dZVTQ4dy9OWklpc2diYXpWVFpOa3FxQ3dSRFE3SzZLdVY5R0pQb1Jsa2xLM3dwbE5aU3M2MWs2Z1BCMElTc2NHNk1jV1FBcE9IbGtseWIxcS9UcXBWTmVsc2twaDM3K25WNk9wclJOKzJaVEw0bnJHa1k4cGt1VFN3YzNOemYwZHFTOGVRb0VvbXNYNzJxZVZuTFdObTRZdmF2YTBVSUE4QUJDR0djZVFQamw5VnRBY2lsWWc1ZjVxcVhOWUJySnNkeGNVdGFJYXVyMGhsWlhaWHk3dVkrOGRsVkk2dlZTeUh6Sng2UnhQNGFadndZQUNsNHFTUTkvNGJySlVsbGJwZitjRU90dm5CZzhOa3hXakpoejhpMGhtZWlxdklrbDQxUEx0NXk1cjh6WFVpdHQyNnZpOFZpcFMwclZ5NXJPVldWRmZKNnZiRndPTHlHcWdmQUNRaGh6dDA4dUdTTnZlS1NubTJCR1pNVXkrYkZkV0k5bXRnanlQSG5RakhjU0NmTGtEVlFiNi9TbnpFcGxiSnZrRlFkQ0laT2Q3UzJqT1RKNTJlNXBEcFpMVVdLN1ZocGtOV1M2YXlrTXgydExWRU9HUUNMQkFzdXpZWXd6N251MlordksvUHFuZXRyOU5ValF4azcwY3pFNHZyR3NUTjY3eVYxTXBlWUduc29IRjFzUFNMS1FnZ2pxVVdTR2xmVUwzdEJLK3Jyb3FHZVhnYm5CZUNZQzhpaUVnaUczRG8zSzRabnpzTlk1RFZ4V2QrQ3p6NG1KVTFtYUZ5QUJoR09JVGRjT3RlRmhObTR6dWVWRlV3TlplbjlQSkthQXNGUWphUUJwdzdnR3dpR3ltUzFGQ3JoMkZHdHJQRHNyS1FoV3NZQVdNQlZrdXBLU3J5Nitvckx6dnZGdFRVK3ZYbHR0YjV6NG16RzNuemZ5TFQrOGVCcHZXTjlqYXE5QzdlSWVmajBvcWVkbjNlMHRneG1vYXlzRUtaaCtTRk00NG9HTTlUVDIwejFBK0FFUlhHem4yZ2lYeUdyK1hnNkE5MGFpWnN3YitMZjFZbmx6c2lheW5UVWpwdWt4SlN0VlZSTDVFQkZJbVJnSnE2RlZTYU85Nmtzdm1lSnBKWkFNRFFxSzR4eHhJQ3dnV0NvUkZaZzdLZGFuR2MyaktrS0JFT0RIYTB0d3hRSmdBdmNMRWxYWFhhcFBPNkxMOE5mMkdBMVFzMWtFSE5nZEZwLy9VeWZicXozNjdsMWZxMHI4NTczemN1VFo2ZjA4OTdSeFJieHBTeVYxZXJTa3BKb2VWblpzc2NXYTZpcmRYbTkzdlZVUHdCT1VMQWhUS0xGUzNYaXhpbFQyems3VzB4VklCaUtTQnFSTlpaRHVqZEtLNmlTeURLUGFNbVFpanBKUGNwOHQ2UUxWVWdxUzl6WW44M1Z4aWU2UzlZblBsdXhNRk5TWXlBWXFwYlUzOUhhTWttUkFNVXRFQXpWZGJTMm5GWWloTG4rNmlzWGZPNExHOHBrR3RKL0hqK2IwYTVKOS9TUDY1NytjZmxObHhwTDNTb3hEUTFPUnpVNHZlaGxiTENqdGVWWFdTcTJodHFhNnFoc0dPQjlSWDI5REVPcnFZa0FuS0RnUXBoRStGS243SGVwY012NkJyUW1FQXlOU0RxZFNoZ1RDSVlxWlUyRkNtU0RvVVNBS0xvZXBjS1QrR3pKUlFzSGw2UVZpYytLdm83V2x1a3NmN2FXeXdxSzZTNlp2QkpKcXdQQjBMQ3Nsa3gwVVFLS1RPS3o4MHVTM3Z6L0h1NzZrOGMvK3A0WFN0SjFpNFF3a3ZTQytqSlZ1azE5N2VpUXBtT1p6ZjBub2pFZEd3OG4rL1NQWnJING1tcXJxMjFwb2J1aXZsYXhhS3lSR2duQUNRcW02MEVnR0hJbHBuVmVuK01ieTltYjIvV0JZS2doOGMzeFV1dHV5QXFPZ0d6d1NtcVcxWnFCQUNaMTFjcnR0TXVsa3RZa3hvdkp4bWVyR1FpR21oTjFoZ0FtUFZXUzFpWEcwQUZRSkFMQjBDcEp1eVc5WFZLcDRYSjl0ZVdWYjZqM2VyMjZiUE9tSlY5L1ZYV3BQbnhwZ3hwS0hQUFIrOE1zdG9LUnkrVmEwYmlpM3BhTnI2dXQxVXdrVXRsNjYzWmEvZ0xJdVlJSVlSSVh0dXRrdFVSeHlrMmxJV3VNaldRdXZDdVUzbGcxUURvM2d5dXBiOHMrdHFzY3NBNE5nV0JvZFNBWXl0aStUSHgyclpWVXptNWZOcmVrVllGZ2FFVWllQWRRd0FMQlVJdWtleVdkMStSbHhRdHUxUlh2K2hPNVBNbDlkRGY3UFByb1pTdDBRMTNPaCtBYWtQVHViTDZoeCtOdXJxNnk1M1E3WjNEZmxkUk9BTG1XMXlGTUlCZ3lBc0hRQ2ttcjVOeHZhR2N2dkJzWGFSVlRTMVZFaHBteXBqNnZFYTFmN0ZDaDNMYUdtZVdUdERiUlJjbnV6OVlHaDMrMjVxdHFXUzJadkJRRlVKZ0N3VkNWcEY5STJqanZFOVpzMHBjT250WmtOTGtlaXFXbW9YZXVyOUVmYnF4VnBTY25sKzRSU1cvcWFHMFp5T3BOaXVHcXI2eXc1enVBbXVwbnc1d21haWlBWE12YkVDYng3ZThhNWM4QWtWV3l4Z2J3WExBZGZwMmJkUW5JMUkzNktqSG1rSjJjMEJwbTd1ZDRVeUxvWFhiQWxoaFhxMFZXWUlmTUtKRVZ4TkRDQ0Nnd2ljL1FIMG02ZkxIbkhSaWQxaGNPREdwNEpwcjBzcSt2OGVuamx6ZnF4U3ZLWlJwWit6NGxKdW50SGEwdGQyZTdMR1B4V0ZWNW1UMjlPT3RxbnoybE5WQkxBZVJhWG43RG1aaktlWldjOFUxME9oZmVQWE5teTZpbUdpS0RxcWxqR1ZNaDZXemlBdFVKcWlTVkJvS2gzbzdXbG5BNkN3Z0VRejVaVGJWcC9aSjVMa25OZ1dCb3FLTzFaWkRpQUZMK3ZESVN4NUZMVmpBKys1anZDOFo0NGhHYjgyZXNvN1VsRXlQZS9yMmtGeVh6eE5ERWpENjdiMEIvc3JsZVRhWEpmZXlXdVYxNjQ1b3EzYktpVEQvcUh0SGpaekk2K2RxMHBMZDJ0TFo4UHhmN09CcU5WVlNVMnhQQ2xKYVV5T3Z4eE1Jek03U0VBWkJ6ZVhlaG5SaWpvRm41MjZYQ2xOUVNDSVo2SlUxS1lxQkdaS3FlMWN0cUJZUE1NQkxINzZpRDFtazI2TzN0YUcwWlQvR3p0VkpTbytpdWxtMjFpYTVKdlJtNklRVHlYaUFZS3BIVm1yTkVWdXRocngzWHNJRmdLQ29wUE9jeEpXa3EzV014RUF5OVM5SjdVM25OVURpcXorMGYwQjl0cXRPbTh1UWJScThvZFN1d3NWYWhpUmwxOW8zcHQwTVRzbmtTcFFPU2ZyK2p0ZVczdWRydmtVakViMWNJSTBrMTFWWFJ2b0ZCV3NJQXlMbThDbUVTVGJkWEZzQk5naUVyU0JybmhnY1o0RW5jVE5PYUlmTXFOSDhJWStyY043U3ozOHJHNWp5aUdWd25sNnh4cUFZNldsdk9KUG5aV2lkbWFNdWxjbG5kVmJzN1dsdWlGQWVLWFNKMDhjOTVaT3BheVpUMVpjWGNMeXppZ1dCb1d0SkU0akdaVENnVENJWnVrUFRQNmF6RWVDU21MeDRZMU52VzE2aTFOclh2VGxyOEhyMXpmWTFldDZwU3V3Y250UHYwdUU1UEwrdGo1S3lrejBqNnh6bXR0ck91OWRidDFaSmtWM2NrU2FxdHFUSDZCZ1pYY0lRQnlMVzh1VWxMdElBcGhBQm1MbHJCd0c0K1NTdEV1SmN0M3NRTmdsdldON1NleEdPcDhvOUxta2s4cGhLUEdadlhyU0hSd3FKL3NSdUlRRERVSkttU1habHpzMU9QaHpwYVcyWW9qcUlQSVl6RVo4bnM1NG83RVJqTUJyeHpQMlBtaHJ1UnhDTXNLZHpSMmhMSm8yMzJ5UXEyeTNOOGZXb2tqc2RTV1JNbnhBTEIwSmlrTVVuajgzMmVCb0toR2tuZjB6TEcrSXZFNC9yYTBTRjFUMWJvMWMyVmNxVjRGcS94bW5wbGM0VmUwVnloa3hNemV2THNwSTZPaFhWOGZDYVpBWUFuSmYxYTBnOGxmYmVqdFdYQ0FWV2lXckkzaEttcnJYYTdESVB1U0FCeUxpOUNtTVFZTVBuY0JRbklobkpaclJrNFRySXJuVy9WREoxclVqOTdoUm1SMVRwdVBIRURaWWNxU1o3RU9GU3hlVzd5bWhJM1BYQUdqNndXTWFGMHgvVkJma29jajdPdFBueXl3aGM3QnRxT3lBcDVKeE1CUXRoaDIyMG1QcWVxRXZYZmlWeXlndXBLU2RGQU1EUXFhYmlqdFdWNnpyNzdwcVIxZHJ6WkwzcEgxVFUrbzNkdXFGRzVPL1g1TXd4SmEvd2VyZkZieFJtWGRDWWMxYWM3dnFrOVhkMHFiV3p1YkxybFpUK1hOQ3hyMnVuRGtnNDdNTENybG13T1lXcHE1UFo0bUtJYVFNNDVQb1JKakRLL2lodExZTW1MbFdxS0llOC9qMmR2UnFZU0Y4aDJOQVgzNjF4WGw4aWNtNFptMFJyUHFmVmdOb2lacGpnS1YrSTRMSmNWaEpabDZEckhuWGlQY2xtdDQyWmtkYUVjeldYOVNuUTNxa2xzZXo1ZDM1bXo1OXRBTURRcDZZeWtnS1JYMmZrbWUwZW05TGQ3K3ZXdURUWGFYRkd5ckdVWmtzcmlVVDM4aS85Vk9CeVdwSS8vejEvOHdVTjVVTlpWa21Uem1EQ1MxYW9lQUhKK3NlZjBDNVJtNWQ4c1NFQTIxU2N1c0ZFNFpwdkNUMHM2cmVXM2pDbVp2YkdYMWVKbWxheHdCczY5MFdzaGlDbE1nV0RJazdpUnI5TDhNL2xra2tkV0Y1dmFRREEwSld2OGo5RnNEUXFkYU5sY3A4SUlnSDJTbmlOci9CVGJEYzlFOWZjSEJuVnJVN2xlM1Z3cGp5djlyT3FSeDUrWURXQzZKVDJjSitWYkxVbmxaZmFkcWlvcktpUXIvQU9BbkhKNlM1ajZ4STBJZ1BrMWlOWU1oYXhFVmhBOUt1c2IxK1ZNaCsyUnRFWldvTU9zV2M0M0c4U2NwR3RTWVVpTTBWUW41M1FCTEpYVkpiRStFQXlka1hRMlUyRk1JbmhxVUdGOVllQ1hOUjExeHE2bDQ1SitkV3BNend4UDZiYTFOU25ObmpUWEF3OEhaLy82djhGZE8vTmxGcllxd3pEaVhxL1h0cFpTbGVYbGlrUWlkTUVGa0hNdXA2NVlZb0EyMG1wZ2ZvYXNzVWdJWUlwRGhhd20xTjVsTG1kMkpoRGtoOWtneGtOUjVLOUFNR1FHZ3FGR1dXT0dPUEVHMEMwcklGa2ZDSVlxYk41Mkl4QU0xU2UydmRCYWJINU0wdHBzdkZIdlpFU2YzeitnL3poK1JpTXpxYzk4OUdEd3NkbS83c3lqOHZXV2xwVFlPbHRjUlVXWllyRllTZXV0MjcwQ2dCeHlaQWlUNkliVXlPNEI1alVid05DZHBMaDRaQVV4ZEQwckxtNVpVNDdUTFRjUEJZS2hLa25ybFJqZklnL3Eyc3BBTUxRNjBXcG51ZHRlbHRqMldoWGV1SDdiSmIwdTIyKzZlM0JDZi8xMG4zYjJqR282bGx5RGxsQlByM3I3K2lWcjlxeTc4NmlNeTcxZWo2MnRkaXJMbnoxOTF2THBCQ0NYbk5vU3BsckwvOFlYS0ZRTm9qVkRzVEprZGRPc3BpaUtpbGRTYytJTEN1U0JRRERrRGdSRHEyVjlvZVRLczlYM1NWb2JDSVpxMDl4MlY2TGx6eXJseVN5Y0tWb3Q2Uk81ZXZQcFdGdzdlMGIwa1NkUDZYKzZSelF5czNndjFVZWZmSHIycjQ4RWQrMGN5NmQ2NlBYYWV5dFFXZmxzUXk5YTJnUElLY2VkSEFQQmtFdFduMmtBRjZzWExXQmdoVENHckhGaVVCeDhzc2J2NktVb25DMFFESlVuOXBVcmp6ZkRrRFZXakYvU3FXU25MMDRNdkx0U3pwMXUybzdyNWkvSUFTMFNKNk14L2J4M1ZMODhOYW9ycTByMTNEcS90bFNVcU95Q2FhMGZmK3FaMmIvZWsyZGxYVkxtOTl2YkVxYUNFQWFBYzA0bVRsT1Q1eGN1UUNhUERicWlZTlpzOXdhQ21PSlJFUWlHcGp0YVc0WW9DbWRLakg5U1NGMGQvSkxXQklLaG5vN1dscWtsdHIxRzFoY0ZoZHhpNi8yU3JuYlNDc1hpMHBObnAvVGsyU21ycjNLcFcydkx2THEwc2tUWFZ2djA5TDREczAvZG5XL251TklTcjYzZE1Ddk9kVWNpaEFHUVU0NEtZUkpOcmF2WkxjQkZLcFVmWXdvZ3l4ZXBzdnI1ajFBVVJhTStFQXhOZGJTMlRGQVVqcnQrS2RReG05eXlwcmcvMWRIYU1yckF0amNtemxPRnJFM1NIenA1QmVPUytxWWk2cHVLNkpIVEUvcHY4NnhHYXhxbDdoNUplaWpQeXR2cksvWForcVdzMzFjcWw4c1ZqOFZpaERBQWNzcHBMVTRxWmMwR0FXRE9kWU1ZUkE0THE1VTExU3lLeDhwQU1PU21HSndoMFkxNnRRcTdwYUtScUhjMUYyeTdtZGoyUWc5ZzZpVjlUbm5XeW1jOEd0ZUcyd0phODlyZk8zUGQ3Vi9KdDFhVFpYNWZxWkdCaFVaRVN4Z0FPZWJFRUFiQU9WNVpBL0VDaTJrUUFYWXhNV1cxdWtDT3pRa2hpaVVJYlFnRVEzV0piZmRJV2xNRTIyNUsrcUtzSUNZdjFULzM1aHBKUDBpTTJaTVhETU1vZDN2c3o1cExTMHNscVl4UEx3QzU1SmdRSnZHdEhqTytBT2RmK0RXcXNQdlh3NzY2VWs4eEZCWGY3TTB3Y25iZDRwTFVJcW1reURhOUxqSDcwUm9WN2dDOGMvMkZwTllDMkk3WFNQcFpZckJseC9PNDNmN3lNdnV6a3ZJeXY3amZBSkJyVG1vSlU4SHVBSjQxMjhlZTFnMUkrcVpjZkx0WGJPcnk2WnZ0UXBJWUI2VVlBNWhaVlVWeWZucU5wSGNVMFBhOFNOSlBBOEdRMStrckdvdkhLMDNUL3RzVVgybXBTNHl4QnlESG5CVENrRW9EYzI2dVpIVkZBbEpSSzJhWEt6YU5pVUFBMmJWU2pNVlU2SzZVOUxjRnVGMHZsdlFmVHYvY2NMbGNMbitwL2JjR3BTVWxMbGxqN1FGQTdqN2pITFF1aERDQXBVSk1SWTMwbUtKVlliRXBFUU4zWjFVZ0dHcmdNN3JnMVV2Nkp4VnVTNmMzU2JyRHlTdG9HSmtKU2lyS3l3enVPUURrbWlOQ21FU3pTTHBkQU54UVlma3F4VGhDeGFZMk1VZ3FNbis5VWlGbVZpbDBIa2xma3RSVTROdjV3VUF3OUI2bnJsdzhGdmQ2dmZZM0NDNHRLWkhYNCtFNkMwZ3dEQ1B2SG9YQUtTMWhTamdFQUpteVpybmhCaHJMclVkOFMxOWsxMUNTVmxBTW1aVUl1aG9waVlMM01VblhGY20yZmpFUURMM0FrUjlxTHNOVjRyVS9XeTRwS1pGb01Rb2d4NXdTd3ZBTkhtQ05BK09tR0dBRFFwamlVeFlJaGhpWU9iT2F4SmhMaGU0dGt0NVlSTnZya1hSbklCaHkzSlQzOFZnOEk1OW5mcDlQaHN2Z3N4SkFUaEhDQU02NWFXYWdPTmlsUkFSNnhhaUJJc2lNUURCVUxjYVJLSFRYU2Zxckl0enVKa2svY0dDWFJ0UG5zLytROC9sS0pXWVNCSkJqVGdsaHVGbEFNWFBMYWdVRDJJbFFyL2g0QThGUUpjVmdyMEF3NUpZMVVDc0tWNTJrTHhieDllanpKWDNTU1N0a3VBd3pFMU5VdTAxVDhWaWM3a2dBY3NyRmVnRHpuLzhURjJPbHNscXBWTW9hakxGTzFyZk5LMlNORGJCeW5rZGo0am4xc2diWnJVb3N3eWVyMWRlRjlaMXhZSkFKVEo5Ym5PcVpzdHIrTXVVNnBhQ1prcjRneHZ2NWNDQVl1dFVwS3hPSlJNc3lNUUJuYVVtSlpCZ2N6d0J5eWltSlB4K0d5QlZEa2pmeDhDUWUyWml0S3lvcElpa21CcVpHWmhEQ0ZPOTV2VkxTTUVXeGZJRmdxQ1JSbmloYzc1WFZFb1RySWVrL0FzSFExUjJ0TFFOT1dLSHlNdnQ3RGJrOWJoa0dYM3dCeVAzRm1sTSsrSUZzTUJNM3A2V3l3ZzlQanVxZkthWmxSMmE1RW5Vc1NsRVVuUm9Sd3RpRnJxS0Y3Ym1TM2sweFBHdWxwSCtWOU5wY3IwZzhIcy9ZR0RXR0RLNi9BT1Q4SXAzMVFLRXJUZHlVTkV0YUxhdjdUNFdzRmk4RWdPQXpIb1dHc1dGc0VBaUd2R0ttc1VKV0krbnpmRTVlNURXQllPanR1VjZKV0N6bXpkU3lJOUVvWTZZQnlDbW50SVNKc1N0Z001K3NnVW45b3NVSmlwY3BhWVppS0VwTmdXQ29RdExwanRhV0tZb2plWWt4ZGFvVE4ra29USWFrejhnYTN3MFgrMklnR05yVjBkb1N5dVZLK0RNeE8xSXBQWFVCNUo1VDBuOUNHTmpCbmJob1hpMXJnTDBLRWNDQXozZ1VyekpKYXdMQjBLckUyQ1pZUXFJRjBYcFpMU2FadWJGd3ZVblNMUlREZ3Fvay9YdXVCL2syWFJtWUhjbk5ZUTNBR1RldFRoQm5WMkFaL0xJR1R1VHJEZUI4ZExlRFpJVXhaWUZnYUVUU1lFZHJTNFFpT1Y4aXBHcmtQRklVV2lSOWhHSlkwdTlJZXFla3J4WGd0dkVGSFlDY2NzcTNwRndRSXAyYnkwcEpxMlExSitiQ0daai9PQUZtVlVwYUh3aUdhcG5HMmhJSWhveEFNRlF2YVMzbmthSzU3cjFEVnBkbExPM3ZBc0hRNm15L2FldXQyelBhY2k4U2lkQXlFRURPVDBaT3dKZ0ZTT1dtc2xMV04xbTFzbVkzQWdBay94bGFMMmx0SUJncTZzRXBFd1B2cmttY1MxQWNicE4wUGNXUXRFcEoveFlJaHVxekhOeG1MQ1R6bFpLL0FNZzlRaGprMDQzRDNQQ0ZwcVRBMHVqcWlZVjRKYlVFZ3FIR1FEQlVkR01ISmNaK1dTT0pPN0xpMFNUcFR5bUdsRzJUOUdaSjY3SWQzSmFVMkQ5Qmt0dGtUQmdBdWVlVVQ2SnhTVDNzRGl6QUwrdWIyNGlrMHhRSGtMUnBpZ0JMcUpMa0R3UkRwenBhV3lhTFlZTUR3VkNEbVBtb0dQMjFyUEdSa0xxUFNkb3R5Uk1JaHM3SUdsc3E0eUcveDBOalp3Q0Z5UkVoVEdLUXdERjJCeTY0VVBiS0d1L0ZMeXVBWWV3Z0FNakF2WTZrMVlGZ2FFaldsTllGMllJcTBaMmltUnZ4b25TTHBGc3BoclExU0hxL3BFL0xDakI5Z1dDb3Q2TzFKZTlhc29kbmFId1BJUGVZdmhTT3ZGQU9CRU8xc2daSzlGTWlBSkFWdGJLNktCVmNlLzFBTUdSS1dpMENtR0xrbHZTWEZNT3kvYjZreXhOL0w1VzBKb1Bka3pMVzVYdzZIR1pQQXNnNVFoZzQ3VUs1VkZZLy9Yb3hzd3NBWkp0UDFxQzlCUk5XSkVLbEZqSDdVYkc2VGRJNmlzR1dlNFpQenJsM01DV3RDZ1JEVlJsNHI0cE1ib2piN1o1Z2R3TEk5UWNxNEpRTDVWcFozMVF5VUNJQTVNN3N6VlhlajVzeXB3VU01NVhpVkNucHZSU0RiYTZROUtZNS96WWtOUWFDb1RxS0JnQ1NSd2dESjF3a2V3TEIwR3JSK2dVQW5LUWhFQXl0elBMVXRIYWVXMXl5V3NBd3VtZnhlcHVzSUFiMitUTlpBM3JQVlJjSWh1b3BHZ0JJRGlFTWNuMlJYQ1pyN0JjZnBRRUFqbE1oYTV3WU01OVdPaEVjclJJdFlJcFpqYVIzVUF5MnE1UVZ4RnlvMXU0Z3h1TzJmM2lxOGZFSnVWeXVTWFlqZ0Z3aWhFRXVMNUxyRWhmSjFFTUFjQzZmck5tVDhxbEZTYU1JOTR2ZE84UkF6Sm55UmttWHpmUHpXanU3TVphVzJwK2h4dUl4R1FhemJRTElMVzUra1hXQllNZ1ZDSVpXU2FJUE1RRGtCNitzMlZBYzM3SWtNYjRZWFZDS20wL1NXeWlHak40L2ZFenpkeUZ2Q0FSREZVNWQ4Y25KS1JreWFBa0RJT2Nmb2tBMkw0N2RZcHBRQU1oSHBxd1dNWTZkWlNnUURQbGtqUytHNHZaNkVjUmwycldTWHJQQTc1cWMramtSalVabEdBYnpWQVBJS1VJWVpQUGl1RVRXOU5QMDBRZUEvTDF1YUFrRVEzNEhubU5NU2Mzc0l1cW9yQUY1a1hsL0lhbDhucDhia3BxZE9KYlUxUFMwNHZINE9Mc09RSzVQVkVBMkxvNzlzbHJBdUNrTkFNajdhNGRWaVZZblR0SW9xN1VPaXR2elpIM2hnOHlybC9USEMvek9MV21sMDFaNFluSktjY1hIMkhVQWNva2JZbVJjSUJncVQ1eUltWDRhQVBLWEtXdHNHRS9pc1NJUURQVkxta2w4dnB1U1lvbEhYRkkwOGJ0dzRzK3BqdGFXakF5SUdRaUdLalgvTi9Jb1BxK25DTExxYlpLK0wrbllQTC96QjRLaDJvN1dsaUduck96NHhJVGlzZmd3dXcxQUxoSENJS01TZzdNMWlRQUdBUEtOSWFsVWtsOVdOMUx2UE05Wks2bFhWc2dpTGRIQ05oQU16VWlhbERRaGFheWp0U1ZtdzNuR2xOVEE3b0tzY1dDMlVReFpaVXI2cUtRL1dPRDNkWUZnYUx5anRXWGFDU3M3TVRHcDhNek1hWFliZ0Z3aWhFSEdKQUtZbFpRRUFPU1ZFa2tWc2daUVh5cEFkOGtLMm51bHBLWjluVzFGVXlrcEhnaUd4aVVOZDdTMkxHZU1oanJSRFFtV2Jaby9MRVJtM1NUcFprbS9tZWQzaHF5dWdsMU9XTkdSc2JHb0pGckNBTWdweG9SQlJnU0NvYkxFaFRrQUlELzRaUTFzdTFKVzE1NWtXekNhaVp1c1ZLOHBqTVQ3ckFvRVErc0N3VkJsSUJoS3FkVmtJQmp5U3FwbTF5SGhaUlJCenZ5bEZnNURTd1BCVUpVVFZuSjBkQ3dxYVlUZEJTQ1hDR0ZndThSZ2pjMmlDeElBNUlPU3hHZjJDcVhmaXNDVGVIMjZuL3RlV2NIOXVzUTRZc21xWS9jaG9VTFdvTHpJalEyU2Jsdms5L1dCWUNqbjl4M2pFeE9TTk1ydUFwQkxoREN3VldJYTZsVWlnQUVBcHpObHpXNnlVdlowNFNqVjhrTVJqNnlwYlZzQ3daQW5pZk5OQmJzUkNiY2s2Zzl5NTMxYXVHV2FLYWttMXlzNGRIYllsRFRBcmdLUVM0UXdzRTBnR0hMTENtQ29Wd0RnYkxNdEZ1MmVVYWhjMW5ndnkrV1gxU3Btc1M0TU5leEd6SEVqUlpCemxaTGV2OWd4bXhoSU95bXhXTXpXbFF2UHpDZ2NEcHVTK3RsVkFIS0ptMlhZSXRHUGY1VVk3QmtBbks1RzFoZ3VaZ2FYWDJMRGNneEpqWUZnYU9XRjNSZ1NvVCt0WUREWDh5a0NSM2lUcEVzV3VlOUlPandkbjVpMGRjV0doNThkQ29iWmtRRGtGQ0VNN0xMU3BvdHVBRURtenZtTmtqSTlRS1loYTN3WXUwS2VDa21yRThITHJDclI3UlhuckJPVEFUaUZLV3VRM29WVXBUb0F0MTJHemo0N0tSSWhESUNjWDVBQnl4SUlodXBrZjVOMkFJQzlOMFpOc3JvaFpldjk2bTFjWG9ta05ZbHhZQ1I3dWp5aGNOeEFFVGpLalpKZXZNaG5RMDVhc1owZGZqYUVvVHNTZ0p3aWhNR3lCSUlodjVpZEFnQ2NiRGFBOFdiNWZYMnlOeXh4eTJvUlV5c0dZTVg1cnFJSUhPY3ZGemxPbDJxTk41T0pGZW9mUEMyWHl6VVQzTFZ6bU4wRElKY1l2d05wU3pRTlgwbEpBSUJqelFZd3VRb3RhaVJOMm5oVDVaSzlMV3hRR0FoaG5HZU5wTGRMK3RkNWZ1ZEx6SDVteUpwVnJVUldTR3hLY3AvZDgzajEwVzkzMkw1Qy9RT0Q4bmpjdmV3YUFMbEdDSVBsV0tuTURld0lBRmllMlRGZ2N0bHF4SkRVSUttblFNclRTRHd1YkVrY2t4U2Y4eWV5eHlkcEU4WGdTSDhrNlVlU0J1ZjUzVG90TUs2VDRUSXowbEsvZi9DMERCa2hkZ3VBWENPRVFWb1M0OEQ0S0FrQWNLd0daYjhMMG55OHNyb2xqVGk4dkZ5SmRmVWtIdTQ1RDBQSkR3UThHOFpFWmJVQWlpVCtuSDNFcUpxMjJpUytFSEtxTWtsL2R1Q0pmWjkvNkZmM2Z6Z1dqVmJmOU1vWGZYalRsVnZPS2djRGEvZjI5Y2ZENGZBUmRndUFYQ09FUWNvU0F5UFdVaElBNEZnMWNsWlFibmUzSkR0NGRLNHJSSW5zYXpGa0pFSUJVL09IWURPU3BoT1BDVmxoRGRKSEt4Z0hPek13OUx2My8renVXeUl6a1RwSnV2L245MzV5MDVWYi9pUVg2M0txcno4U2k4ZTcyU3NBY28yQmVaR1N4TFNDaldKcVVBQndLcDh5UHcxMXFnemxQcnczRW1WVEw2bEYwaXBaQTh1WEs3dGR0anlKOTZ5VHRIck9lcFJTZGRPeWtTSndwcUgrMC9ySk4zNWd6QVl3a2pROU9mWFN1Mzd3aTJ0eXNUNjkvZjB1U2NmWk13QnlqUkFHcWFyaFFoRUFITXVVMVEzSmlYeVMvRGw0M3hKWndjdHFXVjhpbE10WkxZRTlzcWJzYlVxc1k1MmMwWTBzWDJ5Z0NKeG5lT2lzZnZyTkgycHFZdktpMzNVZFB2RUgyVjZmd2FFaFRVK0hUVW1IMkRzQWNvMFFCa2tMQkVOZU1SMDFBRGhaamNQUDdiWEtUa3RLbDZ4eGFGYkpHa1MrUEUrdWVVeFpnVXh6NGxFaFdwNHVaUzFGNEN3VFl4UDYyYmYvWjk0QVJwTENVOU8zN3Y3bGI1WnN3UlNOMnRkVHJ5djA3TmpnaERBQWNvNFFCcWxvNEdJUUFCeXJWRmJZNEdSdVdlRklwcGl5Z3A3VmlUODllYncvWjcvNFdDMnBtbXUyQlRWVEJNNFJuZzdyWjkvK3NVYk9EQy8yTk9QZ2svdmZ2OVN5SmllbmJGdXZrOTA5Y3JsY001S1lIUWxBem5GQ1IxSUN3VkNackZIdUFRRE9sQzhEcGxkbjRQcGpObnhwa1JYeUZOSVhCcTVFbVJIR1hLeFN1ZW5paG5sRVppTDYyYmYvUjZmN0JwZDg3dlRrMUV0Ly9sOC9hY3ZXdXAwNEdaSzN0TFRudXR1L1VzR2VBdUNFRXp1d3FNUmd2QTJVQkFBNGxrLzVNNDZJSWZ0YXd4aXlCaUV1eFBCbHZtMnRuck90c01iUmdRTk1qSTNycDkvOGdmcEN2VW0vcHZ2WXlmYUpzZkdzVEM5K3JDc1VqeHF1UTVLYUFzRVF4dytBbkNLRVFUS3F4Q0NCQU9CazFYbDRYbG51elpkZjFwZ3ZOU3F1cnJJdVdhMSttc1ZBK1NzNTlIT3Y5MFMzZnREeEhmVjM5NlgwdW1na2Vza3Z2dlBUVjEzMDRYRHBWU04ycitQK1E0ZWpocmQwWCtLZlRZa1czZ0NRc3hNNXNLQkVLNWhhU2dJQUhLc2s4Y2dueTJrTk16c0QxQW81YTVhamJQUEthZ2xTVjhUWGM5VWMvcmtUajhmMTIzc2UxaysvK1VOTmpFMmt0WXloL3RQdnl2UjZEbytNNnZUUUdiZTN1bmJmbkIrdlRFdzRBUUJaUndpRFpDNXczQlFEQURoV3ZvNXhVSm5HZFVpWnJOWXZmSXQ5L3Y1ZnBlSnNGY09NalRreU5qeXFuM3pqQjNyMDNvY1ZqOGZUWGs0MEV0MTgzNy84eTJ2bi9WMHNac3U2SGp4eTFQckEyYlIxM3dYM1FDc0R3UkQzUWdDeWpnOGVMQ2pSQ3FhR2tnQUF4ektVdndPVEdrcCtOaWVYcEhwWkxXQzRkcm1ZS2F0VlRMRjF6YXBtMTJmZnNmMUhkT2RYL2t1bnVucHNXZDV3VC9kbjkvenRuMy8zMkhlL2RzM2NuMDlNVHRxeS9BT0hqOHJ0ZGs4MHZmZ1ZGNjV3aVJqekVFQU9jQ0dEeFZTSlZqQUE0R1NsZVg0dVQ2Wkxra2ZXMkIvbDdPNmt6dHROV3Y1NE8vbWltbDJlUGZGNFhBLzk2bjUxZnU5L0ZaNmF0bTI1bnFaTmFscTU2dW96VHdhL3QrZjJEMy91ekZPL3JUSk5jOGF1NVI4NGRGaW10MlRmUXNkTUlCaGloaTBBV1VVSWc4WFFDZ1lBbk0yWDUrdnYxdUl0ZWZ5eUJxRDFzS3VUVnBJb3M1SWkyRlphTVdSSlpDYWlYM3pucDNweTkyTzJMdmQxejc5Q1QvM3pCM1huVjc3ZytsVDdYOGhuNkpYZFAveldMMkt4bUcwdHVuNzc1TlBSdUxja3VNaFRWaVJhZndOQVZoRENZRjZKVWVPNTZBVUFaeXVFY1VBcUYvbjVDaFZYOXhxN3pIWlBLdlN4YzFhd3F6TXZQQjNXenYvNGtib09IYmZ2QnNRd2RQdmJYcTRmL09YdnE4Sm41WVhiWG5TenZ2KzFmemF2dWVMU21uZzhia3RMN042K2ZwMGVPbU9XTmpUOWRwR25lY1cwN3dDeWlCQUdDNkVWREFBNG01RzRlY2gzcGJxNCsweTltSm5QanZyUlVPQTNsMDNzNXN5S3grUHEvUDcvcWkvVWE5c3k2eXZMMVBtM2Y2Q1B2T0VXR2NiNUdXdDFWYVgrL2xNZk4yNTYzZzBhSDU5WTluczkvdlFlR1lZUlgvR0NXeDlmNHFtMXRJWUJrQzJNOTRHTEpLYnNvMzhzQURoYklVMnZXaTVwZUU1d3dEbklQcld5UXE0ekJiWmRwYkxDT21UUWs3c2ZVL2ZSazdZdDcvcE5MZnBoKy8vVm1vYnFCWi9qY2J2MW1ZLy9wUTRjUHJMczkzdmk2VDN5bHBZZXJ0eDgyZGdTVC9YSW1tbHNoTDBPSU5NSVlUQWZtbVFDZ1BNVjB1Q3I1WW1ibnhYSy8zRnVuS2hLVnV2bjAvbStJZC83cDIvOXdkVGsxSllWcXhwN2I5NytZcFZWTWw1ekpoMTRmSzl0eTNySHRsYjl5N3RmcXhMUDByY2ZIcmRiVjJ6ZHN1ejNmT2pSeHlNeFQ4bURLVnovRXNJQXlEaENtRHlWYURMcFRseUVtNG1McXd1YlVjWVNmMFlUajBoSGEwc3N5Wk1RQUlCemVMYk16b0RrWmJkbVRFWGlPbUV3WHpmZ2w5LzczeHZPbmo3ekY1TFVkZWk0L3ZPTFg5ZjZyUnQxN2MydHFtOWlqRjY3UldZaU9udDYrUTJvM0c1VC8vS2UxK2tQZnFjMXErdC8vR1JJcC9yNjNaVmJycmczeVpmNEE4R1F1Nk8xSmNMZUI4QUZYQkZMaEMwbHNwcmRsaVF1VUwxSzh4dlFRREFVbHpRaktTeHBPdkhuVkVkcnkwemk5MzdxQlFEa2hVSWJQSjBBSnZQS0pjV1ZweTFpZW82SDNqSDMzL0Y0WEVmM0hkYlJmWWUxZnV0RzNYQnJtNnJybkR1azNkVEVwRXI5K2RQUWEyeDRkTm5MYUtxdjF2LysxVnQxM2NaVldWLy8reDU4UktacFRyZTg0ZzJQcFBDeUNoVmUxejBBRHNQTnRnTUZncUVTV1RNYStHVTF5N1p6b0xEWmdSeTlpWXV4MmZlTVNKcWtUZ0JBM21BUVNhU2pRbFpMMmJ5NjBUeXk1MkJWZUdyNmhRdjkvdGorSXpwKzRLZ3V2ZjRLWGYvQ0crUXZkOWJFVU1jUEhGVThIdGY2clJ2enBzekQwOVBMZXYwTHI3NUVQL3p3NzZtMklqZERQUDNtd1lkalpxbnYvdElWVGVFVVh1WVRJUXlBRE9PRzJ5RVN3VXVsckdERWs2TzZVTUdlQUlDOHdReUhTRmVWckc3S2VUUCt4ZE1QUFhHVGxtZ0ZISS9IdGZlM1QrdmdrL3QxeFExWDZmSWJybEo1Wlc0dWJhTFJxRTUxOWFycjBIR2RQSHhjWndhRzlPcTN2ejZ2S2tsa0pyMWVPWVpoNktOdmVvays4WHUzeW1Ya0ppc2VHUjNWVTN2MkdiN20xYnRTZkNsalVnSEl5bzAzY2lUUjFhaENVcldzN2tZQUFDUjlyME1SWUJscVpYVlBuc3lIbFIwZUduNUI4dUhCako1NDRGRTl1ZnN4TmExcDFwcEwxbW4xeGpXcWJheS9hRXBrdTBRaUVRMTA5K25VeVY2ZDZ1cFJ6L0hRUlNGR2xZTzdTdG1sdnFwYzMvMkx0K2dsVjIvSzZYcDAzbjJmSk1WWDNQaVN1MU44cWNtNE1BQXlqUkFtQndMQmtFdFc4Rktqd3ByZEFnQ1FQYlNFd1hLdGtOUWpLNHh4dFBCMCtQcFVYeE9QeDlWN29sdTlKN3IxOEs0SFZGSmFvcVkxemFwcmFsQkQ4d3BWMTllb3NxWktMcGNycFdXT2o0enB6TUNRemd3TWFhai90SWI2VCt2MHFRSEZZZ3ZQZmVEeGV1UXZMK3laMTMvbjJrdjByVDk3c3hxcmN6OWoxVTkrOGF1WXQ2ejh3ZHBybjV0TzF5SzNKRUlZQUJsRENKTkZpWll2MWJLK2ZTSjhBUUFzUjR3aXdESVpzb0tZWGlmWHA0TlA3YStKUmFOcmxydWM2YWxwblRoNFRDY09IanRYQUlZaFg1bGZaWlhsS3ZXVnlsUGlsZHZqVml3YWZiWWxTelFTMWNUWXVDYkdKalExTWFsNFBKN3llMWZXVmhkc0pmSjYzTHJqN1MvWG43enF4b3kxTkVyRnNSTW50Zi9RWVZmWm12VS80UDRJZ0JQeElaTWxnV0NvWEZLRENtODJDd0JBYnNRcEF0akFJNmxlVXI5VFYvRG9ua05iTW5ZUXhlT0pnR1U4bzl0UW5ZZGRrZUt4cFQ5aXJsNi9VdC82c3pmcnluVk5qbG52bloyNzVIYTdSOWUrL20yL1NuTVJmRkVLSUtNSVlUSXNFQXk1WlgzTFZFNXBBQURzdkVlaUNHQVR2NnpKQVJ3NVVPL0ltWkdOK1Y3QVZiVlZlYmZPaXdWVEhyZXBqNzM1SmZydzYyK1J4KzJjekdKNk9xd2YvNnd6YXBSVmZEL0ZXWkhtWXJ3dEFCbEZDSk5CZ1dDb1VsWUFRNzk5QUlEZDZJNEVPOVhJR3FUWGNlUER6SVRESy9POWNMM1JxYnhiNS9HUnNYbC8vcHpOYS9UMVAzbTlybGpiNUxoMS92bGRkMnRzZk54WWVldXJ2cjJNeFJEQ0FNZ29RcGdNU0F5ODJ5aW1mQVlBWkE0RFI4Sk9ocXh1MHowT1hMRzhyK3NyTnF6UHUzV2VHSjg0NzkrbGZwOSsvM1V2MGxmZmRMTWp4bjY1VURRYTFkZi82L3RSYjNuRnI1cGUvSXFlWlI0TEFKQXh0TkN3V1NBWThrcGFJd0lZQUVCbUVjTEFibDVaM1pJYzVZcm5YZk1kbDJsMjUzUEIxclUwNTkwNkc0a3N3akFNWFhIRDFYcnorOTZxdDd6b2VrY0dNSkwwODd2dTBhbitBYlBxeXVkOGFabUxvcXNuZ0l5aUpZeU5Bc0ZRbWFTVkl0d0NBR1RlaktScGlnRTI4MGs2TFFlRmZGYzk3OXJqM2hMdnk0Sy91dThqVTVOVHQ4WHk3REtyek9lUnQ4U2JkeFZoMVliVm1nblA2TXJuWGFPYWhscXJjcmlkV2ZiVDAyRjk1ZXZmam5yOFpUOXJlZFVibjdiaHN4VUFNb1lReGlhQllLaEtWaGNrQUFDeUlTeHJhbUhBYmxNZHJTMU9xMXNuVzIvZC90NklZZDUyeTJ0L1QvY2Y3bFB3VUNndkNyT3hPVDh2RDlkY3NrNXJMbGwzM3M5OHBqTkRtUC82NFk4MU9EUVVpOFZpNyt0b2JUbkpJUXpBeVdpeFlZTkFNRlFyQWhnQUFGQVlLZ0xCVUtrRDE2dk1IWS9xdGhzdjFTTi85ejZkK1BlLzFKZi82TFY2ZmR1VnFxOHNjMnhoYnJqMkNtcFVCb1Y2ZXZXMWIzMDNGb3ZGZGdSMzdUeEJpUUJ3T2xyQ0xGTWdHS3FYVkV0SkFBQ0FBdElneVdrdENqeVM1UGRaK2RDYWhtcTk1eFhQMTN0ZThYekY0M0h0Qy9VcmVEQ2tSdzZlMUtOSHV2WFVzVjVOaG5QYnM4UjBHVnE5YVYzQlZJcFkzRm5EcGNSaU1YM3k4LzhRazNSTTB1MGN0Z0R5QVNITU1oREFBQUNBQXVVTEJFUCtqdGFXQ2FldG1HbWFGLzNNTUF4ZHRycFJsNjF1MU50ZWN2MnpnY0h4dmpONjZuaXY5bmIxNlZEUGFSM3VIZFNobmtIMW5SM0x5cnBlZXRYbXZCd1BaaUhUVVdlRk1OLzR6cDE2NnBtOThWZzgvcWJncnAyTWtRVWdMeERDcENuUkJZa0FCZ0FBRktwNlNWMU9XNmx3a3ExYlhJYWhEVTIxMnRCVXE5Yys3L0x6ZmpjMkZWYlh3QmwxOVo5VjE4QlpuUndjVnQvWlVmVU9qYXJ2N0toT25SblYwTmlreHFmQ0thK2ZZUmhxcmlxVk1kd1hmZjcyVzgxQ3FoQVJCN1dFZWVEaG9EcSsrWi94ZUR6K3dlQ3VuWTl5dUFMSUY0UXdhVWdNd2x0UFNRQUFnQUpXR2dpR1NqdGFXNlljc2o3amtqUWREaTk3UWVXbDNtZGJ6aXdtRW8xcGFHeENZNU5oalV4TWFXSjZSdUZJVkxGNFhDTVRWckg0U3p6eXV0MnE5SmRvUlZXNW1tb3E5S2NmL1p2NG9icjZzTXMwZllWVUljWWpNVWVzeDk0RGg5VCtxVHVpcG1sKzU4RmYvUGlMSEtvQThna2hUSW9TMDFBekNDOEFBQ2dHTlhMT0xGd3praFNKUkxOM29XeTZ0S0txWEN1cVVudmRrM3YyeFJ0KzV6VytRcXNNNDlIY2h6QUhqeHpWK3o3eXNXZzBGcnM3RW9tOGkwTVVRTDVoZHFRVUJJSWhyNlNWbEFRQUFDZ1NGWUZneUNsZjJrMUswdFRVbEtNTDdGVC9nS2FtcGx5K2xhc0tyakxrdWlYTVE3OTlUSC80Z1E5SHA4UGgrOExoOEd1Q3UzYUdPVVFCNUJ0Q21DUUZnaUdYcEdiS0RBQUFGSmxLSjZ6RTdNQ3JrV2pVMFlWMTdJUTFqRTdwaXNMNzNxNXZaRHduN3h1TlJ2WFZiLzZuM3QvK04vR1pTT1RiNFhENHBjRmRPeWM0TkFIa0k3b2pKVytGSkMvRkFBQUFpa3lWcENGSFhMaTYzZVBESXlObFRpNnNZMTBoZVgyK0dYZFpoYWZRS3NMVFI3djBpVi8rdDk1NTI1dTB1ams3SWRQalR6K2pPLzd4SzlGalhTZWo4WGo4angvOHhZLy9qVU1TUUQ0amhFbENJQmlxbEVPK0JRSUFBTWd5ajFNRzZIV2I1cG16dzg0T1lmcjZCMVJTVlJPV1ZIQWhUT21LcHVGZmZmVTNrei83MWErYlhueFRXL3dOcjM2bGNkMVZWOGd3REZ2Zlp5WVMwZjBQUGFMdi9QQW5zU2VlM3VQeWVqejN4R0t4L3hmY3RmTW9oeU9BZkVjSXM0UkVQK2dWbEFRQUFDaGlGWkp5SHNJWWhuRjY2T3h3aTVNTHFuOXdVR1pWVGJ3UUs0SExXMUpldHZXcUZXZWVmdlNOOXozNHlJZnYrczBEVnpTdGFJaTg3Q1czdUcrNThmbmF1bm1UWEdrR01yRjRYSHYySGRCZHY3bGZPenQvSFIwWkhYVjVQWjU3SlgzeWdaLy82QjRPUVFDRmdoQm1hU3ZFT0RBQUFLQzRsVXNheVBWS1JDS1IzdUhoNGF1ZFhGRGR2WDBSVDMyTHIwRHJnYm4rOS82d3RyUDFFOStXOU8zV1c3ZGYzejh3K1BadjMvbWpOMy9qTzNmV2w1ZVZSYTY1OGpMenNpMmJqVFdybXJXbXBWbE5LMWFvdk13dnQvdmNiY2ZrMUpUNkJnYlYwOXVuSThlT2ErL0JRd28rL2xSa1pIVFU3ZlY0ZXNNek0xK1g5SzhQL1B4SHh6bjBBQlFhUXBoRkpLYWpMcWNrQUFCQWtmTUVncUdTanRhVzZWeXV4RXdrMG4xbWVDUW1CMzlCTm5oNktPN2RjRVVoWDJNM1N6b2xTY0ZkT3grVjlHanJyZHYvUk5JMVkrUGp2L05nOExHYkhubnN5ZXRuWm1hYTR2SDRzODFpVE5PTW02WVpDNGZENW5rVnkrMCtZeGpHNCtHWm1ic2wvZnlCbi8vb1VRNDNBSVdNRUdZQmdXRElrTlJBU1FBQUFFaVMvSkttYzd3T3AzcFA5VVhrNE1rU2hrZEh6WlZsQmYwZFh0T0ZQd2p1MmhtWDlIamljWWNrdGQ2NjNTdHBvNlJWa3NxajBXaFZOQm8xSkUxSUdwZlVJNmxyOXk5K2ZKcERDMEF4SVlSWldMV1lEUWtBQUdDV1g5S1pISy9EaWI3QjA0NjlmcDJlRG10bVpzYmxLUy9vK1J5U0dwTW51R3RuV05LK3hBTUFrTUJZSi9OSXRJS3BvU1FBQUFDZTVZUnhUazZFdzJIWDJlRVJSeGJRMlJGcnZkeEYxaElHQUpBOFFwajVWWXRXUWdBQUFPZGROd2FDb1Z5M0VqNHVTYjE5Zlk0c29LRXpWa01odDcrc2tPdEJNNGNDQUN6alpFb1JuSTlXTUFBQUFBc3F6Zkg3ZDBuU3FmNEJSeGJPOE1pb0pNbGRWbEhJZGFDRnd3QUEwa2NJYzdGeTBRb0dBQUJnUGlXNWZQUGdycDFUSHJmN2RIZXZNMXZDbkIwZWtlRnl4VTJmdjVEckFOMlJBR0FaQ0dFdVZrVVJBQUFBektzazF5dGd1RndIajNlZGRHVGhuRDV6UmlVK2Y3akE2OEJLRGdNQVNCOGh6QnlCWU1namErUi9BQUFBWEN6bk0wZUd3K0duVDV3TXhaeFlPR2ZPanNoVFhoRXA4RHBBdDMwQVdBWkNtUE5WVWdRQUFBQUxjaWZHejh1bEEwZFBuSFJrQ0hQNnpCbVpaUlh4QXE4RHZrQXdWTUtoQUFEcElZUTVYemxGQUFBQTRPanJ4NE9qWTJQdTBiRXh4eFZNNzZtK21GbFQ3eW1DT2xETFlRQUErWGtTZFl4RVZ5UlNmUUFBZ01XWk9YNy92WkowdkN2a3VJTHA3ajBWTGFscktJYnJTYm9rQVVDYUNHSE9LYU1JQUFBQUhILzllTnpsY29VUEh6dnVxRUtKUkNJYU9EM2s5bFlYUlNNUlprZ0NnRHc5aVRvSkEvSUNBQUE0L1BveHVHdG56T3Z4SER4eTdJU2pDdVZrZDY5aXNaaFIybGdVa3djMWNoZ0FRQjZlUkIzR1J4RUFBQUE0Ly9veFBEUHo2S0dqeHgwMUFPN3hrOWEwMmFYMVJaRlBOSE1ZQUVDZW5rU2RJQkFNZVpYNy9zMEFBQUQ1SU5lekl5a1dpejF4Nk9neFI4MlFkUFI0bDN5VlZWTXViMUVNTVVoTEdBQklFeUdNaFFGNUFRQUE4c2ZUWStQajVzRHBJY2VzMFBHVElaWFVOMGFLcFB4WFV3VUJJRDJFTUJaQ0dBQUFnT1FZRGxpSHB5WHBpSU1HNXoxeTdFVEV1M0oxc1l3eHVKYkRBQURTUXdoajhWSUVBQUFBU2NsNUNCUGN0YlBmNDNhZlBleVF3WGxqOGJoT2hMcGRwWTByaStYYW1oQUdBTkpFQ0dQeFVBUUFBQUJKY2NTQXVDN1Q5WXhUcHFudTZUMmxtWmtabDIvRnltS3BBeXNUWXlvQ0FGSTlmMUVFa2doaEFBQUFrdVdJRUdaNk92em93Y05ISFRFR3kreDAyYVZOcTRxbERoaGlYQmdBU0FzaERPVUFBQUNRajU0NmZqTGtpc1Z5UDBuUzRXUEg1YXVzbWpKTFNvdXAvTGRTQlFFZ2RVVWZQZ1NDSVlOcUFBQUFrTFM0UTliajZVZ2s0dXJxN3NuNWlodzVma0lsalN1alJWWVBObkVvQUVEcWFBSGlqQkgrQVFBQThrWE1JZXV4VDVLT25laksrWW9jT0h4MHBxUjVyYi9JNmdFaERBQ2tnUkNHRUFZQUFDQVZqbWdKRTl5MWM4enI5ZmJrZW9ha21VaEVvWjVldDY5cFZiRmRVOUlkQ1FEU1FBZ0RBQUNBVkRpbTIwMDBHbjNpeUxIak9RMkZqcDNvVWp3ZU4zekZNeWp2ck1zNEZBQWdkWVF3dElRQkFBQkloVk82SXlrYWpUNTU2TWl4bVZ5dXc2RWp4MlM0WFBIU2hxWmlxd2ZOZ1dDb21zTUJBRkpEQ09PY3dlVUFBQUR5Z1pNR29OM1QzWHZLTXhQSjNVelZoNDRkVjFsZHc2Umhtc1ZZRnk3bmNBQ0ExQkRDQUFBQUlGbVJqdFlXSjMyQnRTY1dqeHNudWtJNVc0R0RoNC9HdkN0WEYrczFOU0VNQUtTSUVJYVdNQUFBQU1rS08yeDk5aHFHRVR0eVBIZUQ4eDQ0ZkRUbWExbGJXcVQxNFJvT0NRQklEU0VNSVF3QUFFQ3lIQlhDQkhmdERIczhucTZqeDNNelRmWGcwSkJHeDhiYy9wVXR4Vm9mcnVPUUFJRFV1SXU5QUJKTmFnOVNGUUFBQVBKUE5CcDkvUEN4NDJ1Vmc4a1dEaDg5TGtueU5SVnRDSE5sSUJneU8xcGJvdFJFQUVnT0xXRUFBQUNRdDZMUjZOT0hqeDNQeWNpOEI0OGNWVWxaV2RoZFhsR3N4ZStYdEpsYUNBREpJNFFCQUFCQVBqdlkxei9nanVSZ2hxUkRSNDdKMTlnOFUrVGwzMG9WQklEa0VjSUFBQUFnbisyUHhlTkdxUGRVMXQvNHdPR2prWkpWNjN4Rlh2N1Bwd29DUVBJSVlRQUFBSkRQRGtuU2laUGRXWDNUOE15TVRvUzZUVi96Nm1LL25pYUVBWUFVRU1JQUFBQWdid1YzN1J6eHVOMURKN3Q3c3ZxK3gwNmNWRHdlTjN6Rk96UFNyQ3NEd1ZBNU5SRUFra01JQXdBQWdQeStvRFZkQjQrZlBKblY5engwOUpoY3Boa3JiV2ppZmtLNmdWb0lBTWwvYUFJQUFBQjVhM282L0hUWHllNVlOdC96NE9HaktxdGZNV1c0dUp3V1haSUFJR21jTlFBQUFKRHZEaHpyT3BuVkVPYlFzZU14ejhyVlhFdGJicVFJQUNBNW5EZ0FBQUNRN3c0T2o0eTZ4OGJIcy9hR2g0NGNpL21hVjVkUzlKS2s1d2FDSVlOaUFJQ2xFY0lBQUFBZzN4MlFwSzVRZGdiblBUTThySkhSVWJldnNabVN0OVJLMmtJeEFNRFNDR0VBQUFDUTc0NFpoaEU5ZmpLVWxUYzdjdXlFSk1uWHRJcVNQK2NsRkFFQUxJMFFCZ0FBQUhrdHVHdm5qTmZyNmNuV05OV0hqeDJYcDZRMDRxbXNwdkRQZVJGRkFBQkxJNFFCQUFCQTNvdEZZM3RPWkxFbGpHOUY0eFNsZnA0WEI0SWg3aTBBWUFsOFVBSUFBQ0R2elVRaWU0OTNoU0xaZUs5RFI0OUZ2YzFyU2lqMTg5Ukl1b1ppQUlERkVjSUFBQUNnRU96djZ1N0orTFZ0UEI3WDBlTmRocStweFVPUlgrVEZGQUVBTEk0UUJnQUFBSVhnWURnY2R2VU5ER2IwVFU3MUQyaHFldHJGb0x6enVwVWlBSURGRWNJQUFBQ2dFQnlVcEs1UWQwYmY1TkRSWTVJa1h4UFRVOC9qcGtBdzVLVVlBR0JoaERBQUFBREllOEZkTzN0TjA1ek1kQWh6NVBnSitTb3FwODFTUDRWK01iK2s1MUlNQUxBd1FoZ0FBQUFVQkkvYmZhd3JsTmxwcW84ZU82R1NocVlaU250Qkw2TUlBR0JoaERBQUFBQW9DT0dabVQxZDNUM3hUTDdId2FQSElpV3IxdElNWm1HdnBBZ0FZR0dFTUFBQUFDZ0lzVmhzMzdFVFhaRU1MbDlkb1I2enRLbVphK2lGWFIwSWhsb29CZ0NZbjVzaUFBQUFRSUU0ZktwL3dCMk5SbVdhcHUwTDd6blZwMmcwYXBUV04xSFNpM3VscEk1QzM4aHRPM2FYU2xvaHFVeFNpU1N2cExDa1NVbkRrdm82Mjl2aVZBY0FjeEhDQUFBQW9GQWNqTVZpUm05ZnYxcWFWOXErOE9OZElVbFNhVU1qSmIyNFY2aEFRcGh0TzNZM1NMcFUwbFpKV3lSdGxyUlJVck9rcWlWZVByTnR4KzZRcENja1BTcnBYa2tQZHJhM1Jha2lRUEVpaEFFQUFFQ2hPQ2hKSjA2R01oTENkSFgzeU92emgwMmZuMm1ZRjNkcklCZ3E3V2h0bWNxWEZkNjJZM2VUcE1za1hTRXJkTGxVMHVXUzZwZXhXSStrOVluSDZ4SS9HOXkyWS9lZGtyN1UyZDYyajZvQ0ZCOUNHQUFBQUJTRTRLNmRaNTcvc3RlT251enByY2pFOGsrY0RNbFgzeENXMWUwRUMvTkxlcUdrWHpwdHhiYnQyTDFTMHBXeUFwZkw1L3habGFWVnFKZjBSNUwrYU51TzNUK1c5TUhPOXJZalZCbWdlQkRDQUFBQW9HQ1lwdXRRVjZqN3Vrd3MrMWpYeVppN1lhV0hVazdLSzVYREVHYmJqdDJWc2xxMVhDRXJkSmw5MURxb2pGNHI2UlhiZHV4dWwvUjNqQjhERkFkQ0dBQUFBQlNNbWZETW5oTW51NitWWk5pOTdPTmRvVmpaamJlV1VNcEplWTJrUDhuMG0yemJzZHN0YTd5V3EzVis2TEkyVDhySksrbnprcDYzYmNmdTJ6cmIyOEpVSGFDd0VjSUFBQUNnWU1UaThZUEhUNFlpc3NianNNM1U5TFRPRGcrN2Eyc2JLT1RrckFrRVE5ZDN0TFk4YXRjQ3QrM1lYU1hwR2xtQnk5V0p2MTh1YTJhaWZQY0dTU1hiZHV4K0EwRU1VTmdJWVFBQUFGQklEZ3llSHZLRVoyYms5ZGlYdy9UMDlrbVNTbXJyS09Ia3ZVN1dyRUFwMjdaajkzcWRDMXhtLzF4WDRPWDFLbG16U3IyRHFnTVVMa0lZQUFBQUZKTEQ4WGhjb2U1ZWJWaTN4cmFGOXB5eVFoZ3ZMV0ZTOFFaSmY3WFlFN2J0MkcxSTJpVHArc1RqT2tuWFNxb3Awako3KzdZZHUzL1QyZDcyZGFvUFVKZ0lZUUFBQUZCSURrcFNWM2UzclNGTWQrOHBlVXRMWjh5U1VnYm1UZDZXUURDMHRhTzFaYjhrYmR1eDI1UzBXVmJRY3IyazU4aHE1VkpCVVozbkM5dDI3UDVwWjN2YklFVUJGQjVDR0FBQUFCU000SzZkNHplKzRuZFBuK3p1dGJYZlVNK3BQcFZVMTRabDgxZ3poVzd5OU5RbnR1M1kzUzNwdWJJQ0Z6K2xzcVFhU1IrWDlENktBaWc4TG9vQUFBQUFoY1F3ZE9oRUtHVHJNbnRPblpLN3RzR2dkRk5qZWx4dmxQU25rdHBFQUpPS2QyM2JzWnNCaUlBQ1JBZ0RBQUNBZ2pJOUhYNm02MlIzek01bGRuWDN6SGpyRzMyVWJtcThsVjY1UzJsOG53YWZwSGRSREVEaElZUUJBQUJBb1Rsdy9HUW9hdWNDQjArZk1UeFYxYlNFU1VOWkl3MWcwdlFtaWdBb1BJUXdBQUFBS0RTSHpnNlBlQ1ltSm0xWjJFd2tvdEd4TWJlbnZJcVNUUU1oVE5xdVMwelZEYUNBRU1JQUFBQ2cwQnlTcEs3dUhsc1dkbnJvakNUSlcxMUR5YWFocE1vcmo0OHVTV202aVNJQUNnc2hEQUFBQUFyTlljTXc0bDJoYmxzV05uaDZTSkxrcWFBbFRMcG9EWk8yR3lrQ29MQVF3Z0FBQUtDZ0JIZnRESHM4bmw2N1c4SVF3cVN2YkdVWmhaQ2V6UlFCVUZnSVlRQUFBRkI0NHZIOUowUDJoREJuUjBiazluaWlocHN1TmVueWxudmtLZk5RRUtsak1HaWd3QkRDQUFBQW9PQ0VaMmIySE92cWl0aXhyT0dSRVhuOEZTYWx1anpsVFhSSkFnQkNHQUFBQUJTaVExM2RQYmEwSWhnZUdaWGJUM2VhNVdKY0dBQWdoQUVBQUVCaE9qQXhNV21lSFI1WjlvS0dSMGZsOGhIQ0xKZW56Q052aFplQ0FGRFVDR0VBQUFCUWlBNUowZ2tiWmtnYUhpR0VzVXRGU3ptRkFLQ29FY0lBQUFDZ0VIVzVEQ05peHpUVkk2Tmpjdmw4bEtnTnlwdjhNa3pHbWdWUXZBaGhBQUFBVUhDQ3UzWkdQVjVQVjZpN2Q5bkxHaDJma052SGVDYTIzSHk0WFl3TkE2QzRQd2NwQWdBQUFCU2lTQ1M2NS9qSjBMS1hNelkyTHBPV01MYXBwRXNTZ0NKR0NBTUFBSUNDRkkxR0R4dy9lWEptdWNzWm41aVFXVW9JWTVlU3FoSjV5ejBVQklDaVJBZ0RBQUNBUXJVLzFOMXJ4dVB4WlMxa1ltSkNaa2twcFdrakJ1Z0ZVS3dJWVFBQUFGQ29EczlFSXE3K3dkTnBMMkI2T3F4b05FcExHSnVWcnl4amdONGtxeUJGQUJRV1FoZ0FBQUFVcWdPU3RKd1prc2JHeDYyTFprSVllMjlDR0tBM1daTVVBVkJnbjM4VUFRQUFBQXBSY05mT1U2WnBUcDQ0dVp3UVprS1M1R1pnWHRzeFFDK0FZa1FJQXdBQWdJTGxjYnVQbmdpbFAwUFNiRXNZdWlQWnI2U3FSSjR5QnVnRlVGd0lZUUFBQUZDd3d1SHdFOGU3bGgvQ3VFb0lZVEtoWWxVWmhRQ2dxQkRDQUFBQW9HREZwSU5IVDZRZndveU9XU0dNMjhmNEpabFF2ckpNaHNFQXZRQ0tCeUVNQUFBQUN2ZGl0NlRpeE9EcFFVMVBoOU42L2Nqb21Ed2xwUkpCUVVhWVhsTytlcWIvQmxCRTV5V0tBQUFBQUFWN3NldXJQUmFQeDlYVm5kN2d2S05qWS9MNDZES1RTZVVyS2Q5Rm5LVUlnQUk3TDFFRUFBQUFLRlQrVFMvcWt3eDFoWHJTZXYzbzJEaUQ4bVo2SHpYNDVISnpXd0tnT1BCcEJ3QUFnSUpsVnF5TWxaUlg2M2pYeWJSZVB6d3lJdFBQVk1xWlpMZ00rUnNJdWdBVUIwSVlBQUFBRkxJU3cxZVhka3VZb1ROblpmanBMcE5wZEVrQ1VDd0lZUUFBQUZESXh1S2xOVHB5b2l1dEZ3OE9uWlc3b3BKU3pMRFMyaEs2SkFFb0NuelNBUUFBb0pDZE5mMTE2Z3FsTnpEdm1lRmhlUWhoTXM0d0RKWFdsbEFRQUFvZUlRd0FBQVh1cWU2ejVwNitVWk9TUUpFYU0vMTFtcHFhMHNEcG9aUmZQSFRtck54bGpBbVREZjU2eG9XWnh4UkZBQlFXUWhnQUFBcGNKQkw1STBsL1EwbWdHSFcydDBWYy90cHBTZW82R1VycHRXUGo0d3FIcCtXcHJLWWdzNEFRWmw2RU1FQ0JJWVFCQUtDQUJZLzBsY2ZqOGQrVjlORTlmYVBiS0JFVTVRVnZTY1dJNlNuUjhSUkRtTDZCUVVtU3Q3cVdRc3dDczhTVXU5VHRoRlhwWlc4QXlOZzVpU0lBQUtCd3hhVVB1a3l6U3BJaDZkdDcra2FiS1JVVW9YNXZlWjFPbkV4dFhKaFQvUU9TQ0dHeXFhVFNtOHUzSDVMMFFVbVhTSXF5TndCa0FpRU1BQUFGNnBFamZTc2xmZEJ0bXFzU1AycVE5QjNHaDBFUjZvbVYxS2JlRXFaL1FKNlNVcG1sZEpQSkZyY3ZKeTFocGlUZElXbGpaM3ZiRnpyYjI4WWxoZGdiQURMeU9VY1JBQUJRc0Q0aHlYQ1pyc1k1UDd0WjBxY2xmWVRpUVJIcGMvbHFkZlRFdnBSZTFOdlhyNUlxV3NGa2s4dHRaUHN0NzVUMEY1M3RiU2N1K0htWHBMWHNFUUMyZjg1UkJBQUFGSjVIanZSZEp1bWRobUVjbStmWEg5N1ROL3B5U2dsRnBNZmxyOVhBNEtDaTBlUjdtWnc0MlMxM2JRT2xsMFdScWF6MUFucEswb3M2Mjl2ZU9FOEFJMG1ISFZJa2NXb0ZVRmdJWVFBQUtFeWZsV1NhcGpteHdPKy90YWR2dElWaVFwSG9NLzIxaXNmakdodzZrL1NManB3NHFkSW1obEhLbHVoTVRPTjlFNWwrbXlGSjc1RjBYV2Q3MnoyTFBPOFpoeFRMTURVREtDeUVNQUFBRkpoSGp2VGRJbW03SkpsdXMzcUJwOVZKK3U2ZXZsRVBKWVlpY05KVldpVko2ay9NZUxTVVNDU2k3cDVlbFRZMFVucFpjbnIva0dLUldLWVdINVgwVDVJdTZXeHYrNWZPOXJhbG10enNZNDhBeUFUR2hBRUFvSUE4Y3FUUGtQVDV4RC9qcHVuYXNNalRiNVIwdTZ6WlFJQkNkdFR3K09ReVRaM3FIOUNWbDIxZDhnV2gzbE9LeGFJcWJhUWxURGFjUFRhaThWTVphd1d6VzlKN090dmJua3poTllRd0FES0NsakFBQUJTV3QwaTZYcElNd3podUdNWlNNeUg5K1o2KzBWZFJiQ2h3UnlYSlUxS3VvVE5uazNyQmlTNXJjaHhhd21UZTJhUERPblA0YkNZV1BTRHBYWkpla0dJQW84NzJ0dU9TenJCM0FOaU5FQVlBZ0FMeHlKRStyNnlaajZ5VHZNczFtT1JMdjdtbmIzUU5KWWhDMWRuZWRrYlNHWmVuUkNOalkwbTlabnhpUXFiYkk1ZTNoQUxNa0hnMHJvRm5UdXZNRWR1SFBZbEorbWRKV3pyYjIvNjlzNzB0M2NGdEgyVXZBYkFiM1pFQUFDZ2M3NU8wYnZZZnB0dE05dTZ4UnRMMzkvU04zbng1WTBXWVlrU0JPbXFZM3V2SEo1THI4dExjMUtob1pFYlRnMzBxcWFjMWpOMm1oNmMxOE14cHpVeEU3RjcwUTdLNkhqMXV3N0lla1hRcmV3dUFuV2dKQXdCQUFYamtTRitOcEkvTy9abHBtdXRUV01SekpkMUJTYUtBSFltYlhvMk5qeWYxNUNzdTNhS2E2bW9ON0w2SGtyTlJOQnpWNE40aDlRVDc3QTVnVHN2cWV0Um1Vd0FqT2FNbHpDUzFCaWdzaERBQUFCU0F1UFRSdU5XaVpkYWd5MlZVcExpWTkrL3BHMzBkcFlrQ2RTQnV1RFUrbnR3OXJkdnQxdHZlL0FZTlBueXZKbnRQVW5yTEZKdUo2ZXpSWVlVZTZOVm85NWdVdDNYeC95WnA4eks3SHMxbnR3T0ticHJhQXhRV1FoZ0FBUExjdzBmNjFzbnFpcVI0NG1HNFhPbmVOZjc3bnI3UjlaUXFDdENlbUZtaXFlbms3Mm5mOU5ydDJyeHBvNDUvKzZ1S1R0RWdJUjJScVlpR0RwM1Z5ZnU2ZGViSXNOMVRVRDhsNmNiTzlyWS83R3h2RzdKNzNUdmIyMDVKT3NKZUJHQW5RaGdBQVBMZnB5VjU1LzdBTkYzcDN1bFV5eG9maHRGSVVXaWVNVnh1SlRzbWpIVWNtZnJNWDM5WVpuaFNKNzd6YjRwSEk1UmlraVpQVDZuL3lVR0Y3dS9SOFBFUnhhSzJObjBaay9SQlNkZDN0cmRsdXJYS2ZleE5BSFlpaEFFQUlJODlmS1R2T1pKKzc4S2Z1OTN1cG1VczlqbVN2a0Rwb3NBY2xPR09qVStrMXFLbHVhbFJmLytwajJuaStDRjEzZmxOS1I2bkpCY1FIcHZSbWNOV3E1ZFRqL1Zydkg4aUU4WDFBMG1YZGJhM2ZhR3p2UzBicWRqOTdGa0FkaUtFQVFBZ244WDF1WGwrT20yYXJsWExYUElmNytrYmZRTUZqRUxSMmQ0Mlk3ak1nYkh4aVpSZmUvWGxsK3F6SC91SXpqN3ptTHJ1L0tiaXNSZ0ZtaEFlbTlIWm84UHFmckJYM1EvMjZ1eXhFVVdtb3BsNHEyT1NYdG5aM3ZhR3p2YTJiQTdTY3k5N0dZQ2RDR0VBQU1oVER4L3UyeTdwbG1jSGdrbDg0MndZeGxHYjN1SnJlL3BHTjFMU0tKd3JYek0wZE9aTVdpKzk4Ym10K3V6SC8xSm5uZ3JxeFBlL1hyUkJUQ3dTMDhUQXBFN3ZQNk9UOS9lbys4RmVuVGt5clBEWVRLYmVNaXhwaDZUTE85dmJmcGJ0N2Uxc2J6c3NLWlRMSXVmQUJRcUxteUlBQUNEL1BIeTR6eTNwc3hmOUlpNlpwbXZVcHJlcGxQVGZlL3BHbjM5NVk4VVVwWTY4WjdnT1RFOVBYejg5SFZaSmlUZmxsOS84L09mcXN4Ly9TMzM0RTdlclM5S2FONzVEaHF1d3Y5T014NlhwNFdsTm5wN1MxTkNVcG9lbnM5a2o2OWVTL3JpenZXMS9qb3ZoTGtsdnk5RjdqM0RnQW9XRkVBWUFnUHowRGttWHpYdHlkN3VyYkh5ZmF5UjlVZEs3S1hMa3ZWZzBLT24zQm9lR3RHcGxlc01telExaVl0RzQxdnlmdDh2MEZzNGxkV3dtcHFuaGFVMmZuZGJVMldsTmo0UVZqMlo5SEp4VGt2NjBzNzN0dXc0cGxudVV1eEFHUUlFaGhBRUFJTTg4ZkxpdlhOSW5GL3E5NlhadHNQa3RBM3Y2UnUrNXZMSGl1NVErOGxvODlyK1MvdjU0MThtMFF4anAvQ0Rtd0ZlbVZYN1ZhK1QyZStUeHUrWDJ1ZVV1TlJOL1duODNYSVlqaXlNV2lTazhPcVBwa2JEQ28yRk5qNFExTXo2VHkxV0tTdm9uU1IvcmJHOXpVZ3VRdXpoNEFOakZvQWdBQU1ndkR4L3UrNWlrVDh4N1lqZlVWVmJ1WDVPQnR4MlRkUDNsalJVSDJRUElaemUrK2kyUnQ3MSt1L21IYi8yOVpTL3IzdDBQNjBOLzgybVZycnRScGV0dlh2QjVwdGVVV1dyS25malQ5SnB5bHlUKzdqRmxlbDB5dmFZTU16T1g1dkc0RkptWVVYaHNSalBqTXdxUHppZzhGdGJNaEtPbTNINUkwcnM3Mjl1ZWRHSzkyYlpqOTJGSnVSZ2o2eDJkN1czZjRNZ0ZDZ2N0WVFBQXlDTVBIKzVya3ZTaGhYN3Zjcm42SkdVaWhDbVg5SU05ZmFNM1hONVlNY21lUUw0eS9DdENEd1FmVzJ0SENQUEN0dWZxL1lGMzZZdGYrVGVaVmF2bHFWMC83L09pNGFpaTRhakNTNjJieTdBQ0c2OUxMcmRMTGsvaTRVNDhURU9HMnlYRFpWaC9OdzBaeHJuZ0poYU5LVFlUVXl3U1UyUXlvcG1KaUdiR1p4U1pqQ3J1M0ttMVQwdjZpS1N2ZGJhM09Ybis3N3VWbXhBR1FJRWhoQUVBSUwvOGphU3loWDVwdWsxdkJ0LzdDa2xma3ZRSDdBYmtLMWZWNmwvdjNYL1BPMDZjN05iYTFhdVd2YnkzL082cmRkOURqMmh2MXdNTGhqREppc2ZpaWt4RkZDbU9ZYkRqa3I0bTZTT2Q3VzJuODJCOTcrS3pENEF0NXlHS0FBQ0EvUERRNFZOYjQ0ci9RVndMZjFuc2RwdHJNN3dhNzlyVE4vcjc3QTNrcTVLVzF2OHNxYWpUdjM3cnYyeFpubUVZZXNsTk55bzgwa3ZocHZCeEp1bUd6dmEyUDh5VEFFYXlCdWZOaFFtcUMxQllDR0VBQU1nZmQwZ3lKU2srNTc4NXpyaGNydW9zck1kWDl2U05Yc2J1UUQ0eVRNL0RudlV2aW5YZS9SdmQ5WnY3bDcyOHNmRngvY2YzZnlodjdUb0tkMmw5a3Q0dXFhMnp2ZTIzK2JUaW5lMXRweVR0eWNGYmg2azJRR0VoaEFFQUlBODhkUGpVelpKZU5kL3Zac01ZdzJXY3lOTHFsRW02YzAvZmFCbDdCdm1tczcxdHpGTy8rVEhmMnVmcXIzWjhYcDEzL3lidFpZMk5qK3NESC8ya1RnK1B5M3ZKeXlqY2hVVWtmVUhTNXM3MnRtODZmT3lYeGR6RHJnU3dYSXdKQXdDQXd6MTArSlNSdUlGWmxHbWEyWnpxNURKSlg1YjFyVGFRYng0bzNmaVM1MGd1L2RXT3orblg5KzNXTzI5N296WnZUSDUyOThlZWVrYWYvUHcvYW1Cb1JMNnIzeUpYU1FXbE9yOU9TZS92YkcvYlh3RGJjcGVrUDJhWEFsZ09RaGdBQUp6dlRaS2VzOVNUUEI1elJaYlg2MjE3K2tidnVieXg0aHZzSXVTWkJ5Uzl2M1RqaStTdVhhL2RUOTJsWDkvM2ZsMnljWU5lY01OemRNVmxXN1J1ZFlzYUcrcmw5VnBqWGNkaU1ZVjZldlhRbzQvclYvZmNweWVmMmF2U3V2WHlYLzk2dVVvcktkR0w3WlAwb2M3MnRwMEZ0RTMzeWhwUTJHRDNBa2dYSHlBQUFEallRNGRQZVNYdGw3VFV0Q3ZoaW9veWJ3NVdjVUxTOHk1dnJIaWF2WVY4c1czSDdwV1NldWIrTEhMbXVNSjllNldSRTVvZU8vUHN6ejFlcjl5bVcxTlRrNHJINDNLNVRIbnJOc2pkZkwwOGRSc296SXYxUy9xNHBIL3JiRytMRkdEZGVWelNOVmw4eTlkMXRyZjltR29GRkE1YXdnQUE0R3p2MWRJQmpBekRPQ1pwU3c3V3p5OXJmSmpuWE41WU1jYnVRajdvYkcvcjNiWmo5MUZKejZZbzdwcDFjdGVza3lUNUlsT0tUcHhSZkhwVThjaVU0ckdvL0taSExuK3R6TElHR2FhSFFyellwS3h1azUvdGJHOHI1TStDKzVUZEVDWksxUUlLQ3lFTUFBQU85ZERoVTlXUy9pcVo1NXFtYXppSHE3cEYwbGNrTVhVMTh1MW1ldDZtTElhN1ZPN0tsWkpXVWtwTG01SDA3NUwrdHJPOXJic1lQcG9sdlMrTDd6ZEtGUU1LQ3lFTUFBRE85VmVTYXBJNm9idmR1UjRWOUxiRStERC94bTVEbnJoSDB0c29oclJOU1BxNnBEczYyOXU2aW1pN0gyTFhBMWdPcHFnR0FNQ0pWL21IVDYyVjFSVXBLVzYzNllUQktiNjBwMi8wR3ZZZThzUXVpaUF0QnlYOXVhVFZuZTF0N3kyeUFFYWQ3VzFIWlkxN0F3QnBJWVFCQU1DWlBpMnBKTW5uaGd6REtISEFPcGZLR2grR3VYcVJEemZUSVVtSEtJbWtSQ1RkS2VsV1NWczcyOXYrcnJPOWJhaUl5NFBXTUFEU1JuY2tBQUNjZG5WLytOVDFrbjR2MmVlYnB1dVVwQmFIclA0bVNmOHE2YzNzU2VTQlgwdTZoR0pZVUpla3IwcjZXbWQ3MnltSzQ5ekh0S1JYVXd3QTBrRUlBd0NBdzhTbE95UVptdjNmVWlkenQ5dDAyQ2E4S1RFK3pGZlltM0M0WFpJQ0ZNTjVwaVQ5U05KL1NPcnNiRytMVVNRWGVaQWlBSkF1UWhnQUFKeDBaWC80MUNzbHZYajIzL0U1djFzb2tIRzd6VFVPM0pSLzJOTTNHcnk4c2VKUjlpb2M3SjdFWVdaUUZCcVExQzdwenM3MnRtR0tZMUcvbFJSVGRvWjJHS2U0Z2NMQ21EQUFBRGpFZzRkUG1aSSt1OUR2NDNNZWM0eTRYSzQ2QjI2T1Y5TDM5L1NOVnJGbjRWU2Q3VzJEa3A2a0pDUko3K3hzYi9zM0FwaWs2czJZcEtlejlIWXpsRGhRV0FoaEFBQndqbmRJdWp5Wko4NkdNWWJMT083Zzdka2c2V3ZzVmpqY0x5Z0NEVXY2SmNXUUVyb2tBVWdMSVF3QUFFNjRtajk4cWt6U0oxTjluV21hMHc3ZnROZnY2UnQ5SDNzWUR2Wnppa0EvN1d4dm84VkZhaDZtQ0FDa2d4QUdBQUFuaU92UEpLMU05V1VldDdzK0Q3YnVDM3Y2Um05Z0o4T2hkc3RxQ1ZMTXZrODFTQmt0WVFDa2hSQUdBSUJjWDhrZk90VW82Y01MRGZxeWlLaHBtdXZ5WUJNOWtyNjNwMiswaHIwTnArbHNiNHZJbWlXcFdJMUk2cVFtcE95Z3BLRXN2QTlqOUFBRmhoQUdBSURjK3h0SlplZjlKSWxBeGpDTUk0YVJON082ckpQMDczdjZScG1GQms1VXpPUEMvTHl6dlcyYUtwQ2F6dmEydUtSSHN2QldjVW9iS0N5RU1BQUE1TkNEaDA1dGxmU0hTMTZDenhQSW1LWXIzNzRoZmEya1AyV3Z3NEdLT1lTNWs5MmYva2M0UlFBZ1ZZUXdBQURrMW1ja21Vay9lMDRnNHpiZC9qemMzcy91N1J0OVByc2RUdExaM2haUzlxWWNkcElKU1QrakJxVHRJWW9BUUtvSVlRQUF5SkVIRDUyNlNkSnIwbjI5eDJOdXlLZnROYXlIVzlMMzl2YU4xbElENEREUEZPRTI3K3BzYjV0azE2ZnRZV1crdTlBNHhRd1VGa0lZQUFCeVlQZWhVMFpjK254cTQvQ2U1NVJoR0w1ODJOWkUrRExYYWtuZjNNdjRNSENXN2lMYzVwM3M5dlIxdHJjTlM5cWY0YmRoNm5DZ3dCRENBQUNRRy85SDByUFROcWM2TVpKcHVoeC93emhQK0RMWGRra2ZvaHJBUVFhS2NKdnBpclI4dXlrQ0FLa2doQUVBSU50WDdJZE9lU1hkdnREdmt3bGszRzdUa2ExSURDMFp2c3oxNmIxOW95K2dSc0FoZW90c2U1L29iRy9yWnJjdjJ5TVVBWUJVRU1JQUFKQjk3NUdVMUhndUN3VXlicmU3eFVrYmxFTHdNdmRGcGd4OWQyLy9hRDFWQWc3UVgyVGJ1NHRkYm90TWh6QlRGREZRV0FoaEFBRElvdDJIVGxWTCt1dDBYanNua0JrM1RkY0tKMnhQbXVITDNCZXRrdlN0dmYyTUQ0T2M2eW15N2Uxa2w5dmlHV1V3S09sc2J5T0VBUW9NSVF3QUFOblZMbWxaTXdPNVhNYlJYRytFRGVITFhDK1Q5RkdxQm5Lc21GckNURXU2bjEyK2ZKM3RiUkZKajFNU0FKSytqcU1JQUFESWp0MkhUcTJWOUw3bExzYzB6Wng4TTVyaWVDOHB2c2o0eEw3K3NSZFNTNUJEQTVKaVJiS3REek0xdGExK1N4RUFTQlloREFBQTJmTXBTYVhMWFlqSGJkWmtjNlZ0YnZWeTBaT3MvK1NTOUoxOS9XTXJxQ2JJaGM3MnRwaUtaNFlrV3NIWTYrRU1MVGRLMFFLRmh4QUdBSUFzMkgzbzFIV1Nick5oVVRHMzI5eVFqWFhPZlBoeTBWTlhTdnIydnY0eGt4cURIRGxWSk50NUg3dmFWbzltYUxsakZDMVFlQWhoQUFESWpzOHBqVXpqUW9aaEhEY01JMlBuNzdTNkhFbEpoeS9HL09ITFhMK2pOQWN1Qm14UURDRk1UTkp1ZHJXdERrZ2FvUmdBSklNUUJnQ0FETnQ5Nk5UTEpiM1lqbVdacHV0MEp0WnhXY0ZMQ3VGTGt2NTZYLy9ZUzZnNXlJRytJdGpHL1ozdGJRUUdOdXBzYjR1TGNXRUFKSWtRQmdDQURIcmdVSzlMMGgxMkxjL2pOa3Z0WEw4c2pmZVN6dlhKZis3ckgydWlCaUhMaXFFbHpLUHM1b3dJWm1DWjR4UXJVSGdJWVFBQXlLeDN4QlcvSWk3cnYrVnl1OTIyakFlVGcvRmVVdFVvNmI4WUh3WlpWZ3d0WVdpeGtUL2xPa094QW9XSEVBWUFnQXg1NEZDdlg5SW41LzRzUHVlL05BeTZYRVpadXV1VDRTbW1reG52SlZVdmt2UUphaEt5cUxjSXR2RXhkbk5HUEVJUkFFZ0dJUXdBQUpuelo1S2FGL3BscW9HTTZYSjFwYk1TbVd2MVlqMHh6UzVIeVdyZjN6KzJqYXFFTE9rdmdtMThodDFzdjg3MnRxNE0xQi9HN2dFS0VDRU1BQUFaOE1DaDNoV1NQcHpzODVNSlpOeHVNNlhtTXc0ZDd5WFZWVEVrZlh0Ly8xZ3p0UXBaVU9ndFlmbzYyOXZPc3Bzenh1NHVTVEdLRkNnOGhEQUFBR1RHeHlXVnAvUENoUUladDhkY21jenJjenpGOUxJczBQdXBRZEozOS9lUHVhbFd5TEJDYndtemwxMmNVWFozU1lwVHBFRGhJWVFCQU1CbUR4enEzU0lwWU04VitMUC9UYmxOYzhIV0lOa2E3eVZUa2xpTm15UjlpdHFGVE9wc2J4dFVZUStHdW8rOW5GRjJ0NFFacGtpQndrTUlBd0NBL1Q0anlkWlpmVnlHY1dTK254ZElsNk5rZlhoLy85akxxVjdJc0lFQzNyYWo3TjZNWW5CZUFFdGYwMUVFQUFEWTU0R0R2UzlRWEsrMWU3bW0yeHlmKys4OG1HSjZ5ZFZJYy9uZjJqOHcxa0pOUXdiMUZQQzJkYkY3TTZlenZXM0E1aktPWkh5bHQzL0kxUFlQWGE3dEg3cEYyei9VeUY0RU1vKysxUUFBMk9TQmc3MkdwTTlMT3I4bnZ3MXBodGZ0cms1N1VVblBjcFJaaGowdnJwUDAvZjBEWXkvYzJsQStRNjFEQmhSeVN4aENtTXg3UXRJYW01WTFscEUxM1A0aFE5S3RrbTZUOURwSmxjKyszL1lQTldubkhlUHNSaUJ6Q0dFQUFMRFBHeVE5OTZLZkxqK1FpWHZjNW9hVXgzdEo4b2w1RXI3TTlYeEp0MHY2SUZVT0dYQ3lnTGZ0QkxzMzR3NDdkczIyZjZoYzBsc2x2VS9TMW5tZVVTNnBYaEloREpCQmhEQUFBTmpnZ1lPOTNrUXdzTGcwQWhuRE1FNFlockV1dVNjbi82UThERi9tK3ZNREEyUDNibWtvL3ltMUR6YnJMdER0Q2t2cVkvZG0zRUVibHpWaHkxSzJmNmhPMG50bGhTOTFpenh6Um9YZEhROXdCRUlZQUFEczhXNUpHMU42UlpLQmpPbHlEVWhhdCtpeUhCSytHQmxld0FXLy91YUJnYkZydHpTVTgrMCs3RlNvSVV4UFozc2JVeDVubnAwaHpQSmFwR3ovVUwyc0ZvUHZsVlNXeEN0MmFlY2RkUE1FTW93UUJnQ0FaYnIvWUc5MVhQcllBa0ZCY2hZSlpEd2VkOG1Dcnl1czhWNVNmVXFOcERzUERJeTlZRXREZVppYUNKdUUyQzRzZzUzZGtkSUxZYlovcUZyU1I1UjgrRExyNit3K0lQTUlZUUFBV0w2UGFFNFQ3d3UvYWs0NW9MZ2drUEc0emJYcExiQmd3NWU1V2lYZElla0RWRVBZcEZBSHJ5V0V5VjQ1VDBrcXRXRlpaMU42dGhXK2ZDRHhxRXJ4dmZaSitnRzdEOGc4cHFnR0FHQVo3ai9ZdTFyUyt4ZDdUbnpPSTJWeERaa3VsM1V4bmRJVTAwYkd1eDBaR1hweEdsTll2Ly9Bd05qcnFJMnc4U2E2RURFelVoWWt1bnpaMVJvbXVURmh0bitvWE5zLzlERkp4eVY5WEtrSE1KTDBaOXA1UjR3OUNHUWVJUXdBQU12emFhWHdqV2VxZ1l6cGNuV2xGcjVrYnN5WE5NS1IrUmVRM3ErWDh1OEhCc1kyVUIxaHcwMzBxS1NSQXR3MFdzSmtqMTBoek9KVFZHLy9rRS9iUC9RUldlSExKNVJlK0NKSlg5Zk9PMzZ4NkFhZG52UWNQajFwc0d1QjVhTTdFZ0FBYWJyL1lPODFrbjQvM2Rjbk15NnYyMk5HRmw5S1VYUTVTa2ExcERzUERJeTNiV2tvbTZaMllwbDZKRlVXMkRZUndtU1BYU0hNNlhsL3V2MURQa2tCU1IrVzFMVE05OWd2NlUvbTNZalRreHNsdlZ6U05ra3JKZDBvYTVZdEFNdEFDQU1BUVBvK2IxZUdzRkFnNC9XNEcrZC9CZUhMUEV1N1R0SVhaQTFHQ1N4SGw2U3RCYlpOaEREWmM4eW01Wndmd3RnYnZraFdTNXZYYStjZFk1SjBlSEN5VE5LTEpMMU0wc3NVMThZNUg5UTNiNnJ6RWNBQU5pQ0VBUUFnRGZjZjdIMlpwSmRrWXRsekFwbXcyMjJ1UHZmUHpFOHh2ZXpsR3hsY2RoSkxOS1EvUGpnd2ZzL21ockwvcHBaaUdRb3hzRGpPYnMwYXU4YmZHWkFrYmY5UWphUjN5eHB3ZDRWTnk0NUplc3ZoYjN6Q0xYM2lnN0phdkx4QWt2ZWlFNUtoZjkxVTU3dVAzUXJZZ3hBR0FJQVUzWCt3MXlWclJwNk1NZ3pqcUtTdHRIcFplb2tYTFA5ckJ3ZkduOXpjVUhhSTJvbzBIUyt3N1JucGJHOGJZTGZtVi8zWmQvVEpPbTMvMEQ5SmVydFNtMnA2UVZWbFB0MTQrVWE5NitWdGoxeTFmbFZIWEdwZTR2TzVUM0Y5bUYwSzJJY1FCZ0NBMUwxZDBwV1pmaE9QMnh6SmRQeVNoMTJPa2xsK3BhUTdEdzZNUDI5elE5a1UxUlZwT0ZaZzIzT1VYWnBWSit4WVNLanZ4RjNMWFlicGN1bUs5YzI2K2NwTnV2bktTM1RWaGxWeUdZWWtQVy8yT2ZIRlA2cy9zS25lZDRaZEN0aUhFQVlBZ0JUY2Y3RFhKK2x2cy9GZVhvODdZd09ENW5QNGt1U3lyNWIwUlZsTitJRlVIUyt3N1RuTUxzMmV6dmEyMFcwN2RwK1JWSlB1TXFiRFU0ckgwNXN4ZWtWMWhWNXd4U2JkZk9VbXZlQ0tqYW9xOHkzNW1nV0NtRjlzcXZkOWx6MEsySXNRQmdDQUZNU2xQek9rNW15OGw4Zmp0blhLWlNQREM4aHlsNk5rQkJManczQVRnVlFkTDdEdElZVEpUUjFLTzRTWm5CNVAvbHpoTnZXY1M5Ym9waXMzNmFZckw5SFcxWTNwbnQvbWZzNU9Tdm9qZGlOZ1AwSVlBQUNTZE4vQjNnWkpIMDVtYXVubE1nempwTXN3VnR1eXJBeS8ySUhoeTF6L2VuQmcvSW5ORFdYN3FjRklRWStrR1VtZUF0a2VRcGpzNjVKMGJib3ZucHlhV1BUM3F4dHFkUE5WbCtqbUt6ZnErWmR1a0svRWE4dEt6d2xpUHJhcDNuZWMzUWpZanhBR0FJRGtmVnhTeFlVWHJEYUZCZWN4VFZlZnBHV0ZNQVU2M2t1cWl5MlhkT2ZCd2ZFYk50ZVhUVktGa1l6TzlyYll0aDI3dXlSdExKQk5Jb1RKdnVQTGVmSG94TWg1Ly9hVmVQVzhTOWZwcGlzMjZlYXJObW5OaXRvTWZSWkxjZWx4dytyT0NTQURDR0VBQUVqQ2ZRZDdOMHNLTEhIaGF0dEZzZGZ0VHZzY1hRVGp2YVM2MkNza2ZVblNIMUNUa2VKTk5DRU0wcldzYWFwSHhzNXF5K3BHdmVDS2pYcmhWWmZvK2t2V3lPTTJGenozR0VzTnI1dThtS1RBcG5wZmhGMElaQVloREFBQXliazlsZlBtY2dNWnI4ZTlKcFhuRitGNEx5bXRxQ0c5NjlEZytEMlgxSmQ5bTZxTUpCMHZrTzBZN214djYyWjNPci8rK0V0TWJWMVZvYTB0NWZyWUc5K3FGZFVWU2IvV3hpRG1TNWZVKzRMc1BpQnpDR0VBQUZqQ2ZRZDdiNVQwdSttK1BvMUFadGcwWGJYSlBKRXVSNHN2NUlKZmRSd2FISC84a3ZxeVBkUnFKT0ZJZ1d6SFUrektuRmh5bW1xWFlXaE5nMCtYcmE3VXBhc3J0SzZoVE1ZeVBoUnRDR0pPU3ZwcmRoMlFXWVF3QUFBczRyNkR2WWFrejltMXZHUUNHZFBsT2lIcHFzV1dRL2lpeFZxOUxNUXY2ZnVIQnNkdnVLUytiSnphalNVY0xKRHQyTXV1eklsNVE1Z3F2MGRiV3lwMDJlcEtiVzJwVUZtSmFldWJMak9JZWU4bDliNVJkaDJRV1lRd0FBQXM3dldTbnArSkJTOFV5SGpjNXZSQ3I4bGsrRklBWFk2U2NabWtMMHQ2TzFVYlN5aVVjVlFJWVhLZ3M3MXRjTnVPM2VPbXl5amIyRlNtUzF1czFpNnJhbjBYblFjeU1MQnVPa0hNRHkrcDkvMkVQUWRrSGlFTUFBQUx1TzlncjFmV1dEQVpOemVROFhqZEsrYitqdkZlRmw5UUdzdC9XMko4bUc5UXk3R0lRZ2xobm1GWFp0ZUJnWWtOa2w1K29IczB1cjZ4VEY2M2E5RVAvN2lSOHlCbVZOTDcySE5BZHJnb0FnQUFGaFNRdENuTDd4bnhtTzYxU2x3NnAzMWhiaXk5Z0dVdFA0azN0R1g1aTJ6SE1wZi9MNGNHeDYra2ltTWhuZTF0NDVKQ0JiQXBqSUdVWVFjR0pzb09ERXhzUHpBdzhhVURBeE9IWlkwbjlFOWJWbFZVTGhyQXpJcWZIOFRiSlQ3bi8wdjR5Q1gxdmg3MkpKQWR0SVFCQUdBZTl4M29yVkpjSDg5QU01RkZHWVp4MUdWb2Mvb0xzT1VweTNyREhJMzNrcXBTU1hjZUdoeC96aVgxWldQVWVDemdzS1NXUEY3L25zNzJ0ajUyby8zMkQweGNaVWpiSkwxYzBnc2tlWmUxd055MWlIbEkwbGZZbzBEMkVNSUFBREMvajBpcVcvWmMweW55dU0yemFiMlFMa2ZwMkpLNCtmaDlxanNXY0VqU0xYbTgvbyt5QysyeGYyQ2lSdEx2U0hxWnBKZEthclo5UEpmc0J6RVJTZi92a25wZmpEME1aQThoREFBQUYvak5nWjZXdU9JZk1DNjhZTTFDSUZQaWNaY24vZVNzdDNxNWVJbFpubUk2RTF0ejIrSEI4ZDlzcWkvN0tqVWY4OTE3NS9uNi81WmRtT2FPSDVnd0pUMUhWdWp5TWtrM2FKNmhIUEk4aVBuOEpmVytwOW5iUUhZUndnQUFjTEZQU1NxTnowbGRGZzFrYkV3THZHNzNobVNTQXh1ZWtvTHNkam15Zi8yWFhQNC9IaDRjZjJSVGZka1RWSDFjSU45bkZxSWxUQXIyRDB3MHkrcGk5REpaclY1cWszbGRuZ1l4UnlWOWtyME9aQjhoREFBQWMvem1RTS9Wa3Q1NjhjWHJJb0hNN05YdE1oTUV3MUNQeTJVMEo1c2NwUG1VVk5Zb004dk9icGVqWkpaZkl1bk93NFBqMTIycUx4dmxLTUFjK1Q2ejBPUHN3b1h0SDVqd3loclA1YVd5Z3BlcjBsMVdIZ1l4Z1V2cWZaUFVBaUQ3bUIwSkFJRHpmVzZwYStuNG5QOFd2TXFkZmFUQWRKbTlDNllIU2N4eVpQOU1SMG05ZmJxTHRYLzVxYjN0aFRaSitsZXFQK2JxYkc4TFNSck8wOVUvMmRuZXhvdzNGOWczTUxGaDM4REVIKzhibVBpSnBDRkpkMG42a0pZUndNejk2TGRWNW1aTit2WWw5YjVkMUFZZ04yZ0pBd0JBd204TzlHeVQxUVE5aFl0WisxckllRDJta2V4emszeEtpZ3B1dkpkVXZlbnc0UGg5bStyTHZzelJnRG1lbHRWYUl0ODh5SzZUOWcxTWxFbDZrYXpXTGkrWHRISHV4M05tV3ByWXUwQ2JXOFFNU2ZvemFnYVFPNFF3QUFCSStzMkJIcGVzVmpETHVGWmVYaUJUNG5HdllieVhqTDF0c3Y3dThPREVRNXZxL1l5bGdWbDdsSjhoekFQRnVzUDI5WTlmSmNOSWF2cm9JZ3hpUHJpNTNqL0FZUTNrRGlFTUFBQ1d0OHFHNXVqbnJwbFREbVRHM0c2elBzTUJ3NEpMSytEeFhsSmRpbGZTOXcrZm5yaHVVNTEvbU1NQ3l0OXhZUjRxbGgyMHIzLzhvdW1qRlk5TFJuS2ZERVVVeE53ajZSc2Mwa0J1RWNJQUFJcmVidzcwK0dUTmlKUVJ5UVF5THBmcm1LUXJNeE11TEx4RXdoZGp2cjl1a1BRMVNXL2c2SUNrTTNtNHp1T1NIaXZVSGJLM2Y5eGxTSzFhWXZwb2dwanpURXNLYks3M3h6bWtnZHdpaEFFQVFQcFRTYXV5OFVZTEJUSmVqemxsYjdpdytOS0tjTHlYaFpjdy8yREJyejl5ZXVJREcrdjhYK1R3S0hxZVBGem4renZiMnlLRnRCUDI5byt2bE5YSzVhV1N0c1dsMnFRK0J3aGladTNZWE84L3lPRU01QjRoREFDZ3FQM21RRStEcEEvbjRyM25CaklsWG5lZFBlSENBa0hEd25tREhZdTFkL2taWGZiQzRjczh5Ny9qeU9tSjNSdnIvSTl3cENEUDNKUHZHN0MzZjl3cjZVYWQ2MkowOWNXZm9VbCtMaERFN0pQMEdRNEx3QmtJWVFBQXhlNWpraXB6dkE0eHI5dGNaKzhVMDR1R0MzWXMxdjdsSzFQTE4xTDU1MXdlU2Q4N2Nucml1bzExL2pNY0trWEx6TU4xdmljZkMzcHYvL2dHbmV0aTlDSko1VXU5aGlBbUtmOXZjNzAvektFTU9BTWhETkwybnEvODZvb0RKL29QM25YN2JYeW9BOGhMOXg3b3VTUXV2ZHZJOFhvWWhuSFVNSXhOTml3cDJYQmhPWXUxZi9uSzFQS1g3SEtVakhXUy92M0k2WW5mM1ZqSFdBcEY2dm84Vzk5UlNiL05oeFhkMnovdWwvUmlTYk16R2FYMU9VZ1FzNmgvM1Z6dnY1L0RHSEFPUWhpazdaSzFLN2JmZE4ybVR6Ly82dDJubmpyWXZYdDhNdnlvcEtja1BYWFg3YmVGS0NFQWVlQjJTZTU0Rm9PRitYamM1akphV1REZXk2SkxNR3haOW1zbC9ibWt6M1BJRktXWDVkbjYzdVhrOFdEMjlJOWZLZW1saGxXdU4ybVI2YU5UUVJBenJ6NUpIK0lRQnB6Rm9BaXdIUCs4YTg5L1hidTE1UzB6a2FqMkhqMmx4L2FmMU5IUWFjWGo4Yk9Tbmt3OG5wWVZ6anh6MSsyM1RWQnFBSnpnM2dNOWJaSWVjTUpKc3NKZityUy8xSHZsY2svaG1ReGY4bWlLNlhrWGFNUHlJNUp1M2xqbmY1Q2pwM2hzMjdIN1JrbjUxb3JnUFozdGJmL2lsSlhaWTAwZmZhdXNsaTdiTkdjUTlFeDhyaVM5VE1Pd2Y1bTV2QW1iUDRoNXkrWjYvM2M1a2dGbklZVEJzbjM5dm9PUGJWM2ZlTzNzdjRmSEp2WDQvcEFlUHhEUzZiUGpjNThhbDNSWWlkWXlpY2VUa283ZmRmdHROUEVHa0ZYM0h1aDVRRktiRTA2WTlkWGw0NmJMVlpiT210RGxLTzN4WHRKeFV0STFHK3Y4UXh4QnhXSGJqdDNma1BTMlBGdnRqWjN0YlVkejllWjcrc2Rkc3FhUGZxbXMxaTdQMVh6VFIyZndNNFlnUnBMMDg4MzEvbGR3RkFQT1F3aURaZnYwajRMZVRhc2JUcTVwcWxseDRlOU85QTdwOGYwaFBYMjRSOVBoQlZ2R2pzbHFMVE8zMWN4VGQ5MSsyd2lsQ3lBVDdqM1E4M3BKLysyUWsyZGZZMjFsWTZydlNwY2pXOFo3U2NmL1Nub1Y0OE1Vdm0wN2RxK1I5ZVZSUGsxUmZhU3p2VzFUdHQ5MHp3WFRSMHVxemZVTlNaRUhNUk9TTHQ5Yzd6L09rUXc0RHlFTWJQR1ovM20wOGZLTlRjZnFxOHQ5OC8xK251NUt5U3oyaEt4ZzVpbWRDMmtPMzNYN2JWRktIRUM2N2ozUTQ1RzBSOUlsVGppWnVrM3pzYnFxc3V1U1hUTGhTMGE3SENYN3puKzVvYzdQZEs4RmJ0dU8zZjhpNmQxNXR0cGY2bXh2KzVOTXY4bWVKS2FQZHNKTlNSRUhNWCt4cGQ3UEdGYUFReEhDd0RaMy9PU3g1MTEzYWNzRFpiNFMxMkxQR3g2YjFCTUh1dlg0L3BNYVBMKzdVakltSmUzVnVWWXpUOHBxTlhPYVBRQWdHZmNlNkhtdnBDODU1Y1JhVnVwOXROeGZldjFpUzZITDBRVkxNWEsrL2xGSnQyeW9ZOGFSUXJWdHgrNHRrcDVSL2sxaTBkYlozcGFSY1l1ZTZUdC8rbWpEV0hyNmFDZmNtQlJoRVBPNHBCdTJOUGdqSE1tQU14SEN3RmFmMy9uNFcyKzRZdTAzUFc0enFlZDNuVHFqeC9lZjFOT0hlalFWWHRhNW9rZm54cG1aRFdmMjMzWDdiVFBzRlFDejdqM1FVeW5waUtSNnA1eGtheXZMVG5uY1p0TjhyeUI4eVZtWG8yU1czeTNwbWcxMS9rR09yTUt6YmNmdW4wcmFubWVyZmJpenZjMjJGbjdQOUMwOWZiUmhPUEZ6WXhuTHpQOGdKaWJwZVZzYS9FR09Zc0M1Q0dGZ3UzLzg1Vk9mYTcxODdRZFRlVTBrR3RQZW83MTZiRjlJUjBLRHlYWlhXc3FNcEgwNmZ5RGdwKzY2L2JaZTloSlFuTzQ5MFBOcFNlME9PdUZPTk5aVytobnZaWkVsWkRsOFNYSFp2NVQwaWcxMS9oaEhWK0hZdG1QM2F5VDlPQTlYL1gyZDdXMy90SndGUE5OblRSK3RGS2FQSm9oeDFMYi93NVlHL3djNGlnRm5JNFJCUm5UY3ZlK1hWMTNTdkMyZDE0Nk1UMW16SzZYWFhTa1pnN29nbUpHMDU2N2JiNXRpendHRjY5NERQUzJTRGtrcWRjckoxM1M1OXRSWFYxeHU2MGs1UitGTEFYWTVTdFpmYjZqemY0b2pyREJzMjdHN1FsYTM1NVk4Vy9YVGt0WjB0cmROcFBLaVovb1duajQ2cGVPSElNWUoyMzVTMHVWYkd2eWpITW1Bc3hIQ0lHTys5ZURoUTV0V055eHJoSDRidXlzdEpacTRPWnVkTnZ0cFdhMW1UckFuZ2NKdzc0R2VyMHQ2dTVQV3FkVHJDZGFVKzFzemVVWm52SmVNcjM5TTBvczMxUG52NVNqTGY5dDI3TzZROVAveWNOVS8zTm5lZHNkU1QzcTZ6NW8rMmtoeSt1aVVqaVdDbUZ4disydTJOUGgvd2xFTU9COGhERExtMHo4S2xtOWQxeGhxYnFpcVd1NnlNdFJkS1JuRG1qTUFjT0x2VDk5MSsyMWo3R0VnZjl4N29PY3FTVTg0N2J4WFUrNC9WT3IxTEc4TUI4WjdjY0lGVUsrczhXSDZPZHJ5MTdZZHUxOHU2V2Q1dU9vaFNaczcyOXNtNS92bDAzMWpGMHdmYmRSbUxEZ2dpTW5WdHY5d1M0UC85UnpGUUg0Z2hFRkczZjdqMzE1eTllWlZlMm9xL1I2N2xqbmJYZW1KQXlFTm5NbEpGaEtYZEV6bldzM01kbWs2ZXRmdHR6RXVBT0JBOXh6bythV2tiUTQ3NmNXYmFpcGpobUdZS2IrUzhWNmNkZEZqTGZndVEzcnArbHAvbENNdS8yemJzYnMrY1M1Zm1ZZXIvNDdPOXJadnpQN2o2YjZ4SkthUE5qSVhIQkRFWkhzOVJ5VnQzZExnNytGSUJ2SURJUXd5N282ZlB2YXkxc3ZXL0t5MHhHTjdmUXYxbmRWaiswL3FxVU05bXByTytVUkk0NUwyNlB4V00wL2VkZnR0WjZrRlFPN2NzNy9uVmttL3luWTNsNld2NjQxalRUV1Y2KzA2YXpQZVN3N0t4cmhvK1o5WVgrdi9HNDY2L0xKdHgyNUQwdi9LR2hjbDMreVc5SUl2dk91cTlab3pmYlNVelBUUkJERUZFc1Q4OFpZRy96OXpKQVA1Z3hBR1dmSDNQMy95VDFzdlgvdDNwaXN6VlM0U2pXbmYwVk42YlA5SkhUazVxRmoydWlzbDQ2UXVIZ2o0NEYyMzN4YWhaZ0NaZGMvK0hwZWt4M1RoTjhFT0NHUzhibmV3cnJJc3VmRmdDcUhMVVE3S1BZdmh5NnlZcEczcmEvMTNjZlRsajIwN2R2KzVwTS9uMHpwNzNTNWQwbHdlZTkzem03OVhVKzV0MVR6VFI2ZFNtUWxpN04yZ0xLN25nNUplc0tXQkdkcUFmRUlJZzZ6NXAxODk4L1hyTDEzOTlreS96K2o0bEI0LzBLM0g5NS9NVlhlbFpFekxtajc3U1owL0VERGpDUUEydW1kL3oxc2xmWE1aT1VIR1ZQcExueW9yTGJrcW5iTTBYWTV5Y0hGakpMM3NQa25YcksvMW4rSUlkTDV0TzNiZktPa2VTVzZucit2S21sSnRhYW5RMXBZS2JXZ3FrMzFmYkJIRTVHa1FFNUYwM1pZRy85TWN5VUIrSVlSQlZ2MzdidzQ4ZE9tR3B1ZG02LzBjMWwwcEdYMjZ1TlhNM3J0dXZ5MU03UUZTYzgvK0hwK2tnMHBscXRrc0JqSU5WUldqYnROVmtjcVpPWi9EbHdKczliS1kzMGg2TWVQRE9OdTJIYnViWkxXVWMrUTRNTDRTVTV1Ynk3VzFwVktiVzhwVk5XZDRQU05ERlowZ3h0NE55dkI2M3I2bHdkL09rUXprSDBJWVpOV25meFIwYjFoVmYySmRjMjF6TnQvWDRkMlZsbHg5U2Z0MWJwYW0yVll6SVdvVXNMQjc5dmQ4Uk5MdGRwMGhiVDVobmw1WlcxV1h6QnN3eFhTT0xtU001U3pma0tSUHI2LzEvUlZIb2pOdDI3SGJLMm1YcEpzY2MxRnVTS3ZyL2RxeXFrSmJWMWRvVFlOLzBmdDlncGdjTGpQM1Fjd1JTVmR1YWZCUGNqUUQrWWNRQmxuMzZSOEY2Ni9ZdVBMRWl0b0tmeTdlZjNSOFNrOGM2TmJqQjBMcUh4ck41NkljMHNYVFp6OXoxKzIzVFZETFVPenUyZDlUTCttd3BLcE1uQzJYZS9KMG02N0hHNm9xcmwxc1lZejNrcU1MbU9XSEw3UGlrbDYydnRiWHlSSHBQTnQyN1A2YXBIZm1lajBxL1I1dFdWV3VMYXNxdEhsVmhmd2xaa3FWbkNBbWg4dk1iUkR6TzFzYi9MczRrb0g4UkFpRG5QanNUeDY5OXJxdHE0UGw1MTF0WkwvaWgvclA2ckY5SVQxMXFGdVQrZEZkYVNteHhJM24zRll6VDBvNmZ0ZnR0OFdwZVNnVzkrenYrVWRKNzh2R21UT2RFMmxaYWNtamxXV2wxK2ZpeE14NEx3c3YxTEIvclFZa1hidSsxdGZOVWVrYzIzYnMvbE5KZjVlTDl6WmRodFkzbG1sTFM0VzJyS3BRYzIzcHNpczhRVXdPbDVtYklPWmJXeHY4YitWSUJ2SVhJUXh5NW5NN0gzL0xEWmV2L1Mrdng4eDVwWTlHWTlwM3JFK1A3VCtwUTEwRCtkWmRLUm1qU25SajBybFdNMC9kZGZ0dEk5UkVGSnA3OXZkc2tyUlhraWZiSHlySm5sVHJLc3RDWG8rN0pac25aTVo3V1hqQlJtYlg2Z0ZEdW1WZHJZOFo4UnhnMjQ3ZEw1ZTBVNUlyVys5WlYrRjlOblRadUxKY3BSNlg3VldOSUNhSHk4eHVFRE1rYWV2V0J2OEFSek9RdndoaGtGUC84SXVuUHRWNitacVBHb2JobUVvL09qbXRKL2FIOU5qK3ZPK3VsSXpqdW5nZzRNTjMzWDRiZzBraWI5Mnp2K2UvSmIzZUNXZlZCVDV2cHB2cXFrb01NZDVMemk1U3NoTyt6SDNtWjlmVitqN0MwWmxiMjNic3ZsVFNRNUlxTS9rK0hyZExtMWFXVzkyTVdpcFVYMW15L0xwTkVKT1R6d3NIQmpIdjJOcmcvd1pITTVEZkNHR1FjMS81OWQ2ZlhyMTUxWFpIVlBnTG50Q2Q2SzcwNU1HQzZhNlVqRWxKZTNRdWxIbFMwdE4zM1g3YmFXb3JuTzZlL1QzUGw3VGJpV2ZZMlgrNlhNYStwcHJLUzUxOWNpL2NMa2ZwTDk5WTdyTmVzYTdXOTNPTzB0ell0bU4zZzZ3QVprTW1sdDlVVTZvdHF5cTBwYVZDNnh2TDVEWU4rK3M1UVV4T1Bqc2NGTVRjTGVrbFd4djhkQzhIOGh3aERCemhtdzhjMnJ0NTdZcmMzNVFzY0pFZWpjYTE5OWdwUGJhdllMc3JKYU5iNTdvMHpZNDNzLyt1MjIrYm9RYkRLZTdaMzNPL3BCdWRmTGIxZVQyUDFGYjRiM0RtU1QxMzRZc3pXNzBrLzhva25uVmEwblhyYW4xZEhLblp0VzNIYnIra3V5UTl6NjVsK2twTVhiS3lYRnRiS3JTNXBlSzg2YU16V3U4SlluTHlXZUtBSUdaYTBsVmJHL3dIT2FLQi9FY0lBMGY0OUkrQy9pMXJWNXhjdGFLNk5tZVZmY0Y3ai9QL05Ub3hyU2NPaFBUWS9wUHFPejFhN0x0dVJ0YllHK2ZOMG5UWDdiZjFVcXVSYlhmdjcvNWRTVCt3amxybm50NXFLdndIL0NXZUxjNDZrZFBsS04yMVNuSDVEMG02ZVYydGovQTZTN2J0MkcxSytwR2tWeTAzTEdpcDkydnJLaXQwV2J2RTlORVpQUVlJWW5MeXVaTGpJT1pqV3h2OGY4c1JEUlFHUWhnNHh1MC8vdTNhcXk1WmRiQzJ5dS9OZWtWZjlNdmZoVi9kM1Qrc3gvYWYxSk1IdXpVeEZXWW5uak9nODF2TlBDVnA3MTIzM3paRjBTQVQ3dDdmN1piVmpXN3p4VWV3czA1MUsrc3FaMXlHc2V4Qmd3bGZGbCt3dzhLWHViNndydGIzUVk3YTdOaTJZL2UvU0hwM09xK3Q4TG0xT1RHZzd0enBvdzBuSEE4RU1UbjVqTWxSRUxOUDBqVmJHL3hjYUFJRmdoQUdqbkxIVHg5NzRYTXVYWE8zcjlSalpMV1NKOWtLWnFHWFJhTXg3VHZlcDBmM25kVEJybjdGWW5UWG5VZFUwa0ZkM0dybUJFV0Q1YnA3Zi9jZlMvcW5wUS8xM0o3MkRNTTQwVnhYdVRhM0oyNm1tRTUzcld4YzkxZXZxL1g5bENNM3M3YnQyTjB1NmRQSlB0OTBHVnJYV1BiczJDNHJGNWsrbWlBbUU1K1ArZkY1azRNZzVnVmJHL3dQY0VRRGhZTVFCbzd6ZC8vN3hIdHV1R0x0bDAzVGxaMEtubVlBczlBenhpYW05ZmlCa0I2bHUxS3loblh4REUzUDNIWDdiV01VRFpKeDkvN3VDa2xISkRXazl2bVEvVk9nMTJQK3RxR3EvRG01T1dFejNrdTZhNWFCOVQ4ajZmcDF0YjVqSE1HWnNXM0g3cmRKK3NaU3o2dXQ4RDRidW14YVdTNXZDdE5IRThSa1lQc0pZaTcwMWEwTi9nQkhORkJZQ0dIZ1NGL3FmUHBmbm5QWm1uZG52SUxiSE1CY3FMdC9XSS9TWFNrZGNVbEhkYTdWek94QXdFZnZ1djIyR01XRHVlN2UzLzBwU1I5ZDNtZEZkazZIbFdXbFQxYjRTcTdPN2ttYUxrZnBybFdHeXlkb0dIckIyaG9mSndlYmJkdXhlN3VrSDBxNnFOdWZOWDEwbVRhdnF0Q1dsdklMcG84MkhGSEhDV0x5NDdNb0MwRk1uNlN0V3h2OFp6bXFnY0pDQ0FQSCtyZDc5OTkvK2NhVk4yYXNjaTk2TTJMWWV1REU1blJYT2tCM3BlVVlseFhHekk0Mzg1U2twKzY2L1RZdVVJclUzZnU3VjBrNkpNbG4zNGt4YzZmR3hwcUtzMjdUVlozNWs3T1J5ai96NStLaUFNS1hDKzdIL21GdGplOERITW4yMmJaajkwMlNmam4zTTZHcHBsU2JWNVZiMDBldm1ETjl0R0hQM2llSXlmaHg0dGpQcFF3SE1XL2UydUQvSGtjMVVIZ0lZZUJZbi81UjBMV3V1ZTc0aGxWMXF6TlNzWmM1RGt6SzY1TDR5OWpFdEo0NDJLMUg5NTFVNytBSU85b2VYVXFNTWFOenJXWU8zblg3YlJHS3ByRGR2Yi83YTVMZW1ibVRwSzJueWJPcjZxdXFNM3RTWnJ5WGROY3E0Mld6OEJ2ODd0b2EzNDg0bXBkdjI0N2RWMHY2amM5clZtNXF0a0tYemF2S0w1bysybGh5eHhQRXBQcW1CREgyYnBBaC9YeHJnLzhWSE5WQVlTS0VnYU45K2tmQjJzczNyRHpSV0ZkUmJtdkZ6bkEzcEl1ZXU4Q0xlZ2FHOWVpK2szcmlZTGZHSjJtUmJyTnBXYlBsWERnUWNEOUZVeGp1M3Q5OVpXTGZadVZjdHR4QXhtMjZubXlzcWJnNk15ZGp1aHlsdTJZNURGOW1EVXU2Zm0yTjd3aEhkWG9lN3gxMVBYbHMrTFduUjZiL1krUEs4ckkxU1V3ZlRSQmovMW9TeE5pMlFST1NMcnUwd2MvRUJVQ0JJb1NCNDMzbWZ4Njk0cnF0TFk5WGxKVzZiYW5VYVU1SG5jNEJZeVQ1d21nc3B2M0grcTN1U2lmNkZZMHg3RWtHbmRMRnJXYjIzblg3YmFSZ2VlYnUvZDAvbC9TeTNKdzhVejk5bHBWNmYxdGQ3bnVPdlNkZ3dwZDAxOG9CNGN0Y2owbHFXMXZqbStiSVRzN2p2YU5Oa2w0cTZXWHh1RjVxR0twWlZtMGhpTEZsTFFsaWJObWdEMTdhNFA4Q1J6bFF1QWhoa0JjK3QvUHgxOTV3K1pvZmVqMXVZOWtWT2tmZGtKSmQ5dGprdEI0L1FIZWxMSXRJMnEveloyaDYrcTdiYnd0Uk5NNTA5Lzd1V3lYOXloa24wdVErSGVxcnlrNlVlTnhyR2U5bDhRVm5Nbnh4V1BCeW9TK3ZyZkc5bDZON2ZvLzFqbm9OcVUxVzhQb3lTVmZiWHA4SllteFpTNEtZWlczUTQ1SnV1TFRCVDNkcW9JQVJ3aUJ2ZlBFWFQvNzFEWmV2L2FTeHdJa3JGOU5STC9sY1kza0hZcy9Bc0g1TGQ2VmNHdEw1d2N5VHNsck5URkEwdVhQMy9tNlhwRWNsWGVPOGsrcUNCLzNNcXJvcXovSnVKQmp2SmQyMWNuajRNdGYvV1Z2aisyK09jc3RqdmFNYmxHanRJdW5Ga3NvemZ1Tk1FR1BMV2hMRXBMVkJNVW5QdmJUQi8xdU9mcUN3RWNJZ3IvenpYWHUrZisyV2x2K1RWbVhPZGdCajR3VlFOQmJUUHJvck9VVk0wbUZkSE02Y3VPdjIyNWoyS2d0K3ZiLzcvMHI2RDZlZnhPWUdNaTZYY2FDNXRuTExzay9WdEhwSmFjM3lLSHlaTlNicHVyVTF2a1BGZUd3LzFqdjYvOXU3OC9ESThvTGUvNTlUVzVaSzBudlM2VWt2c3pMZGsrN3BaZEk5d0lDQ0lNTXdBK01WOWNwNEZhOWVlaEFkTmhYMS9zVG5lcEZoRTFFVWFQaUp3aWlpZ095Z3lJeUNPRnQ2ZW1DWVhtZnRKTDBuNmV5cDlaejdSMVYxS3RWVlNTM25WSjF6NnYxNm5ucXluWHpQa2pybmZNOG4zNlZkMHN1MEVMeGMyNUFIWjRJWVc3YVNJS2JpSGZyenJldmEzOFpkSHZBL1FoaDR6dC8rMTFOUHZHQno5L2FLM3NoMW5JNjYybTVJNVZab1p1WXpzeXNkUERxczB4Y21lVU80eDdRV3hwckpCVE5QM24vdlhmUXBzOUVEeDA2MVNUb3VhYU9YYm1odGtjaWphN3ZhOTFaOWl5WjhrWWZIZTZsMEwzOGs2ZVpOcTlwaXpYQk9Iem96M2E5TTZQSnFTYmRJYW5IRmd6TkJqQzFiU1JCVDlnNE5Lek1ZN3d4M2VzRC9DR0hnT1gveTVjSEl0WnZXbmRyWXMycHQyVzlpRjQ0RFUvNWlwU3N5WjBhbmRQRG9rQTRkSDZHN2tuczlyNFVCZ0hPek5EMXovNzEzcFRrMGxYdmcyS2wzU1hxZjEyNXVxenZhajBaYkkxdHJ1RmpWSjF4d3VOQW1IdStsMHUwL3NHbFYyOTErUEljUG5abGVKZW1ubEFsZFhpWHBDdGMrT0JQRTJMS1ZCREZsN2REcnRxNXIveHAzZWFBNUVNTEFrKzc5eXNFcnRsK3o0ZWsxSzZPdFhwbU91cGJIaXVXV05TMUxSNTgvcDROSGgzVHNPYm9yZWNDOHBDZTF1TlhNRS9mZmU5YzRoNmEwQjQ2ZVdpUHBHVWtyS2prNTNYQ2oyN0M2S3g0TUJGcXFUU29ZNzZWeGY5ODZoeS81N3RxMHF1MXpYajl2SHpzekhaQjBrNlJialV6b2NyT2tnR2NlbkFsaWJObEtncGdsZldscmQvVDEzT1dCNWtFSUE4OTYvOWNPdldoZzI4Yi9iRytOQktwN3J2RldONlJ5QzV1YlQralE4Ukc2SzNuVEtTMmVQdnNKU2NmdnYvZXVKSWRHZXVEb3FZOUllbXN0SjJzamJucUdZWXowclZuUlYrbEZpaTVIamYxYk5qQjh5Wm1WZE5PbVZXM0h2SGF1UHBZM2ZiU2tWMHBhNDZvd290SXlDV0pzMlVxQ21LS21KRzNkMmgwOXpWMGVhQjZFTVBDMFAvM200NysycjMvTC94OEtCaXA4dnZGSkFMUE1nOXZwMFNrZFBFSjNKWTlMU2pxaXhRTUJQM0gvdlhlZGJhYUQ4TURSVTFkTE9pb3BiT2ZKVzQrYllDUVVmS3huWmVlZU1pOU9oQzhOL0p1NUlIZ3BYUHBKU1hzM3JXcWRkL1A1K2RqcDZZZ0twNDgyWEI1R1ZGb21RWXd0VzBrUWM1bTNiTzJPZm95cUR0QmNDR0hnZVIvOXpvOC9NckJ0MDVML0hmZHJONlJ5SDk1TWM2RzcwbEc2Sy9uRkJWMCtROVBSKysrOXk1ZURlVDV3OU5RL1NmbzVKKzl3VHQwUXU5cGJIMS9SM3JxTExrZTFYaEVkUERidUMxL3kvZldtVmEyLzdyWno4ckhUbDA4ZlhjbU9FOFEwZU44Sll0endkM3BJMGkxYnU2TlV5b0FtUXdnRFgvalV2eC85N3Zack4veFVzWGUyMTZhakxydWlVdVYvejJmbkUvcmhpVk1hUERxa1UrZnBydVF6YVVrbnREQVFjSzdWekpDWGQrcUJvNmYyU1hxNG5uYzdPMitPNjFkMmpZVkR3VFdsQ25hMFpZZkRCUk8rMkh2Tlg4SWJONjFxL1V3ano4UEhUcGMzZlhRbHUwWVEwK0I5SjRocDVOOHBKV24zMXU3b2o2bTZBTTJIRUFhKzhONHZEd1kycjEvOTlOVWIxMTdwcCttb3l5MnMydTArTXphbGcwZUdkZWo0aUtibjRyeVIvR3RTQzJQTTVNYWJPWHovdlhkNVlpck1CNDZlK2s5bHBxNXR5SjJ2eGh2bDlNYTFxenJwY21SekpPSENoeldIOTNST21XNUpoK3Q1N2gwOHZYajZhS1BNNmFNcjJVMkNtQWJ2TzBGTW8vNU85Mjd0anY0QjFST2dPUkhDd0RmZSsrWEJqcTFYcmovVnU2NnJxL2diM052VFVTOVZtRkhqU1crYWxvNmRQS2ZCSThNNjh2dzVwZE8wakcwQ2xxUm5kZm4wMmMvZGYrOWRybmtEUEhEMDFKMlN2dXlXdTJDbDE0bFFNUEJFNytvVk8rb1dMamhjTU9POTJMWHRWVDJ3SDVHMGQrT3ExbG1uOXVIZzZha2kwMGNiOXZ5TkNHTGN1KzhFTWZYZS8yY2tiZC9XSFhYMVdFOEFQRmhmQXhyaC9WOTc3THFkTDdqaThJcU90bEN6andOVDdiYk14Ukk2ZEp6dVNrMXNWZ3RkbVhMaHpJL3Z2L2V1aVhwdnlBTkhUNFVrSFpaMG5SdnZpT1VzSG0xdEdWemQyVDdBZUMrTnE0aDRzTlhMVXZlYnoyeGMyZnBHdTdiOTRPbXBnS1E5eW9RdVB5M3BoU282ZlRSQlRORXlDV0pzMmNvbURHSmV1YTA3K2wycUcwRHpJb1NCNzN6dzY0ZHUyOWUvK1JzdGtaQlI3bHU5MmJvaGxidnNtYkVwRFI0ZDFxRmpkRmVDaGxRd1E1T2twKzYvOTY2VVV5dDg0T2lwMzVEMFYxNjRPNVphZk4yS2p1ZmFJdUVyUFhVREozeXhlZnR0Q1YveS9mckdsYTEvWGUxMkh6dzl0VjZad09YVzdNYzExZXdIUWN4U0t5Q0lxWFNsVFJURTNMZXRPL3JMVkNtQTVrWUlBMS82eUxkLzlMdjcramUvUHhBdzVOZnBxQTJIVDNZajc1Y3lzeXVkMStEUklSMTVqdTVLdUNTdVRFdVZSYk0wM1gvdlhhTzFGbnovMFZPZGtwNlcxTjN3bTFYMWdVeDY0OXFWQWNPdzkxR0FMa2YxZi9DcTE1NldPZGg3VE5MZWpTdGJ5eHJRYy9EMFZGalNpNDJGQVhWMzJyWDNCREZMcllBZ3B0S1ZOa0VRTXk3cCttM2QwUXRVSDREbVJnZ0QzL3I0ZDUvOHU5MWJOOTFsNTBuZ3AzRmdsbDIrUkExekxwYlE0OW51U3NQbkpuaWpvWml6dXJ6VnpKSDc3NzByV1c0Qjl4ODk5WDhsL1grdXUzRlZzUEtBWVR5MWNlM0theHV3NnFvS2RqSjhhZklwcG0yL3QwZzZMdW1talN0Yml3NnVQWGg2NmtwbEFwZFhLVFBHUzRkOWZ3ZUNtS0psRXNUWXNwVStEMkorZFZ0MzlHK3BJZ0FnaElHdi9jMFBUZ3h1dTNMOVRYYWNBRjZjanJxbS9TeGpoOCtPVGV2Z2tTRWRQRFpNZHlVc0p5WHBtQlpQbi8yaisrKzk2M1RoZ3ZjZlBiVkJtVll3YmE2K2lTMno4clpJZUxCN1JjZUFLMi9VZERteWVmdHQ3M0pVanIvZnVMTDFseVJwOFBSVXU2U2YxRUx3Y3AyemZ4T0NtUEp2bFFReGxhN1VwMEhNQTVKZXNhMDdhbEVkQUVBSUExOTc3NWNQUnE3WnVIWm9jKy9xbmxyZi9NMHlEa3ladGNwRlB6RXRTOGV5M1pVT1AzdFdLYm9yb1h6anlnWXl5ZzRFL0h1LzlCTnZDUVNNTjNycWhsWms1YXM3Mmc5M3RyWGM0S3FiTStHTHpkdmZrUEJGa3BReUxjMGswMStLcGMwVmtsNmlDcWFQSm9oeHNFeUNHRnUyMG1kQlRGelNqbTNkMFJQYzhnRTB2TTRLMU1ON3YzeXdlOGUxRzU1ZnQ2cWpyZVlnbzhIandGUzY3WFoyUXlxMzdQelpsZWl1aEVxdFd4blZyOTl4azJvZFJxWGhOemRENmx1ellpNFlDTFM3WXJzWjc4WG1iWGRzdkplU1RFdEtwRTNGMDZZU3BxVzBaYm5nSENHSUtmL3ZTeEJUNlVwOUZNVDg0YmJ1Nkh1NHd3TndUVDBWcUljUGZPM1F3SjZ0R3gvdWFHOEpWUHJHOS9OMDFKY3RhNVJmUWpsbG54MmIxaURkbFZDQlgvaXA3YnI2aWpXMmx0bUlHNTFoNk95bWRhdldOM1FialZyTHA5V0xyUS9TVmV4SDByUVV6d1l2eWJSbCs0RW5pSEd3VElJWVc3YlNCMEhNRVVtN3RuVkhFOXpoQVRTeWJnbzB4SjkrODRlL3RLOS84MzJSVU5DeENuU3pkVU1xdCt4Y2Q2Vkg2YTZFSld6cFhhVTN2UEpHWDl6MElxSGdvZDdWWGJzYnNqMTBPYko1Kyt2WDVjaTBMTVhUQzhHTHVWenVRaERqdXVzQlFZejlXK254SU9hV2JkM1IvK0lPRDZBUjlWSEFGVDc2cno5KzM5Nyt6ZTh5S2oxQm1tZzY2dVZLcUhWYjV1TkpIVG8rb2tlUERtdm83RVhlbE1oV2lBMzk2bXQyYS8zcVRsL2NBRmRFV3crdGpMYnRydXQ2NlhMa2lqMnROSHpKZERIS0JDOUowNnA4cXdoaVhIY2RJSWl4ZnlzOUdzUWMyTllkdlpzN1BJQjYxNlVBMS9uVWZ4ejkxbzNYWHZGcXV5dlNmcHlPMnBheWwvamh1ZkZwUFhwa1dBZVBEbXRxTnNhYnM0bjFYOVdqMTk2eTFUYzN3L1dyT3MrMWhFTTlkYm5oK2lCOGFhWXVSMm5MVWp5VmJlMWltcXBtYUJlQ0dQZFhoZ2xpN045S2p3VXg1eVJkdjYwN09zRWRIa0E5NjFTQWEvM2RRMDhmdjI1VGQzbFRlTklOcWJheXkvaWhaVms2ZnZLOEhqMHlyQjgvYzRidVNrMG1GQXpvN2p2M3FpdmE2cGNiNCt6bTdsVlJSMiswZERseVlQdWRDVjhzTFc3dGtqSXRaL2FOSU1aMUZXS0NHUHUzMGtOQnpDOXM2NDcrRTNkNEFFWHJ2aHdDTktQaHN4TjdvcTB0dzFkMHIxaFp2NHBHOHdRd2xXNWt3REMwZFV1UHRtN3B1ZFJkNlpFamRGZHFGamRkZjRWckFwamNRM010Ny8xZ0lQQ3NJVzEzTWxVZ2ZMSDN1bHgxK1NWK1BXVmFpbVdEbDRSRG9iSlZ1SHFyOWorY1pjdmZmbkVwVlplNXhDOWFEcnhISFMrejZBb3FYNnNyOXIyTVg3Qi9Pek1sT3JML2x1M1hwRzhSd0FCb1pEMExjSzMzZmVXeHEzZTk0SW9qcTdyYUk1VlVybXVwNk5NTnFiSjl6SFZYR3FTN2ttKzF0WVQxR3orelR5MFJiL3hQb0p4em9hTTFNcmkyS3pyZ3hJb1o3NlZ4ZTdyVTVkSzBkR2t3M1hpNitQVFJScjMybVJZeHJxc1kweUxHL3ExMGNZdVlPVW5iYnVpT251UU9ENkJSOVMzQTFUNzA5VU92SExoaDg3KzJ0WVFYWnhKTVIxMWIyUlg4c0p5eUxjdlNNYm9yK2RJckJxN1d3TmErdlBlRGQyNUxwYmEwczdYbC9KcXU5bTQ3VjhKNEwzWnR1MzFkanBLWFdydVlTcVN0aGg1bmdoajNWNDRKWXV6ZlNwY0dNZSs4b1R2NlllN3VBQnBWN3dJODRTUGYvdEU5Ky9vMy8za3dFR0E2YXJ2S0x2T0hsVDQ4R2NyT3JuVGlsQjQ5TXFUbno0enpCdmF3bFoydDJ2KzZ2UW9FakNYKzR0NjZtVnFXdEhIZENvVUNnWm9Mbzh1UnZkZmdxc3ZQZm1KYUM2RkxQRzJwMnFGZENHTHMzeGlDbUFidk8wRk16dU9TOXQ3UUhVMXhod2ZReURvWTRBa2YrN2NuUHpXd2JkT3YyMStaY0ZjQWMybjVlbmREc2ltQUtYVCs0b3dlT1RLa3dhTkRtcHlodTVMWDNQblNiZHE2WlYwTjd3RDNtWnlKYWVkVnZUWGRrUWxmN0wzK1ZsdStaZVFHMURWTFRCOXQxR0VmYWl5WElNWjFsV1NDR1B1MzBpVkJqS2xNQVBNWWQzY0FqYTZMQVo3eE45OC8vbEQvTmIwMzIvMm93emd3cWptRVdlNEIzTElzSFIrNm9FZU9ET25IejV4Uk1wWG1EZTF5dldzNzljYmJkbGQ1NDNMdnJXdHNjazQzWFh0RlZTY1A0NzAwYms5enY1SE90bmFKRlV3ZjdjU1E1UVF4OW04TVFVeUQ5NzI1ZzVpUDNOQWRmVHQzZHdEbFlIWWtJT3ZzMlBTTDI5c2lRMWRkc2VhS3VsVWdEQWZMbGt2S2RqaUF5VlNVREYyL3VWdlhiKzVXTEpIVW9lT245QWpkbFZ6dHAvWmNYZlgwR1ZiZS9FVnVDMlE2MjFvcVBuR2NERitZWW5wNXVaWXVzZnpwbzQzQzkxeXAwcXVmcThWeTZPL0RyRWtPSDArN3kyVFdKRnUyc3NHekpnMUwra1B1N0FEYzhGd0dlTTY5WHptNGR2czF2Yy8zck82TTFuYkNOTmQwMVBYdWhyVGs2dkorNGZ6RkdUMXllRWlQMGwzSlZhN3RXNlBYdjZ6ZjlqdVNHd0taZFYxUmRiUkdsajFaNkhKazEvWlh2aUVwMDdvVXVpVFNwaXhicmwrMGlLbTJGRnJFTExVQ1dzUlV1dElHdFloNTdRM2QwYTl6ZHdmUTZIcy80RmtmK05wak8vZHMzWGl3SzlvYXJPV2hnRzVJcWpGb3F2eVJ1bFJGeWJJc0hSdTZvRWNPMDEycDBRS0dvVjkvN1UxYTA5WHU2TjJwRVlITWZEeXBiUnU3bDl3ZndoZTd0ci84SlJkUEgyMFduVDY2a3RVUXhOaS9aUVF4UzYyQUlLYlNsZFk1aVBuU0RkM1IxM04zQitDRyt6N2dhUi8rNWc5L1lWLy81bitJaElNVnpsck5kTlRWUGJ6VS9oQmQ3c05oTEpIUzQ4ZEg5UENSSVQxM211NUs5YmJydWcyNmRkKzFkYjFUMVN1UUtUb2VET085Mkx6dDVTMmR5R3Z0a3F4MVNudUNHSWUybFNDbWFKa0VNYlpzWloyQ21DbEoxOS9RSFQzRDNSMkFHKzc1Z09kOTlGK2YrRC83K2plLzJ6QU11aUZWdW15RHV5R1Z1KzBYSm1iMDhPRWhQWHBrV0JNejg3enBIUllKQlhYM3oreFZkS251T2c3ZnRad01aS1puNDlweDVmcEYyOGg0TDNadC85SkxwNjJGMENVemZiUmw3N0VpaUhGb1d3bGl5cjlORThSVXV0STZCREcvY1VOMzlPUGMzUUc0NVg0UCtNSW4vLzNJbDNlL29POU8yMjc2VEVkdCsyTnl0UUZNUGt2UzhaUG45Y2lSSWYzb2Fib3JPZVdsTjI3UmkzZHNkczFkek81QXBqMFNVYytxS0YyT2JOdiswa3RhV3BnK09sWjArbWdIamh0QmpFUGJTaEJUdEV5Q0dGdTIwc0VnNWlGSnQ5elFIVFVGQUM2NTF3Tys4WGNQUG4zNCtpM2QyMnk1MlRNZHRlMFB4b1poN3pHTUpWSTZSSGNsMjNXMFJYVDNuZnNVRGdWY2VVZXJOWkJKcFUxZHUyR05vNDlJelI2K1hKbytPclY0K3VpNlZub0lZaHphVm9LWW9tVVN4Tml5bFE3c2Y4b3d0T3VHN3VpVDNOMEJWSU1wcW9GbGpKeWYyQk50aTR4czdGbTV4czRhQzlOUjEvNGc3TVJEWTJza3BCZHQzNklYYjk5eXFidlNJM1JYcXRsTGRsNnBVQ2h3YVNZYVI5NmpWdlVuUWEzVFhrL1B4aDJiVHRuUjg5bkZYWTRzbFpnK3VzYTNpR0Z6QVV4ZnpmVFZqcFhKOU5XMmJLVUQrLzlCQWhnQWJuMVdBM3pqQTE5OWJPT04xMjE0YXMyS2FFdXAwNGpwcUd0L0FLdDNONlJ5bDgxMVYzcjR5TENlZVBxMEVuUlhxc2k2bFZIOXo5djN5Q2p4eE8vNGphZ09MV1F1VHMxcno3VWJiTnVZWmgzdkpWbnU5TkdOcnZ6UUlzYWhiYVZGVFBtM2NGckVWTHBTbThwOVJsSi9mMDgweHQwZGdOdnU3NER2Zk9qcmgxNjY5NFpOLzk3ZUdnbFVmR05uT21xYkhuV3JlNGkwTDJneU1yTXJuVGlsaHcrZjFMT254aHg3U1BTVG4zdDV2NjYrWW8wamY2dDYzdldXZXBjYWxuVGwrbFUxcjdqWnVoemxwbytPVlROOWRLTXJRQVF4RG0wclFVelJNZ2xpYk5sS0c4cDlaWDlQOUx2YzJRRzQ3WjRCK05hZmYvdEhkKy9yMy96eFVEQWdwcU91OW1Ha3NvZmJXaDhrN1F4Z0NsMlltTlVqaDAvcTBTUERHcCtlNHdRcFl2UDZsZnJGVjk3b3podVVqVE10YlZxN1FwbnJRaTJSaElPNzZxTHdKVkhRMnNYVGxTQ0NHSWUybFNDbWFKa0VNYlpzWlEzbDN0ZmZFLzFsN3V3QTNIaS9BSHp0WS8vMjVGL3V2V0hUVzVpT3VwcUhrT1VlWmN2Y2xqcDFRMXJ1Q1RiM1hVdlNpYUVMZXZqd1NmM3dLYm9yNVh2amJidTFmazJuKzI5V05heGdlamF1blZmMVZobEpPTGhMTGdsZVRNdFNMSjBMWGk2ZlB0cnpGU0dDR0llMmxTQ20vTnM2UVV5bEs2MmkzREZKVy90N29oZTRzd053ZmIwVzhLTlBmLy80OTNaY3MrR2xURWRkYTludUNXQksxMjByRzhja2xranBFTjJWSkVrM1hObXRPMjdaNnIwYlY0VXJHSnVjMDk3citrU1hvNHpNOU5GV1JkTkhlNzR5UkJEajBMWVN4QlF0a3lER2xxMnNzTnhmN2UrSi9pMDFZQUIyWUhZa29Bcm54NmRmOXN6STZMUFg5SzNkN0lZSGdvYU5BK1BDeWxvOTluT3BaVnNqSWIyb2Y3TmUxTDlaRnlabTlYQ1RkbGNLQmdONjZhNHJIU25iY3ZvOVd1RXNTeDJ0TFdVdDZPZndKWjF0N1ZMTDlOR054S3hKekpya3F2ZlRjbVV5YTVJdFcxbEJ1UTlJK2d5MVh3QU5ld1lDa1BHK3J4eGMyWDlWNzFEdjJxN081YzRzdWlFVlc5Ylo2YWpyMFEycDNMSXZkVmM2TXFUSG56cWxSTkwvM1pYMmJkdW9sKzI1eWw4M3RSS0ZyKzJNYWtWN2E4TnV0STBJWHhhbWo3WnNtejdhRjVVaVdzUTR0SzIwaUNuL1ZrK0xtRXBYdWt5NWNVazcrbnVpSjZqNUF2QkVmUlh3dXc5OTdkQzIzZGR2L05HS2p0WlFxYk9LNmFpTEYrRDFjV0NxTFQrZXpIUlhldWp3a0o0WkdmVmxkNlhXbHBEdXZuT2ZXaU9OYld4WmowQW1sa2pwaG8wOWRiKzVOaUo0V1pnKzJuSjArbWpQVjR3SVloemFWb0tZOG0vNUJER1ZyblNKY3Yrd3Z5ZjZIbXE4QUR4VFJ3V2F3WWUvOGNNN2J1N2YvTldXU0tqb25aenBxQy8vWmE5TVIrM29NWlEwT2ptcmh3OFA2WkVqUXhxYjhrOTNwWmZ2dVZwN3QvVTF4YzF1YkhKT2UxK3dzVzQzMVhxR0w0dW5qN2JxT24yMDU5OHZCREVPYlN0QlRORXlDV0pzMmNvaTVSNlJ0S3UvSjVxZ3RndkFDL1ZTb0tsODlGK2UrSU1YYnQveUowYWd0Z29pMDFIWDl0RHBaQUJqNnpFc1lCblMwOE1YOU5DVG1lNUtjUTkzVjFyWjBhbzN2VzZ2QWdIMzNsN3MzTExwMllSMlh0M3JtL0JsOGZUUnpUeXNORUVNUVl6N0s5d0VNZlp2WlVHNXQvVDNSUCtMV2k0QUw5d1RnS2IweVFlTy9NT2VyUnYvdSsyQndGTExNaDIxL2Z0WjV3Q21jSlh4WkVxSGptZTZLejN0d2U1S3IzdkpWbTNkMHQwME44SDJjRmdiMW5RNXQzMkdzL3UrZVBwb1UyWno1eTcyVjVJSVloemFWb0tZOHFzQkJER1ZyalJiN29IK251amRYQVVCdUxKK0FXREJmUTgrOWNOdFY2Ni9rZW1vaXhmZ3QrbW83ZGlXcFI2eWM5MlZIajdzamU1S3ZXczY5U3UzN1c2YUcyTGFOSFZkNzFvWk5pY2xUZ1l2bHFTa3g2YVA5bnhGaVNER29XMGxpQ2xhSmtHTUhWdDV6cEN1NysrSlRuQUZCT0FFcHFnR2JIVHEvT1RlYUd0a1pFdnY2bldPaGdkTVIxMjMvWFQwR0M2ejhOb1ZVZDMrb3ExNnpZdTI2cW5oQzNyNDhKQU9uVGl0ZURMbHl2Zi95L2RjN2VuenQ4S1pxVFU5bTdBMWdIRXFmTWxOSHgzMzZQVFJibmhmTUgyMXZTdGkrbW9IeTJUNmFqdTI4aDRDR0FCT29pVU1ZTE1QZnUxUTc0NXJlcDlkdDZxajFiRkFnT21vN2QvUGVuZERNcW9wMjFnMHU5SlR3eGRjMDEzcG1yNDFldjNMK3B2cVJubHhhbDREMTlVK0FMSGQ0WXNsS1pHZHhTanVvK21qUFY5aG9rV01ROXRLaTVqeXF3YTBpQ25ETjdmM2ROek9GUStBcStzVUFDNzM0Vzg4ZnZQQXRrMy9GVzJMQkd3UEQraUdWUHN4TFBNcHVGSGRrTW85aW1OVGMzcm84RWs5ZkhoSW81T3pEWHUvQnd4RHYzYkhUVnF6b3IyNWJwcW1kTTJHTmRXWFplTWRPR1ZhbDJZeDh2UDAwWjZ2TkJIRU9MU3RCREhsVnhFSVlwWXdLK21HN1QwZEo3bmFBWEIxZlFKQWNSLzUxZzkvOVlYYnQzdzZIQXJhOTREUGROVE83R2NkcHFPdTVlSGJLR01OSjBaRzlkQ1RKM1hveEttNmQxZmFlVzJ2YnIzNXVxWTd4emV0V2FtV2NOQ3g5L2RTVEN2WDJxWDVwby8yZk1XSklNYWhiU1dJS1ZvbVFVd2wzcm05cCtQRFhPVUF1TDR1QWFDMGovM2JreCsrdVgvejIydCthSyt3NXN0MDFCVXM3NUZ1U09WS1pMc3JQVmluN2txUlVGRDc3OXlyYUZ1a3FjN3RtYm00ZGwyMXdaSDNkaW5KUzYxZG1EN2E4NVVuZ2hpSHRwVWdwbWlaQkRIbE9DUnAzL2FlRG5jT3VnYUFlZ1NBOG4zNmU4ZStzL082SzE1Wjh3TSswMUhidjU4Tm5vN2E3cU5ZdUdTdXU5SkREblpYdXVYR0xicGx4K2FtTzYvSEorZTE3d1Y5dHYrOTgrVlBIeDFuK21qL1ZhQUlZaHphVm9LWThxc05CREc1eTYya3ZkdDdPaDdqeWdiQUUzVUlBTXY3L0NQUFBuUGRwblZYVmZYUVhsNU5TbFdYWGZQRFFhM1JBZE5SMjNFVWw2dGZueGdlMVVPSE05MlZZZ2w3L3RIWDBSYlIvanYzcWxTWE96K0x4MUxxMzlKank5ODVKemQ5ZEs2MUM5TkhOMEVsaWlER29XMGxpQ2xhSmtGTUtYKzJ2YWZqSFZ6UkFIaW0vZ0JnZWUvL3lzR09iVmV0SCtsYnQySkZ4U2VvQzhhQnFUaHM4R2czSktlbm8zYXlHMUs1ZGV0RU1xM0huenFsQjU4OHFlUERvN0pxR0V2azFwdXYwODVyZTV2eW5GN1QwYTdWSFcxVnY0OXptRDZhaWhSQmpGUGJTaEJUdEV5Q21FTERrclp0NyttWTRXb0d3RE4xQndEbCtjRFhIcnYycHVzM0hsN1YyUmF1Nk9Sa09tcjc5OU5uNDhCVVdxZk8vV2hzYWs0UEh4N1NnNGRQNnNKRVpkMlYxcTVvMTYvZGNaTU1vL2x1STRsa1dqZHM3SzdxUGN6MDBWU21hci91RXNSVVd3cEJUSlUzRFRmdmUrMUJ6QjNiZXpxK3dWVU1nS2ZxRFFESzkyZmZmUHpXbS9zM2Y2czFFaTR2QjZFYlV0WGI0cmZwcUN2YWppb2VHSjRhR2RXRGg0ZjAyUEdSc3JvcnZmNWwvYnFtYjAxVG5zZmpVL1BhZDExZjJYOVhwbyttUWxWdEFRUXg5bThaUVV5Vk53ODM3M3YxUWN3WHQvZDAvQnhYTHdDZXF6TUFxTXhILytXSmQ3NXcrK1lQQlFPQkNzSUpwcU51bm5GZ0tsdERKUTgrNVpTYVNLWjFhSm51U3B0NlZ1b05QMzFqMDU3RDA3Tng3Ym1tOU14SVRCOU5wY3JPQWdoaTdOOHlncGdsYjVUdTIwNmJmcUZna1NsSjEyL3Y2VGpEbFF1QTUrb0xBQ3IzeWZzUGYyWmcyNlpmTG5sU01oMTFUUmNxdWlIWmN3d3pzeXRkM2wzcGpiZnQxdm8xblUxNy9yYUZROXE0ZHZId1Rrd2ZEZHNxVmdReERtMHJRVXpSTXBzM2lIbno5cDZPVDNERkF1REp1Z0tBNnR6M2c2Y2U2Yjk2L2Q2aUp5VFRVZHUvbno2Zmp0ck9oNE5peXo0MU1xcUhEZzlwT2g3WHJmdXVhOXJ6MXJRc1hkZWI2WWJGOU5Gd3JISkZFT1BRdGhMRWxGL044SFVRODVDa1c3YjNkSmhjclFBMFFvaERBRFRHNmRISkYwZmJ3c05YYmxpenZzS2FrYjJWSFo5TlIxMjhFTVBaWTFqK0ttMDVpazRHTUtWYzI3ZFcxL2F0bFdsSmMvR0VwdVpqbWs4a20rcWNEUWFEc2l4cExKWmkrbWdzeWFyMXZDdFNRT2t5cTErYkpXZXVnNWVWYThPSzdObld4YVZVWGVZU3YrakVNWFc4ektJcnFIeXRydGozNVg4aFpVbi9hd2NCRElBR29pVU0wRUIvOHFWSDErMjV2dTlreityT05xYWpkbkEvbTNRNmF2djMwMWowYVRwdGFubytwcW41dUpMcHRPL096MEFnb0dBb3FHQW9wR0F3MkpRelFhSEJsU3hheERpMHJiU0lLVnBtYzdTSWVlK09ubzcvemRVSmdLZnJCd0JxODZkZlA3UnI3N1pOZzUzdExVR21vM1pnUDVtTzJxYjlOQzc3TkgvNVdDS3BxZm00Wm1KeG1SNGVpRFlZQ2ltVURWNENTd3llRGRTdG9rVVE0OUMyRXNRVUxkUGZRY3d6a3ZwMzlIVEV1RElCOEhUZEFFRHQvdUpiUDN6RHpUdTIvSDBrRkxTOWlzMTAxQTRldy9KWGFjdFJkRVVBay8yeTFQS1daV2ttbHREMGZFeHpIdWl1bEdudHNoQzhBSzZzYkJIRU9MU3RCREZGeS9SdkVQT0tIVDBkOTNORkF1RDVlZ0VBZTN6c096OSs3d3UzYi81OXd3allkc0l5SGJYRHg3Q0dmVndvdTNIVFVaZS8vT0pXTU9XV25YSmhkeVhETUM1MU1Rb0ZReklDM0FiaGtRb1hRWXhEMjBvUVU3Uk0vd1V4OSszbzZmaGxya1FBZkZFbkFHQ2Z2L25lc1cvc2VrSGZhMndKQkd5cnpCZGJsdW1vaXkzY0RPUEFWSHNNWThsTWQ2WHArZnAzVndvRWc1ZGF1Z1NEUVM0MDhHNmxpeURHb1cwbGlDbGFwbitDbURFWnVuNUhUOGNvVnlFQXZxZ1BBTERYNXg5NTl1ajFtN3V2ZHl3OG9CdVNJeGRIMzNkRE11d3AyN0lzeldSblY1cUxPOU5kS2RQYVphR0xFUVBxd2xjVkw0SVloN2FWSUtab21mNElZdDY0WTMzSFo3ajZBSEFMT3NBRExqTjA5dUtlYUd0a1pHUFB5bFcyVjE2WWp0cWhoMzQ1ZGhRYk1SMjFrMlViaHFITzFoWjF0cllvbFRZMUZZdHJlajZtUktxMjdrckJZTGFMVVNpa1FKQUJkZUZlVEYvTjlOV3Vlajh0VjZiM3A2OStRTkpudWZJQWNCUCtQUWk0MEFlL2R1akszUys0NHRpYUZkRUkwMUZYdUR6VFVkdTBuMGJWKzFqTnRzU1RLVTNPeDhydXJzVDAwV2o2Q2hndFloemFWbHJFRkMzVG15MWk0cEsyNzFqZjhSUlhIQUMrcWdNQWNNYWZmZlB4bCsyN1lmUDkwZGJ5Y3hpbW8yWTZhbnYyMC81dVNPVXVuK3V1TkZta3V4TFRSNE5LV0MzWGRZS1lha3NoaUtueXB0VDRmZi9ESGVzNzNzT1ZCb0R2N3Y4QW5QT1gvL0xFVzE2MFk4dGZCc3Q4NEdRNmFuc0RnV1dYYmZMcHFCMDUzbm5mU0tWTmpjM09LMkdKNmFOQlJjeVc2enRCVExXbEVNUlVlWE5xM0w0ZmtiUnp4L3FPcEFEQVpmaFhJdUJpdjNucmpyOGFQREw4eVpvcU5IVU9ZQ3BkZ1p2R2dYRitPbXBuYXRhT3BlbEduY2VZS2ZpR2FWa0toTU5xaVlRVmtDV1pwbFRubVpVQXAxa09GR0E1c0Rhclh2dHZ1ZUNZRmluRmNtQmpMRGUrbjVZcjA3Sm5yUTV2cHlYcFRRUXdBTnlLbGpDQUI5ejNneFAvdGVPYURTK3E2a1JtT21yN3Q0WHBxSjNabHJ4dnBFMVRGK01wbVVWK25FNmJtWEZqREtQeU5BendhNFdNRmpFT2JTc3RZb3FXNmU0V01RZDJyTys0bTZzS0FMZWlKUXpnQVdmR3BsL3k5TWpvU01VVkdCdGF3YmloY3I1azJZMllqdHJCYXFiaDRJSDFTZ0JqV1pZbUNnS1lmTUZnUU9GUVVPRmdRQUVyMjBJRzhEaGF4TmkvSWxyRU9GaW1lMXZFbkxXazMrT0tBc0ROQ0dFQUQvamQxKzB4ancrZDMzbG1kR3EybHFkaXBxTjJiSlcySEVXL1RVZGRkdGtGMzVpSUpWWHVoTldYQXBtQW9ZQmxFc2pBMHdoaTdGOFJRWXlEWmJvemlIbnJqZXM3SnJpYUFIQXpRaGpBSS83Z3YrMGRPL3pjMlJkTnpjWlNybndJYjBRM3BEcVhyWHFQQTFPMy9henZkTlJMbVlvbFZHMG4vbUF3cUhBb3FGQWdJTU95R0Q4R25rUVFZLytLQ0dJY0xOTmRRY3czYjF6ZjhVOWNSUUM0SFNFTTRDSHZ2R1AzRTRlT2oveGlQSm15dkR3ZHRTMFArRGFzMU12VFVkdTNuMFpONjdPekc5SnNJcW1ZWmMvK2hvSkJSWUpCaFExRGhrbVhKWGdMUVl6OUt5S0ljYkJNZHdReHM1TGV3dFVEZ0JjUXdnQWU4OWJiZG43eDROSGgvMk9WK2krL3k4ZUJjZE4wMUU3dXA3dzRIYlVhTnc1TUxKblNYTnIrUndYRE1CUU9CUlVKaGJLQkRETXN3UnNJWXV4ZkVVR01nMlUyUG9oNTk0M3JPMDV5NVFEZ0JVd3JBWGpVcC8vajZCZHZ1bjdqenk1M1JqczlIWFhkWjBQeXpIVFVOWVF3aHNQSHNOaFBqVG9IYW5uZlNLWk5UU1JTeTFhK0RSdi9BcVlzcGROcFdXS0dKZmk4b3Nhc1NRNXRLN01tRlMyek1iTW1IWkswNzhiMUhTbXVHQUNhNHQ0T29IRSsvOUF6UDk1MlpVOS9kWlh0WXNzeUhYV3hoWm1PMm9GdHlYN0R0Q3hkTEhNZ1hqdERtUHdmbXFhcHRHbktNZ3h1aS9CblpZMGd4cUZ0SllncFdtWjlneGhUMHQ0YjEzYzh4cFVDZ0ZmUUhRbndzT0h6RTN0T25yMDRXbmtsdS9ZS0V0TlIyeFVWT0hOZ3ZSREFXSkltNXBOS043aDNVQ0FRVUNRVVVrc3dxSkFoR1pZcDV6cFpBSldqYTVMOUs2SnJrb05sMXJkcjBwOFR3QUR3R2tJWXdNTis1M1Y3RWllR0x1eStNRGticisxQm1lbW9LMWlsTFVlUjZhaWx5VmhDbGJRZHIwY3NFc3dMWklLeTFCb0tLRURqR0xnQVFZejlLeUtJY2JETStnUXh3NUxlemRVQmdOY1F3Z0FlOTg3WDdoNSs0dW5UcjVpZFQxUTkvUXZUVWRkZU9OTlJWL2JMMC9HRTRpNmZzQ2dVRE1xeXBIQWdvUFpRVUsyaEFKMlYwRkFFTWZhdmlDREd3VEtkRDJKKzQ4YjFIVE5jR1FCNERTRU00QU52ZjgydUh6eDJiT1R1Vk1xcytFR1o2YWlMTDh4MDFMVnZZcW5sNXhJcHphVzlkWTZsTFV1V0pVV0NtVUNtSmNqdEU0MUJFR1AvaWdoaUhDelR1U0RtQ3pldTcvZ0dWd1FBWGtRdEV2Q0ozN3gxeDZjR2p3MS9sT21vYThkMDFBNzg3YlBmaUtmU21rbVpuajdYMHBZbFExSmJNS0FvZ1F3YWdDREcvaFVSeERoWXB2MUJ6S1NrdDNJbEFPQlZ0S3dHZk9hei8zbjhnVjNYWGZHeWNrNS9wcU91YlI4WHltWTY2bkwyTVdXYUdvOHRub3JhcUhBbGhwMS9GY08rWTIxSUNoaUdrcWFwaE1tZ3Z2QklKWTVaa3h6YVZtWk5LdjhhWDlXL1BkNTg0L3FPVDNBRkFPQlYvUHNPOEpsejR6T3ZPREY4NFhtN0sxdUdTOGFCY2JSU1dlOEFwbTdIc0w3ZGtJcXhMRXNUQlFHTW0xZzIvSDdhc2hRd0RMV0ZBb3FHQWdvem9pOWMvcjZsUll4VDIwcUxtS0psMnRNaTVrRkwraVJuUHdBdm80WUkrTkFIdi9wWTEvYXIxdzlmc1c1RlY2bFQzeTJ6SWJscU9tcVB6b2JraGVtb3grY1RTbHJMTE4vQWxqQk9IWmRBdHRWUlBHMHBaZEZDQmk2dHpORWl4cUZ0cFVWTStkZjZzdGFha3JSejUvcU93NXoxQUx5TWxqQ0FELzNPNi9aTUhYMysvTDZKbWZsVWJkRUIwMUdYM2srbW95NzNRV2d5Vmp5QWtTUy94eEttbFhtRkE0YWk0WURhUXdFRkRmNy9BWHZSSXNiK0ZkRWl4c0V5cTI4UjgzNENHQUIrUUFnRCtOVGJiOTkxN05EeFUzZkdFaW1ycG9kd3BxT3VlVnZVc1Axcy9IVFVNL0drWWlibm81UUpZeXhKa2FDaGFEaW85bEJRUWZJWXVPWEJtU0RHb1cwbGlDbGFadVZCek5PUzNzT1pEc0FQQ0dFQUgzdnJiVHUvZWZEbzhPK2IyVzRRVEVkZGZHR21vNjU5RTRzdFA1OU1hVFpORjV4aUZnS1pvRHJDUWJXSEF0eVEwZmdIWjRJWWg3YVZJS1pvbVpVRk1YZnZYTjhSNHl3SDRBZjhEdzVvQW4vOTcwZitmdSsyelc5b2huRmdLdDRXdjQ4RGsvMnkzdVBBSk5OcFhVeWtWYzR3S0VZRksvYmFtRENsOTY5NENVSERVTm95RlV1WklyNUN3eXAzakJIajBMWXlSa3o1bDhORjMvenN6dlVkdjhLWkRZRDdOQUJQK2Z4RHp6eldmOVg2M1U2RUUweEhYZnVEZ0orbW8wNmJsc1pqU1ptVmx1SFRFT2JTOG1XT1FwejdTY0F3bERaTnphZnB6NFVHVlBBSVloemFWb0tZb21XV0RtTEdKRjIvYzMzSEtHYzFBTCtnOVRQUUpFYk9UN3p3dVRQajUrd09KNWlPdXZiaS9UUWR0V1ZKRS9IeUF4aG4rS01OaVdsWk1neEQwVkNteTFKTGtGczI2bmdXMERYSm9XMmxhMUxSTWt0M1RYb0hBUXdBdjZGR0J6U0ozMzdkbnNUVHc2TTNuaHVmbm5meUlieXFzaHN4SGJWOVcxL2VrZzBhQjZiZTNaQXV4aEpLdVNRRDhVdDNIa3VaTVdTQ2VZRk1oRUFHOVRnSENHSWMybGFDbUtKbFhyNkNCeVRyUHM1a0FINURMUTVvSW0rL1k5ZTVKNTQ1ODdMcHViaFo4cUdhNmFpTGJBdlRVUzlidGlGTnhaSktNSkNKNHcvVnBpV0ZERU1kNGFBNncwRkZBdlFzaG9NUHpnUXhEbTByUVV6Uk1oZStpRXZhdjNOOUozY1ZBTDVEQ0FNMG1iZmZ2dXVSeDQ2UHZER1pTdGYwMU01MDFMWHowemd3czRtazVrenF5dlZrV3BsWE9CQlFaempUUWlaRUlBTW5IcHdKWWh6YVZvS1lvbVZtdnZpL085ZDNQczNaQzhDUENHR0FKdlNidCs2NDc5R2p3eDljOUJ6TmROUWx5bVk2NnVYRWttbk5wQWhnR3NtME11UHh0T1FGTWtFQ0dkajU0RXdRNDlDMkVzUVVLZk9JTEgyQXN4YUFYMUZEQTVyWVo3NS8vRi8ydktEdlZVeEhYYXBzcHFOZWJ2bVVhV284bmxiaGhNcTFUK0ZjNi9hV0VhRzVmSGFrMnMreHpBeExwbVVwbGtvclRVNEdNV3NTc3lhNS9rSENNcVJiZHZaMlBzalpDb0I3TVFCZit1S2p6NTNZdXFYNzJubzl0R2UreVhUVTl1MW40N29obWJJMEZrc1dmYmduaENteWZBTkNtSHdCUXpKTmFUNlZGcE5lVS9tenV3Q0NHUHUzckVtRG1BTzdlanZ2NWl3RjRHZDBSd0thM1BObngzY1BuNStZY096QjB3MFBFVTB5SFhXOS96N2pzVVRUdHE3dzRtNmJWaWFNYkE4SDFSVUpxVDBVb0JJZzNyOTJGVURYSlB1M3JBbTdKcDJWOUM3T1VBQitSLzBMYUhLLy9kbzlNMGVlTzNmVDJPUmMwczV5bVk3YXdXTlkrTk02akFOVHVQekZlRUlwaThhVVhtVmFsZ0tHY1NtUWFRdFJIV2cyQkRIMnI0Z2dwbWIzN09ydG5PVHNCT0IzMUxvQTZCMTM3SDdtaDArZHVuMCtuclRzZW1ndlhnalRVVHUybjNVc2V6cVJWSnorTEw1aFdwYUNocUhPY0ZCZGthQmFDV1NhQmtHTS9Tc2lpS25hTjNmMWRuNkJzeEpBTTZDbUJVQ1NkTTl0Tzc4emVIVDRIV25UclBrQnYybW5vMjZDY1dEbWtpbk5wa2xnL1BwQWJscFM2RklnRTFKTGtHcENNL3pkN1M2QUlNYitMZk41RURNcjZUYzRHd0UwQzJwWEFDNTU4MDl2LzhqZzBlRy9xYVdNcHA2TzJvN3RsbnVubzA2azBwcE9wYjM5d0lpeWo3TnBTWkZBUUYyUmtMb2lJVVVJWkh6OTk3YTdBSUlZKzdmTXgwSE11M2YxZGc1eEpnSm9GblRvQjNDWmYzanc2WWQyWE5ON3MyMWhBOU5SMjdTUGpadU9Pak1WZFRKdlZoM0R2cjlWaGI5a1ZMQ1VVN01qVmJXUFpVN0o0dFRzU0pXWGZmbFpFVEF5NFV3c2JTcHAwaUtLU21FdDd6bG1UYXEyRkovTm1uUkkwdDVkdloxcHprQUF6WUovYXdHNHpLblJ5UmMvYzJyc3RKdkdnWEYrT21wbmFwcU9KZDFHL2NhQnNTeXJJSUJCc3pLei8rSnVEUWEwSWhKV1p6aWtVSUQvNS9nRkxXTHNYeEV0WXBhVWx2UW1BaGdBellZUUJzQmxmdnUxZTh5bmhpL2NlR1pzZXE2YWgzWW5Bd0c3TjRUcHFKYzNIaytJR3JJYm5uRGR4YlF5TzlRV0RHcEZKS1RPY0ZBQmFoVzhUUWxpSE5wV1h3WXhmN0dydC9NeHpqb0F6WWJxRW9DaTN2bmFQYU0vZnViTWk2ZG1ZOHMrZjN0MU9tcGJBaGlmVDBjOUVVOG9VYS93b040aGhVdERFUzltTmFZbEdZYWhqbEJJSzF2QzZnZ0hxV0I0R0VHTS9Tc2lpTG5Na0tSM2M3WUJhRWJVa1FDVTlMYmJkLzN3NExHUi81RklWdEVPd2dQVFVZdnBxSmNzZXlhZTFMelpQRVBoV3V5UUxlc3pMVXNCdzFCSEpCUElSTU5CQnFCcnhyY1BRWXhEMitxYklPWXR1M283WnpqVEFEUWpRaGdBUy9yTlY5LzRENDhjR1hxUFpWazFCd0pNUjEzTjhvMlpqanFXVEdtR3FhaFJJOU95RkRRTWRVVkNXdGtTVW5zNHlFSHhFSUlZKzFkRUVDTkorc0t1M3M1dmNJWUJhRmI4Y3dwQVdUNzcvV05mdmVuNmphOHQ2d0pTNzI1SWhudTZJVGs5SFhVOVFxOWtPcTN4UkNvekNHdkpubENHSStzdTV4Y05PLy9LUm4zZW84WDN6N0MzYkp2M3I3STV3MHJOQUZWNnVVVGEwbnlLMFlhYW9yTElyRWtPYmFzblowMmFOS1N0dTNvN3ozQm1BZUMrQ2dETCtNSWp6eDY1NGNxZXJVdGVQQm94RGd6VFVkZCtETE1mMDZhbHNYaENhZXZ5Z2doaGJGaVdFR2JSOHJsemR6NWxLazdMSzM5WEdBbGlITnBXendVeGI5N2QyL2tKemlnQXpZenVTQURLTm5UdTR1NlRaeStPbDY2cHVYOGNHS2FqTHIzZGxxU0wrUUVNZk1kdGYxckx5cnhhZ3dHdGJBbHBSU1NrU0pDcWlTL2ZPM1JOY21oYlBkVTE2VUZKbitSc0F0RHNxT2tBS05zN1g3c25kdXprK2QxakU3TUpwd01CK3hkbU91cmxYSnhQS0VrQWcwWTk1R2ZmZTIzQmdGWmxBNWx3Z0FhN3J2b2JPVkFBUVl6OVcrYlNJQ1lsNlUyN2V6dHA4Z2FnNlJIQ0FLakkyKy9ZZmZMeHAwNi9jaTZXV0Z5UllqcHFtN2E3TWROUlQ4VVNpbHNrTUs1OWVHMHl1VW01MmtOQnJXb0pxeXNTVklnYWl6L2V5d1F4RG0ycjY0T1k5Ky91N1R6TUdRUUFoREFBcW5EUGEzWisvOUdqdzcrVnpvM2h3SFRVenUxbkhjcWVUU1ExNjd1cHFJazkvTUswTEFWa3FDTVUwdXFXa0xyQ1FkRkF4dU5uRjBHTVE5dnEyaURtYVVudjRjd0JnQXhDR0FCVmVmT3Jkbnpza2FQREg3Y3JQR0E2Nm9LZjFtazY2bmdxcmVtVWYxdUhFOFg0aTJsSkFjTlFWemlrMVMxaGRZUkRWR1M4ZW00UnhEaTByYTRNWXU3ZTNkc1o0NndCQUp1ZVRRQTB0OC85MTFQZjMzWGRGUyt4SXhBb2QyR21vN1puVzFLbXFkRlljdWtLdFdkblJ5cnpyMStuMlpFdUxkL2cyWkVxTDl1b1lmL3NPMzdMemNZV01LUjQydEpjTWtYdzVyV0tKTE1tT2JTdHJwazE2Yk83ZXp0L2hUTUZBQmJ3RHlRQU5Ua3pOdjJUSjRZdkROWDFRZGFoMzNERk9EQjFPb2FtWldrOG51U0JGYlpwNUh2SnRLUnd3TkRLbHJCV3Q0WVZEUVg1ZzNqbDcwNkxHSWUyMVJVdFlrWWx2Wk96QkFBV0k0UUJVSk4zdm5hM2VlemsrWjJuTGt6T1ZCTUlWQlFlTUIyMTdOcWw4VmhTS1JJWStEQVFNQzBwRWd4b2RVdFlxMXZDYWlPUXFjdHh0N3NBZ2hqN3Q2d0JRY3c3ZC9kMmpuS0dBTUJpaERBQWF2YXVueG00K09TeloxODRNVE9mcWlZUXNIOWhwcU5leXNWWVFnbUhaMElpMy9IUUE3Q1BqNHNscVRVWTBPcldzRmExaE5VYXBOcmoydmNoUVl4RDI5cXdJT1orU2ZkeFpnQ0FQZlYzQUNqcXIvN2xSM2UrZVB1Vi85d2FDUzE3YmFrNGJLaDRyQWwzeklia3RuRmdwdU5KVGFmTjhzdW9ja3lZcXZlRk1XR3FMN3ZNSHpnMUpreDE1Mm10KzFmNXpHeUdJVm1XTkp0S0s1SDI3NkRVbnExWU1rYU1ROXRhMXpGaTRwTDZkL2QyUHMwWkFRQ1g0MTlDQUd6emxsdHYvTW9qUjRiZWJkbmN5b0xwcU8wcGV6NlpXaFRBb0RhMFFQSG8zeTM3aDR1R2dsclRHdGJLU0VqaEFOVWgxNXdYdEloeGFGdnIyaUxtandsZ0FLQXhkWDRBVGVvejN6djJqL3UyYmZwNVd5NDg5WjROeWFmVFVTZFNhWTBsVXlyTXgyZ0o0K1RmdU1peXRJU3A3ZjFSNWdxcktUdGdTQ25UMGt3cXJaUkp4TmJ3Q2lZdFloemFWc2RieEJ3MnBGMjdlenVUbkFVQVVOOTdENEFtOTRWSG52M1I5cXZXNzZqcG9zTjAxTFpzaTJtYXVoQkx5cXltTEdPcFplMmJwcG9ReHFIdDhFa0lVL3A4dFMrRXlSY3dwSVJwYVNhVmtrbmpzY1pWTWdsaUhOcFd4NElZUzlJdGUzbzdIK1RkRHdDbDBmNFdnQ09HejAwTVBIZG0vRUs5SG5DcmV6eDNwaWJ1cHVtb1pWa2FpeGNQWUx5S05ncHdtbWxKSWNQUXluQllhMXZENm9xRXFEQTE0bHlsYTVKRDIrcFkxNlFEQkRBQXNEenFGQUFjOFk3WDdrNGNIN3F3Ni96Rm1WZzF2ODkwMUxZVXIvRllncW1vL2Z1SXloYld3YVZBcGlXc05hMWhkWVJETkNPdTUzdUlJTWFoYmJVOWlEa3I2ZmQ0eHdQQThnaGhBRGptYmJmdk92WERwMC8vMU14ODNHUTY2b0tmMW1FNjZvbFlRbkVibnl4NElBZUJndFFTTkxTbU5kTkNKaG9LY2xEcWNlMGdpSEZvV3kwN3kveXRQYjJkazd6YkFXQjVoREFBSEhYUGJUc2ZIRHc2L0wrU3FYUjV2K0NpY1dBcVZlazRNUGFWZmJuWlJGSnpEQzRLT1BaUWJVbHFEUVcwdGpYVFFxYU5RTWJaMElBZ3hxRnR0U0dJc2ZTTlBiMmRYK1JkRGdEbElZUUI0TGczdjJySHB4ODVNdnlSY3BaMTB6Z3dYcDJPT3A1TWFUckZhS0lOZmVLcWNYM0VaOTU3QzdYbkJUS3RRYXBYanJ5dkNXSWMydGFhZ3BoWlNXL2gzUTBBN25nT0FJQkZQdmVERS8rMjV3VjlyMWpxaXNSMDFMVnRTeXB0YWl5UmttbFo5cFZkNVRUVlZYZjdzbTJHcERMZklZWlRmL2NTeXpvd1E1SlRzeU5WT2o5UzNXZEhLckZTUi8rT1J2bkxtWlkwbTB3cm5pWVV0Ylh5eWF4SkRtMXJWYk1tdldQUGhzNC80MTBOQU9Yalh6VUE2dWJzK015cmpnMmRmN1pVM2EvdTNaQ2NmamlzOVFtL3dsOHhMVXZqaVdUWkFRd3VaN0ZEZFZ1ZjM5K2xscFdwWkhXR1ExclhGdEdxbHJCQ0FhcGR0dnp0YVJIajBMWlczQ0xta0tTLzRCME5BTTdWN3dHZ1poLysycUdPSFZldlA3V3hlMlhYb290UnhZUHh1cU1iVWtWdFFRem53aUJMMHRoOFhFbXIwdU5ZMlVKK2J3bGo3OSsveExMMWJBbFQ0LzVWM0JLbXdoWFkwOXJIblMxaFNyMEREVU5LbXBabWtpbWxtbnpjSmxyRTJMK2lPcmFJU1V2YXUyZEQ1eUZxTmdCUUdmNGxBNkN1M3ZIYTNUTkhuajgvTUQ0OWw2em1vY2FwaXJ2VGxXMm5wNk9lcUNLQWNSUGE3cUJaV0xrcHJ5TmhyV3VMYUVVa3BFQ1Qva3VNRmpIMnI2aU9MV0wrZ2dBR0FLcERDQU9nN3U1NXpjNFRqeDAvZGVkOFBHa3hIWFh0MnpJVlR5aEdpZ0Y0am1WSjRVQkFxMXNpV3RjV1VWYzQxSFFWTTRJWXQ1YTVaQkF6Sk9rUE9ZTUJvRHFFTUFBYTRqZGZmZU8zSGprNi9MdFdCYzN4bVk3NmNuT0psR2JUSkRCby9NTWthanZXbGlXMUJBTmEweHJSdXRhSU9zUEJwdWt6VGhCai8wb2NEbUorWTgrR3psbk9jQUJ3NGprQ0FCejJtZjg0ZXQ4TCt6Zi9VbmtYTFBkTVIxMzJ1QU1PdG9LSnA5SzZtRWpWVk5sMnk1Z3dpNVpuVEJoN3Q2T21HWklZRTZhTTFUbDIzVElrV1lZMGwwcHJOcG1tVWxwRkFaNGRJOFp3eVRHOXZKUXYzTFNoOCtlcHZRQkFvNi9OQUZDREx6ejh6S00zWHRNN1lNUGpkT21MbTgrbW8wNlpwc1ppU2RreDhXMzFVemdUd2xTMWo0UXc5dTVqaVZURXNUQ3RRWU9JRzVKTVNYUEp0T1pTL2cxa0NHTHNYNG1OUWN5a3BPdHYydEI1bHBvTEFGU1A3a2dBR203a3d1UXRUNThhTzF2am8zVDlIcUlyVHl0czNSYlRzblF4bHJJbGdQRTNPdDdBWCs5bVExSTBIRlIzVzBScld5TnFEUVk0YThzb2dLNUp0cFh5ZXdRd0FGQTdRaGdBRGZmMk8zWW5qZzlkdVBIcytQUjg4U1U4Tmc1TUZhdXRaTm1Mc1lSU0JBd05mMWdDR3ZtZURoaFNWeVNrbnJhSTFyU0dGUWtFT0dlWEtJQWdwbVlQU3RZQnpqNEFxQjBoREFCWGVQc2R1OC8vNk9rekw1bWFpeTlxNE1GMDFJdE54QkpLa0NyQU80L0RxTU5mS0dnWVd0a1NVazk3Ukt0YndncjdJSkFoaUxGL0pUVVVrNVQwcHBzMmRIRkJBQUFiRU1JQWNJM2Z1bTNuWTROSGgvOUhNanZlQWROUkx6WWRUMnJlcEE0TUh6ODRvNlpqYlZsU0tHQm9WVXVtaGN5cWxwQkNBWVAzVTFsbEVzUXM0UU0zYmVnNnpGa0hBUFlnaEFIZ0ttOSsxWTdQUFhSNDZIMlpyNWlPT21jK21kSk0ybHVqd1BCQURqVDIvQXNIQWxyZEVsWlBXMFFyVzBJS0d0N2NEN3QvbVNDbUlrOUplZzluRkFEWWg5bVJBTGpTNTM1dzRwc0QxMis4cmVvTG1ZK21vMDZtMHhwTHBHUTVWTXQzYW5ha1NvKzEvYk1qTFN4WnlleEJYcHdkYWNubGpWci9McFZ0aWVIejJaRXFQYzhOQjhQa2F2Y3hsalkxbGZEV3lGS0dBNy9NckVsbGVjVk5HN3J1cDFZQ0FDNjVwd0dBazc1eThQbGpOMnpwZVVIRkZ6SWZUVWVkTmkyTnhoS096b1JFQ09Qa2U2VElzb1F3TlljSTVhelFQU0ZNK1d1b1Z3aVRZMG1hVDZjMWswaDdJcEFoaUxGL0pjc1U4NW1iTm5TOWtkb0lBTmlMN2tnQVhPdTVNK00zRFoyYnVPajRRMXhWeXp2ZkRjbXlMSTNIRTB4RkRjQ3hoL3IyWUZBOWJTM3Fib3NvR2c2NmVudnBtbVQvU3BZb1psVFNiM09XQUlEOUNHRUF1TmJiNzlnOTgrUnpaL2VNVHM0bVNqMUFsUGZONmg1T0t2bXBFMkhReFhoQ0tRWldBZUF3UzVrV1R4MmhrTmEzWndLWjlsRFF0ZHRxOXk4VHhCVDF6cHMyZEkxeWRnQ0EvUWhoQUxqYVcyL2Y5ZHloRTZkdW00c2xsNjl1K21nNjZzbFlRbkhYTjRFaElRTHZOajhlWjhNdzFCVUpxYmU5UmV2YUltb05CZnp6WGlDSUtXZGI3NWQwSDJjREFEajIrQUFBN25mZ08wLysxay9zdlBJdmdvRkE2WXRYeFgzK3ExbmUrWEZnWmhOSlRhWHFsOEJVUHlaTVJVZXIvTzB3N0R1V2pBbWptc2VFcVhSVUdLZkdoQ2w5M2pNbWpOM1h0V0xMRzVLU2xxV3BlRW9KMHgwSk1XUEUyTDhTUTRwTDZyOXBROWZUMUR3QXdCbTBoQUhnQ2Z0L3V2K2pEeDhlK2xRMUR5cjJWWmFkSHdjbWxrcHBPc1VvTU0yRDloM3d4cnZCa2hReURLMXVEYXUzdlVWcldzTUtCd0xlUFY2MGlDbFY1aDhUd0FDQXMyZ0pBOEJUdnZEUU13L3V1bmJEQzh1OWtqbnluK0xzbDNhM21FaW1UWTBuVWpLdCtqNktHUlV1WUZSLzFNcGJ0cWxhd3BRdWdaWXdaUzd2bzVZd0ZidzluTHUrR1pXWG5VaWJta3ltbERZYkV5UFJJc2EybFJ5V3RHdGdRMWVTMmdZQU9JZVdNQUE4NWRUbzVDMG5Sa1pIN0g1QXFiVEdhL2VEdW1sWnVwaEkxajJBQVlCYXRRUUQ2bTZOcUxlOVJTdGJ3Z3JVK1Y5OHRJaXhiZlBlUkFBREFNNGpoQUhnS1crN1k3ZDVZdmpDcnRPalU3TkxMZWVsNmFndFNlT3hoTkxrTDQxaHVYTjl2QjM4K3hid3M3WmdRRDF0TFZyZjNxSVZrVkRkbWx3VHhOUzhrZ01ERzdvZTVCME1BTTRqaEFIZ09XKzdZL2ZvajU0NTg2S0oyVmphanZJYVBSMzFSQ3l1cE5zSGcrQ0pHSzU5ZjFxOFAxM0lrTlFlQ21wOWV5YVE2UXc3SDhnUXhGUzlrak9TZm85M0xRRFVCeUVNQUUvNnJkZnNmT0xnc2VGZmpDZFRWckhLdjFOUEZYYVhQUlZQS01ZNHZPNTZwbWVINnJZKzhvem1lRjhia2pyQ21VQ21weTJpYURqb3p2MXMzaURtbm9FTlhaT2NKUUJRSDRRd0FEenI3bGZ0K01KRGg0ZisyTXI3VDdpWHBxT2VTeVkxU3g4a0FJMTRXbS9RK2dLR29SWGhrRFprQTVuMlVNQmR1OUI4UWN6WEJ6WjBmWkVURFFEcWg5bVJBSGplMy8vbjhYL2V0MjNUejFSNlVYTnl0cERsbGsyazBocFBwRnpSRXNDb2NDR25aa2RhdEx4aDAzYVhPemRORFRNazFUNERsR0Z2MlRidlg4V3pJMVc0QWx2MjBURHNlKytWczJ6RisyZlV0aDJHemVkWEdXOFF4MmFYVXZFWm9GS21wYWxrU3JHVWZVMERtVFZwMlpYTVN0bzJzS0ZyaUpvRUFMaXM3ZzBBYnZmbHdlZWUzSEhWK2h2c3VmZzVPeDExMmpRMUdrdktMYjJRQ0dGRUNMTk15WVF3eTY2dTFuZmcwdHZoZUFoeitVbGU3eEFtWHlKdGFpcVJWc0tzL1NwSkVMUGtTdDQrc0tIckk5UWdBTUNGZFc4QWNMdVBmUDFRcFAvS250Tlg5cTVlMDhpSGtlWEt0aXhMby9NSnBieDJJeUNFc1RkRWFIQUlVMmtzUUFpejdPcHNPNEtFTUl2RnM0Rk1zb1pBaGlEbThpL1Nsbjc4aitlbWI1OUxXeW5wMHY4RTBzcDBZTElLdnFmczE4VytaMGt5RHd6ME1ib1pBRFQ0ZWc4QWRmZlJiejYrY2VENmpVK3RXeGx0c2V0QnhPNEg4ckg1dUJJdUd3YUdFRWFFTUxaRkNJUXd0UjVCUXBoU1B6STBuMHByTXBsUzJxejhJa29RcytpTDlJbTU1TTk5LytMOFlRZFdkU21ZeWZ2YzB1S0FwekRzTVpmN25KQUhnSitFT0FRQS9PTEo3blduOU5TcFYvMUUvNVlIb20yUlFFMFBJUTQ4akUvRUVxNExZSlN0NFpMSWM2dzUxbkM3dGxCUWJhR2dMRm1hUzVtYVRpUlY3dGptTmIwZlN2eHk2VEtyWDV0VDc5djhjbWRUMW1jZENtQ2toVWsvYkowQ2EvL2dTRzQzOGdPYXdwZFZ5ZmNKZGdBMEN2VVRBSFczZjNERXlGYlVjcS9sdmk3bmU1ZXVaOXVtcG43aDF1MmIvemdVREZSNDBYT3VHOUpNUEtucHRIdnJlNVcwRlBGV1M1ak1rbTVwQ1hOcGVWckMyTHVQSlpxbU9OYWlpWll3OW01SG1TMWhpakV0UzNPcHRLYktIT2k4MlZ2RVdOTHBiNDNPM25ZMmtaNm5OcEk3SkNWRG5jSlh1dFRQQ0hRQXVPRWFEOERmb1VsaEVCSXNFWTRFU3dRb2pydHBidWJkTCsvZmZGYzlIa0NXSzNzK21kSkVNdTN0bTRISFE1aEtRd3BDbUdvakJFS1lXbytnRjBPWW1vOTFEU0ZNdnJSbGFTNloxblJ5NlVDbW1ZT1kwL0hVbTc0OU52YzlhamFPV0Rhc0tmalpvczhKY29EbVFRZ0RORWQ0RWl3U25nU1hDRmFLQlMyZTg1T3AyR2YzWG5mRnZrb2ZQdXg4ZUV1bU0xTlJtNWE3anhVaFRIMGUzb3VIRkc0UFlhb0lFUWhoYWp0K05ULzRWN084OTBPWS9LVlNscVdaWkZvenlaVDlGV0NQQmpGeDAvcjIzNTJkZmh1MUkxZGJNcWhaNm51RU9JQjNFTUlBN2c1UWdpVUNrM0pEbGFZK3h3T1dHWGhOV04vZHRtbmRGWlU4ZmR2MThKRTJMWTNGRTJXUFdlRHFtd0VoakwzNzZPTVFwdEtRZ2hDbWpPMHc1UHg3eEdjaFRMNmtaV2s2a2RKY0ttMWZKZGhqUVl3bFRUODBHYnYxNkd4aWxCcVdyNlYxZVZpVFh1THpYSUJqY2VnQUY5VzdBVlJuLytCSXNZQWtxT0toU2JIUE9UOXRFSTNITzErM0p2cTlqZDByb3ZWODhMQWtqYzdIbGZKSXRjYXBFS2JxaHpOQ0dIdTNneERHM3UwZ2hMRjNPeHdPWWZJbFRGTlR5WlJpS2JQMmlyQ0hncGp4WlBxUHZueGg5dlBVQ3JCRXRhVllXRlBzbFF0dTBodzJvREhYZE1EWDhscWpGSVlvcGI1SGlPSkNHMlptcjNuTmxldSt0cnF6TGJoY3NtRFhBODM0ZkVKeHl6di9XQ0tFcWMvRCs2WGxIUWhobGc0cGF2MjdFTUlVTHV4b2Q2NnFRb3BhOTdFNVFwajhoUkpwVXhPSmxKSzFESnJ1Z1NBbVpWbVAvOTNaNlY5TVc2SzFBK3hXTXFRcDlpSzRBV3E5RXdBZWttMlZFdFRsNGNseW9Rcm5pRTljTXpYMTh0ZHMyL2l4MWtqSUtQWFViZGZEekZRc29WblRXM1ZkUWhpSHdvOVN5eExDMkJzaXVENkVxVEZFSUlTUkV5Rk1ibGxMVWp4dGFqS2VWTEthYTdlN2c1alU0ZG5FNng2ZWpEMU5UUUF1a1F0bFVrVStOL08vVDJnRHYrSUJFNTVTMERLbFdJaFM2bnVBZGt4UDczL1ZqczN2Q0JpR1l3OGNzNG1rcGxMZUd4dVBFTWFoOEtQVXNvUXc5b1lJaERBMjdLTTdReGhiamwrSmhZb3RhMG1hVDZVMUdVOHBYVWxyUnBjR01UTnA4MlAvZUc3bXo2a0J3TU9XQ20zeVAwOHh0ZzE4VSs4R25GSWlVRm51eFhzV05YbGhiUGJETDkyMitUVk9QR3pFVXlsZFRLUTkyZDZiRU1haDhLUFVzb1F3OW9ZSWhEQTI3S1BiUXhnYnJ6ZGxkajgxTFV2ektWTVRpYVRLeW1OY0ZzU2tMWjM4NnVqTUhSZVRacHk3UDVwRWZrdWFKVDhTMk1EVjlXNmdYUHNIUnlvTlZBSWNOVFRDSzgza1YzWmYwN3ZWem5GZ1VtbFRZL0drdkRvL1pQVWhURVdQZHVWdkJ5R012ZHZoa3hDbWRFaEJDRlA3UGpvM1J0YXl5N28waEZuMFpHZFptazJsTlJWUExSMjB1eWlJR1lxbGZ1WGZ4dWNlNXE0UEZEK3R0VGlZeVgyZXpQOGVVMytqSWZWdU5LK0NjVlJDV2h5Z0ZINU5LeFY0UmppZGp0elJIdnFQYS92V3JMSGpBZEMwTEkzR3ZERVZkZFUzQXhlR01KVSsxaExDMUZLMjRkanNRWVF3dFlVVWhEQlZiSWRSMjNzdlpWbWFTYVkxa3lnUnlMZ2dpSW1aMXBmLy91ejA3M0hIQjJwbXFTQ1lFV0VObks1M3cxL3lXcXVFU256TS81ejNCM3hyOWR4ODl4MVhyUHh1NytyT2xsb3ZtR1B6Q1NVc2I3ZHFKWVJ4S1B3b3RXeVpUNkdFTUdVdVR3aGp3ejRTd2xSVGRzcTBOSjFJYVNhVkxtdEQ2aEhFV05MRjcxMmN2L1daK2VRRWQzdWdiZ3JEbXFRV1FwdGNVSlBpTUtHMkt6NWNJOXRpcFZTb1V2aVJ2em1RdFhsNmV1ZnQxMjM0aDg3MmxtVzd4cFU2Y1M3R0VvcVozdTlXYkZTNFFDWGp3aERDRkZtV0VNYmVmU1NFc1dFZkNXRnFMVHRwV3BwTXBEU2ZDMlFhRk1TTUp0UHYrdXFGMmE5d2x3ZGN4MUpCTUtPQ3dJYWdwam53UU81aWVlRksvaXRZOEhtWXZ5TlF2YTNUMHovejZ2NU43NHVFZ2hWZktLZmpDYzJrL1RHdUd5R01RK0ZIcVdVSlllemRSMElZRy9heCtVSVkrL2R4WVltRWFXb2lubFRjTkNzc3E3WWdKbWxaRDMzMnpQUWJ1YnNEbnBZZnp1UmVsOElhdWo0MVFiMGI5c3ZPQ2hRcTQ4WGZCNDJXRzBDNTJCaEFJUzBrK21iZXg5eVVnY25zejExdnorek11MTY1WTh2L3JPUkNPWjlNYVNLWmJwNmJRYjFEbURKLzBiWVFwb1lIczZyMzBZRnhZUWhoSENpN3hJS0VNRFllYXgrR01MblBMRWx4TTYySmVFcUpna0RHZ1NBbS9zUk0vSTZEVS9HVFZGOEFYOHZ2OHJRb29KR1VQRERRbCtZUWViemVqY3BrQTVhd0ZvY3BoVjhIT1ZLb1EzZ1N5YjczY2g4TFg1Rzg5MlpFaTF0YTVVS1ZPVW56MlZlc3lNczNGL21mU01iKytvWFg5OTFTemtVeWtVcHJQSm1TNWFQSkRXdDdjQ0dFSVlRcFVyWmgvN0ZiZWg4TjU4b3ViM1cxdmdOTGJ3Y2hUQlV4aVAzbmVqVWhUUDRYbHFUNVZGb1RpYVJTMlc2c2RnWXhVeW56ejc1NGZ1WVRWSUdBcHBjYm55Yi9sY2g5enZUY0hxbDNZOEgrd1pIQ1lDVmM4RG5UTHNQT0lLVWw3eFhKdmxwS0JDejVueTkxYnFja3plUUZMSE5hSExiTStpbGNxY1R0d2ZSMys3ZjBiRnpxQXBrMlRZM0d2RHNWdFRNUEx2NExZWng4QUcxSUNGUGovamtad3RpMmo0UXdOZTdqNVcrUXVvVXdaZStqWWQ5Mk9CSTBHV1h2bjJsWm1rdWxOWmxJeVN5WjZKZS9kV2xMVDMzcC9NeWRNMm1UOFNRQUxLZXdxOU9sRjJQU3VLamUzVXoyRDQ0VWhpcjVuOU5GQ0xYSWhTbnRSY0tWL0krNXoydHBNUlZUSm1qSmY4MW1QOFo4Y2p6elcvc1VhM1VXekR1SGd3WG5kSzVMVmE3clZFSlNLbUtheG4vcmlueDhTOC9LOW1JWFNNdXlORHFma0IvdlRvUXdoRENFTUM0T1laYjRkVUlZYjRZdytVekwwbXdxcmNsRXNrZ0x5N0syMEhwa0t2WW5oMmNTeDdJUFZ3a3RUS05iT0V0TDRSZ1RBTERvZXFMRkxXY1N1YzhKYUFoaGFnbFpBaXJlSllPUUJkVnFrOVNhZmJYbGZWMzQwWWxXVW5GSms1SW1zaDl6TDY5Y0pIT3RmVnExT0l3cTFjSW4vK3VsanFlcFRPaVVhOWtUMCtVdGZvcUdVZXRuNXpiZnZubk50OWF0aUlZS2Z6WTJIMWZDcHcwNDNSTENsQTRwQ0dFSVlRaGhDR0c4RThKVWNJb3Yrbkhhc2pTVFRHa3FrY29iVkczcFg1NU1tVi85VXFZYlVwc3kvK2pKMVVVNnNuWGI1UjYyRm5WVktQSjU3aFhQZXlXcC9nRk54eXdXemtoS01GZ3dJWXoyRDQ0RTh4N1dDaC9nR0k4RmxZcGtLektkMlkvdGtxSjVIK3ZWQlMwdWFTejdHcytHTGZNdVBGNkJ2QXBnZm1Xd1ZZdGJBTFhZY0Q3T1M3b29hVnFaVmo2NWozT3FZVkRncTZlbVgzTDd0cjVQdGJlRUwxMGpKMk1KelpuKzdVSkxDRU1JUXdqVDdDSE01U2M1SVV6OVE1aDhLZFBVVkRLdG1XU3FaQUdtZE9IKzhibFhEOGRTMHlXS2JzdldWVHF6SDdza3JjcldaMnA5R0l0cmNUZ1QwMEkzNTl3L081cTJpelBRWkZKNTRVenUycENnOVl6UFFwanNBTGlSZ3JBbFF0Q0NHclJJV3BGOXJjeFdWRHF6MzIrVU1Va2prczVsd3dhM0NHZVBVNWNXQXFwb1h0amk1UEU0cTB3SWRWRU9obEE3WnFiZmVPdjJ6YjhmREFRMEZVdG8xdlQzR0dhRU1HcTZFS2JTV0lBUVp0blYyWFlFQ1dGSy9jaXdiMXM4RU1Ma1M1aW1waE5wemFZVzV4bm5FK2w3dmpFNis2OVZYUFpEeW9ReHF5WDFaRjlPL1ZNcHFVd3drK3NXbmZ1bnlZVDgwMFVhUUhHNWJ2K0VNelhjTStzdUc3WVVqcHVSQzF1QVdxeVExQzFwYmZiVjdxS0wxVE9TVG1RckxHN1FLbWxEOW5pdFVlMy9RYXZVR1VtSHNoVzN1cmw1ZnZaOU83ZDAzeGtQQkl4bUdFYSsrdG1EQ0dFSVlZcVVTd2hUOVJFa2hDbjFJN2VITUV0c3JXSGY4WXVicGlianFmUjBLdjJEKzg1TXY4bW1XMENMcEcyU3JxdnpyU2N1YVZUU0JVbW42bjJmQjlEUTU1MzhjQ2FtSnVyVzVKb1FKcTlsUzJIZ1F0Z0NPNjJTZEZVMlVHaDM0ZmJGSlQwZ2FjcEYyM1NqcEJjMCtIcHhRdEtQcFBwT1N2U3p2VjI3T2kzckRRZW41cjhWa2lJR3JlenFlNk1wNXhlTlFMd2pFbXB4ZER2OGN2TTFhdnRsbzVtUG5SdTIyMmplNDJjNHNmVkdZNDZkbGVrcWExbVdMRXV5TEZteUxKbFczczlNeThvc0kxbG1kamxKTWkzTHRDUXJKYVduRXVuWVJDcDFZVFJobnJieFVHK1J0Sy9CZis3VGtuNmdHcm9VQS9DMHd2R240bjVzTlJOcXhFcnpXcmNVamhIQm9MaHdTalJic1Zqbjh1MGNsN3NDR0NuVHhhalI1K1oxa3Zva25WU21POUtZSE81ai90STEwU3UyZGJiK2xTR3RtUXNFbnZ1bjA1UGY0alJ5OC8wYUFId3R2NnRRN2g4U3VYOWF4cXNzMDFDbVZYQ1BNZ0hNU3BmVU9RQTByMXl2bDg2ODdDQ3RURXVaUytOUEhSam84L1RnNEk0L1dCVUVMcmxYaFBjWDZ1emxjbjhBazNOQzBoTnkxMEIyWGNxRUlEM0s5QjhQTlhoNzBzb0VWaGUwTURQVXRHejZ6OW5WMFVqSGY5K3c0dk5CdzdnMlYrRjk4T0xjLy83dWhabERuRW9BZ0RvcEZyd1VTaWpUZXFRYzdjb0VMU3VWNlZxODFnVjFjak43SDg5MVI3ckFueDFBbWM4Q3VRSEFZOG9FTTU3cHltUjdDSk9kbWFod2VsNWF1S0RSZHFuKy9aeHJFVk5tWEpobmxSbk16bTNYalU1bGdwa1Z5b3dQMDZHRmdYa2JKYVZNSzZKSlpmcVVUMmxoOEwreUE2MjJZQ0I0ejVWckRyUUVqSmNzdXRKYm12djIrYW0zSFpxTW5lUjBBZ0E0SktqTVB4U01DdTVkK2Exb0ExcVlEU2szY0g1dXdvRkdkdkdQYTJGdzN0dy9UcWF5TDJaUEFtQ0hoUEtDbVFNRGZYRzNibWpONGNqK3daR0FNc2w2N2tVckY3alZGbVhHTmxucHNlMGVVK2EvWEdlVStXK1JtL3RKQjdQWGdmd2d0clhFMS9VMHAwd2dNMXZrTlo5L1ROOXgxZHAzZDRRQ2R4VzlzcHZXbWMrZG1uamIwSHh5Z3RNSkFHQ1RnQmFDbDNMK2s5dFM1RjQ3cDB6NDBpN25aamtxSnFuRi80MmV6L3VZQzE3bXM4c0JRRDJaMmV2UG5LVDVBd045cnBtTnJhb1Fadi9nU0d2ZWhiNVZ0SFNCdDZ5VXRGRUxYV3U4OVA2Tkt4UEtqR1kvT2o0MmlvTVZ6aFl0VERHZkd4Y3FVdUtWKzVrVDNhRE03TVY1N3ZXOUsxNjByYlBsbDVkYWVEWnRIdjdreWZFL21FNlpUS3NKQUtpbERtN2szWWR5d2xvSVdmSzc4K2UzTUM4MlNIeFN0WTBwbDV1cEpKNHRhOUYwc2dXdmVONUhXckVBOEFyWGhESmxQWHhteDNWcDEwSzNBMllJZ1YrRWxla1R2VXFaUUdhVjNEbHJVaW1XTXExalJpVmR6SDd1NTZhOWhqSkJUTGpJSzVUM01WTGsrOEhzOTRQWjE2SkE1K1pWN2RmKzlMcU9YeXJudW5ocVB2bllwNGN2ZnRyS1RxZW54YU80TTZNREFLQlE3aDhLYmJwOE50Q1d2SjlWVXNlMnN2ZjdWUFoxVVpsV243a1FKWm45ZnY3SHdsZnUreVovSWdCTjV0SS9ZaVhOMW5PdzN5VWZOdllQanJRbzA0KzBVd1F2YUs2S1VwY1crbEYzWmw5UjFiZUpiN1VzWmZwYVR4Uzg1dm5UWGlZc0tmU1RhenV1ZThtYTZOOFlsaFV0OXhlZm5JcmQvODlucDc2dmhXREl5RjRuVTNtdi9IQW1vWVhRSnBiOU9RREF1NEphSEtJVXZ2TEQvOXdZTDdsS2ZtNWF0MXdBa2d0VDBubXZaUGFlbmlyeXM1UXVELzNUeWd4dVM2QUNBSlZMS0R0Y3dZR0JQa2ZINUx3c2hNbTJldWxVcHN0R0szOExZTkg1MHFxRlFXaHpyM1psL252VnJzYlBHclNVcERMaFRQN0F0Ym5CYTV1MndyWnpSZHVhMS9SMGZqRm9HQnNrU1ZaNURWa3NTVCtlaXQzN2xiTlQvN0hNZXlha1RIZ1h6SDRNWkwrWFg3R09VMmtHQUU5bzFVSUx5MEQyR3A0TFVmSS9XbG9JU2VyWlFuSkdtZGF4QUlEcXBaVUpaR2FVQ1dWc3ZZNHZDbUgyRDQ1MEtUTmxYWmpqRGxRbHJFd2dFMVhwUVduYjVLNnd4dExpMllSeU13ck5LTk42eHJmaFFIZExxT1hYTnEzK1REaGc3RnA4Uk1vT1lsTC9NVGI3Ty84NU5udUV0ejRBTkRXajRHTWo3NTFubFdseENRQ29uWm4zZkRSblJ5QmpTTkwrd1pHd3BQVnE3UFN5UURQSk5XRnUxVUsvOE56bnBRYXBiVVNYd0Z4ZnlmeHdaamJ2YTgrT1BSTTBET01kVjYvOVVGc3djUHRsUDdUS3Y3YW1MVTErNWV6a1d3OVB4OC93dGdhQXBoTW91R2U2UVZLWldSVVpvd3dBN0pWV3RqZEJMVk5nRy9zSFI5b2xiWkEzeHJvQW1sbXViM2x1UnFGeVgyRUh6Ky9jQ09PNTZaN3pQNStWaTBPYWU2NWFlOC9LY1BBdEpSZW9JSWlKbWViSnp3eFB2T05jUERYRDJ4UUFmQytnekQ4eUxibTN0ZWhGWmJvZkF3Q2NFVk5tM00zcFNsdkhHUHNIUjY0V2crNENmbGM0bzFDbzRIdVJndS9senpDVS83MUtyeFZ4TFE1bGNrRk43cFZveE1INHRjMnI3N2lpTmZ5aFpSZXNJSWlaU3BtUEhYaCs3SS9tVFN2SjJ3MEFmQ2VnVE9oaXlCdmRkQzFsV3NOd1R3SUFaNldWbmFYMndFQmZXZmNIWS8vZ3lKVmlEQmdBNVZkQzg4T2JYRmlUbS9ZNTk3MkFGb0tkZ0JhSE9Qa0RHaXBiUVp6VFFxdWF3cGV0c3dpOWZzT0tYZHM2V3orYjNiNWxxckNWdGVRK0gwOTkvUk1ueC8rU3R3a0ErSUloZDR6eFVxMllNdVBEQUFDY1p5clRNbVo4dVRERzJEODRFbEZtUEJobVFnTFFLTG1tM2JsWmhQSS96NTl0SWxsTFJmaWxhNkpYL01UYWppOGEwdXF5ZjZuQ0lPYnB1Y1FuUGpjeThXWCtwQURnU2ZrRDdPYlBjT1JWbzhxTTRRWUFxSSswcEhGbFdzWllTOTFvdEg5d0pDcXBTNWxaWFJnZkJvQ3ZYQnR0NmZ6NUsxWjhQbWdZMTFUOHl4VUdNUWNuNXYvb1crZW5IK2FvQTRBbkJQTHF4Ym5wcGYzQ2xIUktIaDVJSHdBOEtpN3AzSUdCdnN0bXF6TUt2N0YvY01SUVpwYWs5dXpIRmhIS0FQQ3d0bUFnZU05VmF6L1pFakJ1cWJxUUNvSVlVNHA5NS96TTJ4K2RtSHVXb3c4QXJ1VDFya2FWbUZHbVJRd0FvTDRzU2FNSEJ2b3VGdDZBbHBYdHNsUTRaYTZUTTY0QWdHM2VjZlc2UCtvSUJkNVEyeVcwc24rTUprMXI5QXVuSjkvMjlGemlBbjhCQUhDRlhQQmk1VldPbThVNVpjWmVBd0RVMzdTa3M3bnVTVVl0SmUwZkhNa054SmsvMjByKzRKdTV3VG9Cb0NIZXZHWE5MNjFyQ2YyaExZVlZHTVRNcGMwVGZ6MTA4VjBYaytrNS9oSUEwQkQ1d1l0WFpqWnlRa3FaYmtrV2J3a0FhSWlaQXdOOXAzTTNKa2RsdXpmbGh6SzVqNEc4ajRFaTN6UDRPd0dveGM5dVdORy9yYlAxMDZxaTFaNWxhVmJGK3RCWEdNU01KVlAvK2ZIbnh6OWU0d05FWUpsOU1MUzRhVDBBTkx0Y1hkSlM4d1l2aFNhVm1VWVZBTkFZNHdjRytrWmRXMkhQQzI4S2c1bkFNcCtYK3BsRTl5bjRTK0dzRFdhUnIwc3RtMTdpWjhVcXJFdDlYZW55aGV2WEVoWGtKUWRJWEc3Nk4xeTZudVptbkNxbVdQQ2R1LzdtUDh5RUNuNGVLQ2dqLy9kREJUL1BENUVLcjhtNTM4MS81YmVpREJiWnBtQ1I2enNBQk1xNHJ6Ujd2ZUdNcEFTSEFnQWE1bVJUL3RkMC8rQkkvZ05BNFFPQlVlSVZLSEdUTC96dmMvN0R6RkkvSzFhV2xpaFhTendBTGFkZS95RTNhL3hkcThyeWw1cENjcWx5Uy8xZXVvemx6Q0xMbURiODNwTEJDcUVEVVBLNm5ndHo4Z09jWEhBVXpydHU1Z2M5Um5hWi9JK0J2RElDZVQvTEQ0eG91UW00QjhGTFpSS1NUbk1ZQUtCaHBxZzRBZ0JRby8yREk3bWdKaGZtNUxyZkZuYTNYZXFWdjN6aDczSy9CaFlFMUp5RDY5cGxYTklVaHdFQUdpSkZwUTRBQUpmTHR2UUphR0VnL01Md3B0ajNDai9QLzBnM0xuaE5mcXZlcFZyQVlubVdwQkVWRy9jTUFGQ1hHeG9BQUdnaTJYSFhRbG9JZGNKYUhPZ1VmbDM0dmR4SDZoRndVdjdndWdRdjlwcVRkSjdEQUFCMVoxSjVBZ0FBVmNtT3NSYlc0akFubFBlOVV0L1BCVGxBSWNaNHFaL3p5b1F4QUlENm1TZUVBUUFBZFpkdGpaTWZ5a1IwZVhnVEtmZzZGK1JRZi9HWFhGY2p4bm1wcjdTa1V5THNBb0I2T2tjbEJnQUFlRXAyakp5SXBKYnN4MkRlNTduUUpwTDNOVjJuM0NsLzZuckdKMm1NS1dVRzZnVUFPQzhsNlRrcUpBQUF3UGYyRDQ3a1FwbGNNRlA0ZVM2OHlZVTUxSkdja1QvT0N5MHczT0dNcERpSEFRQWNOM0pnb0crT0NnWUFBRUNCYkd1YlZpMXVjZE9TZllVTHZrZDlhbW01S2FVRG9zV0xHeVdVQ1dMb0JnWUF6cmx3WUtEdm9xZzBBQUFBMUdiLzRFaElDNEZON2xVWTRPUStieFlNc09zdDQ4cDBUUUlBMk85U0FDTVJ3Z0FBQU5UTi9zR1JYR3VhM0tzMTcvUDgxalplWk9SOVpFcHBiN0dVR2FRM3hhRUFBTnVZa3M0ZEdPaWJMbmF6QkFBQWdBdGtaNDdLRDJyYUNqN213aHMzMU9NQ0JRL3lCQy9lTlMvcEhJY0JBR3dSbDNUbXdFQmZvdkFIaERBQUFBQWVsQjFzdUZVTHJXbmF0TkFWS2hmVUJCMVl0WkZYaHlSNDhaY0xrbVk1REFCUU5VdlNtS1NMQndiNnJGSTNVUUFBQVBoUWRyeWFkbVVDbWJic3F6WHZGU216cUZ6d1l1VlZNdUUvcHFRUk1ZNFBBRlJqV3BueFgxTEwzVkFCQUFEUWhQWVBqZ1MwRU16a1FwcVdndTlKbVc1SFBKZzNoeGxKb3h3R0FLam91amwyWUtBdlhzN0NoREFBQUFBb0tqcytUYXNXV3RPMGEzRkEwOEpSOHFXemttSWNCZ0FveVZLbTVjdkZjc09YSEVJWUFBQUFWQ1hia3FaZGkwT2FYRkRUcHNVRDk4STdrcEpPaTI1bkFGQW9KV2xTMHVSeTNZNUtJWVFCQUFDQUk3SlRjbmNvRThpMEYzd01jWVJjYlNMN0FvQm1aeW5UNVdqcXdFQmZ6WU9YRThJQUFBQ2c3dllQam9RbFJiWFFlaWEvRlUyWUkrU0toNDdUeXJTS0FZQm1OS2RNbDZQcEF3Tjl0bzJMUmdnREFBQUFWOGtHTkIzS2hETFI3S3N0KzVINmEvM0VsQmtmQmdDYWdTVnBYcG5nWmViQVFGL2FpWlZ3RXdNQUFJQm43QjhjeWJXWWlSYThJaHdkUjR4bEgwZ0F3STlTa21henJ6azdXN3lVUWdnREFBQUF6OXMvT0JKU3B2Vk03cFVMWjFvNU9qVXhKWjJTbE9aUUFQQ0ptTExCeTRHQnZyclBCRWNJQXdBQUFOL0t6dUNVQzJWeUgzTXRhYWdMbDJkRzBpaUhBWUJIeFpUcFpqUW5hYjRlclYyV3dvMEhBQUFBVFNuYnRTbS8xVXd1b0dGZzRNdWR5ejdFQUlEYnVTcDBLVVFJQXdBQUFPVFpQemdTMGVYaFRMTjNiVW9wMHkzSjRoMEN3RVhTeWdRdXNkekxiYUZMSVVJWUFBQUFvQXhGdWpibFpteHFseFJzZ2tNd0tla2k3d1FBRFdKSmlpc3ZkRGt3MEpmMDJrNFF3Z0FBQUFBMXlyYWV5Ujl2SmplTFU1djhFOUJZa3M1SVN2QVhCK0F3VTVuQUphNU00QktYbERndzBPZjUxbmlFTUFBQUFJQ0Q5ZytPdEdoeE1KUC9DbmhzZHhLU1R2TlhCV0NqdEJhQ2xyaWsrSUdCUHQrR3ZZUXdBQUFBUUlQc0h4eHBWU2FneWUvYTFDWjN0NkFabHpURlh3OUFoZExLQkxrSlpWdTJLQk80cEp2cElCRENBQUFBQUM2VTdlS1VDMlh5dzVrMlNTME5yTXRia2theUQxUUFVQ2pYbFdoUjRISmdvQy9Gb1NHRUFRQUFBRHhwLytCSWZqaVRIOUswU29vNHZQbzVTZWY1S3dCTnk1S1UxRUxRY3VuelptdlpVaWxDR0FBQUFNQm45ZytPQkxVUXpMVGtmZDZhL2JyRmh0V2NWeWFNQWVCZnlieFhMbkJKZUhGV0lyY2doQUVBQUFDYVRIYTY3Ull0QkRPNWo3bVFwbFZTYUpsaTBwSk9LZFAxQUlBM21Wb2N0T1RDbHFTa2xCOW1JM0liUWhnQUFBQUFsOWsvT0JMUzVTRk5TOEhIYVVrWE9WcUFhK1c2RGFXMEVMS2tsQTFhNkRwVWY0UXdBQUFBQUtxU2JWRVRLdklLU2dybmZjNXpCK0NNWEV1V3dwQWwxNUtGd1hCZGhvc2hBQUFBQUVkbHg2Z3BGZGJrZitUNUJGaGdLaE9vNUwrUytaOGZHT2lqTzZESGNKRURBQUFBNEFyN0IwY01MWVF5aFFGTnNPQm5RWTRZUEN5dHl3T1dSVUVMQVlzL0VjSUFBQUFBOEp4c1lKTWZ6QVMwT0tBcDlyMEFSdzRPeW0rNWt0YmlvQ1dkLzMwR3ZHMWVoREFBQUFBQW1rSTJ1Q2szck1sL01hNU44ekdWQ1V4eUg0dDl2aWhjSVZoQk9iaVFBQUFBQU1BeThnS2MvR0FtVU1iM0F0bm5McVBnYXpqSFVpWWtLZWRWTkdBaFVJRlRPUGtCQUFBQW9NNnlNMHNWQmpOTGZWVGVSNlBnODl4elhiREk5NHI5emxMUGg5VThJMXJaVjZIME1zdWFlUit0SWw4WHZzd2lYeTk2TVk0SzNPNy9BWlpVdEZrVTVMYkhBQUFBQUVsRlRrU3VRbUNDIi8+CjwvZGVmcz4KPC9zdmc+Cg==\";","var _rect, _path;\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nimport * as React from \"react\";\nvar SvgSearch = function SvgSearch(props) {\n return /*#__PURE__*/React.createElement(\"svg\", _extends({\n width: 24,\n height: 24,\n fill: \"#1D1D1F\",\n xmlns: \"http://www.w3.org/2000/svg\"\n }, props), _rect || (_rect = /*#__PURE__*/React.createElement(\"rect\", {\n y: 24,\n width: 24,\n height: 24,\n rx: 2,\n transform: \"rotate(-90 0 24)\",\n fill: \"#F0F3F5\"\n })), _path || (_path = /*#__PURE__*/React.createElement(\"path\", {\n d: \"M6 10.5c0 3 2.5 5.5 5.5 5.5 1.1 0 2.1-.3 3-.9l3 3.4 1.1-1-2.9-3.4c.9-1 1.4-2.2 1.4-3.6 0-3-2.5-5.5-5.5-5.5C8.5 5 6 7.5 6 10.5Zm9.5 0c0 2.2-1.8 4-4 4s-4-1.8-4-4 1.8-4 4-4 4 1.8 4 4Z\",\n fill: \"#999\"\n })));\n};\nexport { SvgSearch as ReactComponent };\nexport default \"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHZpZXdCb3g9IjAgMCAyNCAyNCIgZmlsbD0iIzFEMUQxRiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICAgIDxyZWN0IHk9IjI0IiB3aWR0aD0iMjQiIGhlaWdodD0iMjQiIHJ4PSIyIiB0cmFuc2Zvcm09InJvdGF0ZSgtOTAgMCAyNCkiIGZpbGw9IiNGMEYzRjUiIC8+CiAgICA8cGF0aAogICAgICAgIGQ9Ik02IDEwLjVDNiAxMy41IDguNSAxNiAxMS41IDE2QzEyLjYgMTYgMTMuNiAxNS43IDE0LjUgMTUuMUwxNy41IDE4LjVMMTguNiAxNy41TDE1LjcgMTQuMUMxNi42IDEzLjEgMTcuMSAxMS45IDE3LjEgMTAuNUMxNy4xIDcuNSAxNC42IDUgMTEuNiA1QzguNSA1IDYgNy41IDYgMTAuNVpNMTUuNSAxMC41QzE1LjUgMTIuNyAxMy43IDE0LjUgMTEuNSAxNC41QzkuMyAxNC41IDcuNSAxMi43IDcuNSAxMC41QzcuNSA4LjMgOS4zIDYuNSAxMS41IDYuNUMxMy43IDYuNSAxNS41IDguMyAxNS41IDEwLjVaIgogICAgICAgIGZpbGw9IiM5OTk5OTkiIC8+Cjwvc3ZnPg==\";","'use strict';\n\nvar AlgoliaSearchHelper = require('./src/algoliasearch.helper');\n\nvar SearchParameters = require('./src/SearchParameters');\nvar SearchResults = require('./src/SearchResults');\n\n/**\n * The algoliasearchHelper module is the function that will let its\n * contains everything needed to use the Algoliasearch\n * Helper. It is a also a function that instanciate the helper.\n * To use the helper, you also need the Algolia JS client v3.\n * @example\n * //using the UMD build\n * var client = algoliasearch('latency', '6be0576ff61c053d5f9a3225e2a90f76');\n * var helper = algoliasearchHelper(client, 'bestbuy', {\n * facets: ['shipping'],\n * disjunctiveFacets: ['category']\n * });\n * helper.on('result', function(event) {\n * console.log(event.results);\n * });\n * helper\n * .toggleFacetRefinement('category', 'Movies & TV Shows')\n * .toggleFacetRefinement('shipping', 'Free shipping')\n * .search();\n * @example\n * // The helper is an event emitter using the node API\n * helper.on('result', updateTheResults);\n * helper.once('result', updateTheResults);\n * helper.removeListener('result', updateTheResults);\n * helper.removeAllListeners('result');\n * @module algoliasearchHelper\n * @param {AlgoliaSearch} client an AlgoliaSearch client\n * @param {string} index the name of the index to query\n * @param {SearchParameters|object} opts an object defining the initial config of the search. It doesn't have to be a {SearchParameters}, just an object containing the properties you need from it.\n * @return {AlgoliaSearchHelper}\n */\nfunction algoliasearchHelper(client, index, opts) {\n return new AlgoliaSearchHelper(client, index, opts);\n}\n\n/**\n * The version currently used\n * @member module:algoliasearchHelper.version\n * @type {number}\n */\nalgoliasearchHelper.version = require('./src/version.js');\n\n/**\n * Constructor for the Helper.\n * @member module:algoliasearchHelper.AlgoliaSearchHelper\n * @type {AlgoliaSearchHelper}\n */\nalgoliasearchHelper.AlgoliaSearchHelper = AlgoliaSearchHelper;\n\n/**\n * Constructor for the object containing all the parameters of the search.\n * @member module:algoliasearchHelper.SearchParameters\n * @type {SearchParameters}\n */\nalgoliasearchHelper.SearchParameters = SearchParameters;\n\n/**\n * Constructor for the object containing the results of the search.\n * @member module:algoliasearchHelper.SearchResults\n * @type {SearchResults}\n */\nalgoliasearchHelper.SearchResults = SearchResults;\n\nmodule.exports = algoliasearchHelper;\n","'use strict';\n\nvar EventEmitter = require('@algolia/events');\nvar inherits = require('../functions/inherits');\n\n/**\n * A DerivedHelper is a way to create sub requests to\n * Algolia from a main helper.\n * @class\n * @classdesc The DerivedHelper provides an event based interface for search callbacks:\n * - search: when a search is triggered using the `search()` method.\n * - result: when the response is retrieved from Algolia and is processed.\n * This event contains a {@link SearchResults} object and the\n * {@link SearchParameters} corresponding to this answer.\n */\nfunction DerivedHelper(mainHelper, fn) {\n this.main = mainHelper;\n this.fn = fn;\n this.lastResults = null;\n}\n\ninherits(DerivedHelper, EventEmitter);\n\n/**\n * Detach this helper from the main helper\n * @return {undefined}\n * @throws Error if the derived helper is already detached\n */\nDerivedHelper.prototype.detach = function() {\n this.removeAllListeners();\n this.main.detachDerivedHelper(this);\n};\n\nDerivedHelper.prototype.getModifiedState = function(parameters) {\n return this.fn(parameters);\n};\n\nmodule.exports = DerivedHelper;\n","'use strict';\n\n/**\n * Functions to manipulate refinement lists\n *\n * The RefinementList is not formally defined through a prototype but is based\n * on a specific structure.\n *\n * @module SearchParameters.refinementList\n *\n * @typedef {string[]} SearchParameters.refinementList.Refinements\n * @typedef {Object.} SearchParameters.refinementList.RefinementList\n */\n\nvar defaultsPure = require('../functions/defaultsPure');\nvar omit = require('../functions/omit');\nvar objectHasKeys = require('../functions/objectHasKeys');\n\nvar lib = {\n /**\n * Adds a refinement to a RefinementList\n * @param {RefinementList} refinementList the initial list\n * @param {string} attribute the attribute to refine\n * @param {string} value the value of the refinement, if the value is not a string it will be converted\n * @return {RefinementList} a new and updated refinement list\n */\n addRefinement: function addRefinement(refinementList, attribute, value) {\n if (lib.isRefined(refinementList, attribute, value)) {\n return refinementList;\n }\n\n var valueAsString = '' + value;\n\n var facetRefinement = !refinementList[attribute] ?\n [valueAsString] :\n refinementList[attribute].concat(valueAsString);\n\n var mod = {};\n\n mod[attribute] = facetRefinement;\n\n return defaultsPure({}, mod, refinementList);\n },\n /**\n * Removes refinement(s) for an attribute:\n * - if the value is specified removes the refinement for the value on the attribute\n * - if no value is specified removes all the refinements for this attribute\n * @param {RefinementList} refinementList the initial list\n * @param {string} attribute the attribute to refine\n * @param {string} [value] the value of the refinement\n * @return {RefinementList} a new and updated refinement lst\n */\n removeRefinement: function removeRefinement(refinementList, attribute, value) {\n if (value === undefined) {\n // we use the \"filter\" form of clearRefinement, since it leaves empty values as-is\n // the form with a string will remove the attribute completely\n return lib.clearRefinement(refinementList, function(v, f) {\n return attribute === f;\n });\n }\n\n var valueAsString = '' + value;\n\n return lib.clearRefinement(refinementList, function(v, f) {\n return attribute === f && valueAsString === v;\n });\n },\n /**\n * Toggles the refinement value for an attribute.\n * @param {RefinementList} refinementList the initial list\n * @param {string} attribute the attribute to refine\n * @param {string} value the value of the refinement\n * @return {RefinementList} a new and updated list\n */\n toggleRefinement: function toggleRefinement(refinementList, attribute, value) {\n if (value === undefined) throw new Error('toggleRefinement should be used with a value');\n\n if (lib.isRefined(refinementList, attribute, value)) {\n return lib.removeRefinement(refinementList, attribute, value);\n }\n\n return lib.addRefinement(refinementList, attribute, value);\n },\n /**\n * Clear all or parts of a RefinementList. Depending on the arguments, three\n * kinds of behavior can happen:\n * - if no attribute is provided: clears the whole list\n * - if an attribute is provided as a string: clears the list for the specific attribute\n * - if an attribute is provided as a function: discards the elements for which the function returns true\n * @param {RefinementList} refinementList the initial list\n * @param {string} [attribute] the attribute or function to discard\n * @param {string} [refinementType] optional parameter to give more context to the attribute function\n * @return {RefinementList} a new and updated refinement list\n */\n clearRefinement: function clearRefinement(refinementList, attribute, refinementType) {\n if (attribute === undefined) {\n if (!objectHasKeys(refinementList)) {\n return refinementList;\n }\n return {};\n } else if (typeof attribute === 'string') {\n return omit(refinementList, [attribute]);\n } else if (typeof attribute === 'function') {\n var hasChanged = false;\n\n var newRefinementList = Object.keys(refinementList).reduce(function(memo, key) {\n var values = refinementList[key] || [];\n var facetList = values.filter(function(value) {\n return !attribute(value, key, refinementType);\n });\n\n if (facetList.length !== values.length) {\n hasChanged = true;\n }\n memo[key] = facetList;\n\n return memo;\n }, {});\n\n if (hasChanged) return newRefinementList;\n return refinementList;\n }\n },\n /**\n * Test if the refinement value is used for the attribute. If no refinement value\n * is provided, test if the refinementList contains any refinement for the\n * given attribute.\n * @param {RefinementList} refinementList the list of refinement\n * @param {string} attribute name of the attribute\n * @param {string} [refinementValue] value of the filter/refinement\n * @return {boolean}\n */\n isRefined: function isRefined(refinementList, attribute, refinementValue) {\n var containsRefinements = !!refinementList[attribute] &&\n refinementList[attribute].length > 0;\n\n if (refinementValue === undefined || !containsRefinements) {\n return containsRefinements;\n }\n\n var refinementValueAsString = '' + refinementValue;\n\n return refinementList[attribute].indexOf(refinementValueAsString) !== -1;\n }\n};\n\nmodule.exports = lib;\n","'use strict';\n\nvar merge = require('../functions/merge');\nvar defaultsPure = require('../functions/defaultsPure');\nvar intersection = require('../functions/intersection');\nvar find = require('../functions/find');\nvar valToNumber = require('../functions/valToNumber');\nvar omit = require('../functions/omit');\nvar objectHasKeys = require('../functions/objectHasKeys');\nvar isValidUserToken = require('../utils/isValidUserToken');\n\nvar RefinementList = require('./RefinementList');\n\n/**\n * isEqual, but only for numeric refinement values, possible values:\n * - 5\n * - [5]\n * - [[5]]\n * - [[5,5],[4]]\n */\nfunction isEqualNumericRefinement(a, b) {\n if (Array.isArray(a) && Array.isArray(b)) {\n return (\n a.length === b.length &&\n a.every(function(el, i) {\n return isEqualNumericRefinement(b[i], el);\n })\n );\n }\n return a === b;\n}\n\n/**\n * like _.find but using deep equality to be able to use it\n * to find arrays.\n * @private\n * @param {any[]} array array to search into (elements are base or array of base)\n * @param {any} searchedValue the value we're looking for (base or array of base)\n * @return {any} the searched value or undefined\n */\nfunction findArray(array, searchedValue) {\n return find(array, function(currentValue) {\n return isEqualNumericRefinement(currentValue, searchedValue);\n });\n}\n\n/**\n * The facet list is the structure used to store the list of values used to\n * filter a single attribute.\n * @typedef {string[]} SearchParameters.FacetList\n */\n\n/**\n * Structure to store numeric filters with the operator as the key. The supported operators\n * are `=`, `>`, `<`, `>=`, `<=` and `!=`.\n * @typedef {Object.>} SearchParameters.OperatorList\n */\n\n/**\n * SearchParameters is the data structure that contains all the information\n * usable for making a search to Algolia API. It doesn't do the search itself,\n * nor does it contains logic about the parameters.\n * It is an immutable object, therefore it has been created in a way that each\n * changes does not change the object itself but returns a copy with the\n * modification.\n * This object should probably not be instantiated outside of the helper. It will\n * be provided when needed. This object is documented for reference as you'll\n * get it from events generated by the {@link AlgoliaSearchHelper}.\n * If need be, instantiate the Helper from the factory function {@link SearchParameters.make}\n * @constructor\n * @classdesc contains all the parameters of a search\n * @param {object|SearchParameters} newParameters existing parameters or partial object\n * for the properties of a new SearchParameters\n * @see SearchParameters.make\n * @example SearchParameters of the first query in\n * the instant search demo\n{\n \"query\": \"\",\n \"disjunctiveFacets\": [\n \"customerReviewCount\",\n \"category\",\n \"salePrice_range\",\n \"manufacturer\"\n ],\n \"maxValuesPerFacet\": 30,\n \"page\": 0,\n \"hitsPerPage\": 10,\n \"facets\": [\n \"type\",\n \"shipping\"\n ]\n}\n */\nfunction SearchParameters(newParameters) {\n var params = newParameters ? SearchParameters._parseNumbers(newParameters) : {};\n\n if (params.userToken !== undefined && !isValidUserToken(params.userToken)) {\n console.warn('[algoliasearch-helper] The `userToken` parameter is invalid. This can lead to wrong analytics.\\n - Format: [a-zA-Z0-9_-]{1,64}');\n }\n /**\n * This attribute contains the list of all the conjunctive facets\n * used. This list will be added to requested facets in the\n * [facets attribute](https://www.algolia.com/doc/rest-api/search#param-facets) sent to algolia.\n * @member {string[]}\n */\n this.facets = params.facets || [];\n /**\n * This attribute contains the list of all the disjunctive facets\n * used. This list will be added to requested facets in the\n * [facets attribute](https://www.algolia.com/doc/rest-api/search#param-facets) sent to algolia.\n * @member {string[]}\n */\n this.disjunctiveFacets = params.disjunctiveFacets || [];\n /**\n * This attribute contains the list of all the hierarchical facets\n * used. This list will be added to requested facets in the\n * [facets attribute](https://www.algolia.com/doc/rest-api/search#param-facets) sent to algolia.\n * Hierarchical facets are a sub type of disjunctive facets that\n * let you filter faceted attributes hierarchically.\n * @member {string[]|object[]}\n */\n this.hierarchicalFacets = params.hierarchicalFacets || [];\n\n // Refinements\n /**\n * This attribute contains all the filters that need to be\n * applied on the conjunctive facets. Each facet must be properly\n * defined in the `facets` attribute.\n *\n * The key is the name of the facet, and the `FacetList` contains all\n * filters selected for the associated facet name.\n *\n * When querying algolia, the values stored in this attribute will\n * be translated into the `facetFilters` attribute.\n * @member {Object.}\n */\n this.facetsRefinements = params.facetsRefinements || {};\n /**\n * This attribute contains all the filters that need to be\n * excluded from the conjunctive facets. Each facet must be properly\n * defined in the `facets` attribute.\n *\n * The key is the name of the facet, and the `FacetList` contains all\n * filters excluded for the associated facet name.\n *\n * When querying algolia, the values stored in this attribute will\n * be translated into the `facetFilters` attribute.\n * @member {Object.}\n */\n this.facetsExcludes = params.facetsExcludes || {};\n /**\n * This attribute contains all the filters that need to be\n * applied on the disjunctive facets. Each facet must be properly\n * defined in the `disjunctiveFacets` attribute.\n *\n * The key is the name of the facet, and the `FacetList` contains all\n * filters selected for the associated facet name.\n *\n * When querying algolia, the values stored in this attribute will\n * be translated into the `facetFilters` attribute.\n * @member {Object.}\n */\n this.disjunctiveFacetsRefinements = params.disjunctiveFacetsRefinements || {};\n /**\n * This attribute contains all the filters that need to be\n * applied on the numeric attributes.\n *\n * The key is the name of the attribute, and the value is the\n * filters to apply to this attribute.\n *\n * When querying algolia, the values stored in this attribute will\n * be translated into the `numericFilters` attribute.\n * @member {Object.}\n */\n this.numericRefinements = params.numericRefinements || {};\n /**\n * This attribute contains all the tags used to refine the query.\n *\n * When querying algolia, the values stored in this attribute will\n * be translated into the `tagFilters` attribute.\n * @member {string[]}\n */\n this.tagRefinements = params.tagRefinements || [];\n /**\n * This attribute contains all the filters that need to be\n * applied on the hierarchical facets. Each facet must be properly\n * defined in the `hierarchicalFacets` attribute.\n *\n * The key is the name of the facet, and the `FacetList` contains all\n * filters selected for the associated facet name. The FacetList values\n * are structured as a string that contain the values for each level\n * separated by the configured separator.\n *\n * When querying algolia, the values stored in this attribute will\n * be translated into the `facetFilters` attribute.\n * @member {Object.}\n */\n this.hierarchicalFacetsRefinements = params.hierarchicalFacetsRefinements || {};\n\n var self = this;\n Object.keys(params).forEach(function(paramName) {\n var isKeyKnown = SearchParameters.PARAMETERS.indexOf(paramName) !== -1;\n var isValueDefined = params[paramName] !== undefined;\n\n if (!isKeyKnown && isValueDefined) {\n self[paramName] = params[paramName];\n }\n });\n}\n\n/**\n * List all the properties in SearchParameters and therefore all the known Algolia properties\n * This doesn't contain any beta/hidden features.\n * @private\n */\nSearchParameters.PARAMETERS = Object.keys(new SearchParameters());\n\n/**\n * @private\n * @param {object} partialState full or part of a state\n * @return {object} a new object with the number keys as number\n */\nSearchParameters._parseNumbers = function(partialState) {\n // Do not reparse numbers in SearchParameters, they ought to be parsed already\n if (partialState instanceof SearchParameters) return partialState;\n\n var numbers = {};\n\n var numberKeys = [\n 'aroundPrecision',\n 'aroundRadius',\n 'getRankingInfo',\n 'minWordSizefor2Typos',\n 'minWordSizefor1Typo',\n 'page',\n 'maxValuesPerFacet',\n 'distinct',\n 'minimumAroundRadius',\n 'hitsPerPage',\n 'minProximity'\n ];\n\n numberKeys.forEach(function(k) {\n var value = partialState[k];\n if (typeof value === 'string') {\n var parsedValue = parseFloat(value);\n // global isNaN is ok to use here, value is only number or NaN\n numbers[k] = isNaN(parsedValue) ? value : parsedValue;\n }\n });\n\n // there's two formats of insideBoundingBox, we need to parse\n // the one which is an array of float geo rectangles\n if (Array.isArray(partialState.insideBoundingBox)) {\n numbers.insideBoundingBox = partialState.insideBoundingBox.map(function(geoRect) {\n if (Array.isArray(geoRect)) {\n return geoRect.map(function(value) {\n return parseFloat(value);\n });\n }\n return geoRect;\n });\n }\n\n if (partialState.numericRefinements) {\n var numericRefinements = {};\n Object.keys(partialState.numericRefinements).forEach(function(attribute) {\n var operators = partialState.numericRefinements[attribute] || {};\n numericRefinements[attribute] = {};\n Object.keys(operators).forEach(function(operator) {\n var values = operators[operator];\n var parsedValues = values.map(function(v) {\n if (Array.isArray(v)) {\n return v.map(function(vPrime) {\n if (typeof vPrime === 'string') {\n return parseFloat(vPrime);\n }\n return vPrime;\n });\n } else if (typeof v === 'string') {\n return parseFloat(v);\n }\n return v;\n });\n numericRefinements[attribute][operator] = parsedValues;\n });\n });\n numbers.numericRefinements = numericRefinements;\n }\n\n return merge({}, partialState, numbers);\n};\n\n/**\n * Factory for SearchParameters\n * @param {object|SearchParameters} newParameters existing parameters or partial\n * object for the properties of a new SearchParameters\n * @return {SearchParameters} frozen instance of SearchParameters\n */\nSearchParameters.make = function makeSearchParameters(newParameters) {\n var instance = new SearchParameters(newParameters);\n\n var hierarchicalFacets = newParameters.hierarchicalFacets || [];\n hierarchicalFacets.forEach(function(facet) {\n if (facet.rootPath) {\n var currentRefinement = instance.getHierarchicalRefinement(facet.name);\n\n if (currentRefinement.length > 0 && currentRefinement[0].indexOf(facet.rootPath) !== 0) {\n instance = instance.clearRefinements(facet.name);\n }\n\n // get it again in case it has been cleared\n currentRefinement = instance.getHierarchicalRefinement(facet.name);\n if (currentRefinement.length === 0) {\n instance = instance.toggleHierarchicalFacetRefinement(facet.name, facet.rootPath);\n }\n }\n });\n\n return instance;\n};\n\n/**\n * Validates the new parameters based on the previous state\n * @param {SearchParameters} currentState the current state\n * @param {object|SearchParameters} parameters the new parameters to set\n * @return {Error|null} Error if the modification is invalid, null otherwise\n */\nSearchParameters.validate = function(currentState, parameters) {\n var params = parameters || {};\n\n if (currentState.tagFilters && params.tagRefinements && params.tagRefinements.length > 0) {\n return new Error(\n '[Tags] Cannot switch from the managed tag API to the advanced API. It is probably ' +\n 'an error, if it is really what you want, you should first clear the tags with clearTags method.');\n }\n\n if (currentState.tagRefinements.length > 0 && params.tagFilters) {\n return new Error(\n '[Tags] Cannot switch from the advanced tag API to the managed API. It is probably ' +\n 'an error, if it is not, you should first clear the tags with clearTags method.');\n }\n\n if (\n currentState.numericFilters &&\n params.numericRefinements &&\n objectHasKeys(params.numericRefinements)\n ) {\n return new Error(\n \"[Numeric filters] Can't switch from the advanced to the managed API. It\" +\n ' is probably an error, if this is really what you want, you have to first' +\n ' clear the numeric filters.'\n );\n }\n\n if (objectHasKeys(currentState.numericRefinements) && params.numericFilters) {\n return new Error(\n \"[Numeric filters] Can't switch from the managed API to the advanced. It\" +\n ' is probably an error, if this is really what you want, you have to first' +\n ' clear the numeric filters.');\n }\n\n return null;\n};\n\nSearchParameters.prototype = {\n constructor: SearchParameters,\n\n /**\n * Remove all refinements (disjunctive + conjunctive + excludes + numeric filters)\n * @method\n * @param {undefined|string|SearchParameters.clearCallback} [attribute] optional string or function\n * - If not given, means to clear all the filters.\n * - If `string`, means to clear all refinements for the `attribute` named filter.\n * - If `function`, means to clear all the refinements that return truthy values.\n * @return {SearchParameters}\n */\n clearRefinements: function clearRefinements(attribute) {\n var patch = {\n numericRefinements: this._clearNumericRefinements(attribute),\n facetsRefinements: RefinementList.clearRefinement(\n this.facetsRefinements,\n attribute,\n 'conjunctiveFacet'\n ),\n facetsExcludes: RefinementList.clearRefinement(\n this.facetsExcludes,\n attribute,\n 'exclude'\n ),\n disjunctiveFacetsRefinements: RefinementList.clearRefinement(\n this.disjunctiveFacetsRefinements,\n attribute,\n 'disjunctiveFacet'\n ),\n hierarchicalFacetsRefinements: RefinementList.clearRefinement(\n this.hierarchicalFacetsRefinements,\n attribute,\n 'hierarchicalFacet'\n )\n };\n if (\n patch.numericRefinements === this.numericRefinements &&\n patch.facetsRefinements === this.facetsRefinements &&\n patch.facetsExcludes === this.facetsExcludes &&\n patch.disjunctiveFacetsRefinements === this.disjunctiveFacetsRefinements &&\n patch.hierarchicalFacetsRefinements === this.hierarchicalFacetsRefinements\n ) {\n return this;\n }\n return this.setQueryParameters(patch);\n },\n /**\n * Remove all the refined tags from the SearchParameters\n * @method\n * @return {SearchParameters}\n */\n clearTags: function clearTags() {\n if (this.tagFilters === undefined && this.tagRefinements.length === 0) return this;\n\n return this.setQueryParameters({\n tagFilters: undefined,\n tagRefinements: []\n });\n },\n /**\n * Set the index.\n * @method\n * @param {string} index the index name\n * @return {SearchParameters}\n */\n setIndex: function setIndex(index) {\n if (index === this.index) return this;\n\n return this.setQueryParameters({\n index: index\n });\n },\n /**\n * Query setter\n * @method\n * @param {string} newQuery value for the new query\n * @return {SearchParameters}\n */\n setQuery: function setQuery(newQuery) {\n if (newQuery === this.query) return this;\n\n return this.setQueryParameters({\n query: newQuery\n });\n },\n /**\n * Page setter\n * @method\n * @param {number} newPage new page number\n * @return {SearchParameters}\n */\n setPage: function setPage(newPage) {\n if (newPage === this.page) return this;\n\n return this.setQueryParameters({\n page: newPage\n });\n },\n /**\n * Facets setter\n * The facets are the simple facets, used for conjunctive (and) faceting.\n * @method\n * @param {string[]} facets all the attributes of the algolia records used for conjunctive faceting\n * @return {SearchParameters}\n */\n setFacets: function setFacets(facets) {\n return this.setQueryParameters({\n facets: facets\n });\n },\n /**\n * Disjunctive facets setter\n * Change the list of disjunctive (or) facets the helper chan handle.\n * @method\n * @param {string[]} facets all the attributes of the algolia records used for disjunctive faceting\n * @return {SearchParameters}\n */\n setDisjunctiveFacets: function setDisjunctiveFacets(facets) {\n return this.setQueryParameters({\n disjunctiveFacets: facets\n });\n },\n /**\n * HitsPerPage setter\n * Hits per page represents the number of hits retrieved for this query\n * @method\n * @param {number} n number of hits retrieved per page of results\n * @return {SearchParameters}\n */\n setHitsPerPage: function setHitsPerPage(n) {\n if (this.hitsPerPage === n) return this;\n\n return this.setQueryParameters({\n hitsPerPage: n\n });\n },\n /**\n * typoTolerance setter\n * Set the value of typoTolerance\n * @method\n * @param {string} typoTolerance new value of typoTolerance (\"true\", \"false\", \"min\" or \"strict\")\n * @return {SearchParameters}\n */\n setTypoTolerance: function setTypoTolerance(typoTolerance) {\n if (this.typoTolerance === typoTolerance) return this;\n\n return this.setQueryParameters({\n typoTolerance: typoTolerance\n });\n },\n /**\n * Add a numeric filter for a given attribute\n * When value is an array, they are combined with OR\n * When value is a single value, it will combined with AND\n * @method\n * @param {string} attribute attribute to set the filter on\n * @param {string} operator operator of the filter (possible values: =, >, >=, <, <=, !=)\n * @param {number | number[]} value value of the filter\n * @return {SearchParameters}\n * @example\n * // for price = 50 or 40\n * searchparameter.addNumericRefinement('price', '=', [50, 40]);\n * @example\n * // for size = 38 and 40\n * searchparameter.addNumericRefinement('size', '=', 38);\n * searchparameter.addNumericRefinement('size', '=', 40);\n */\n addNumericRefinement: function(attribute, operator, v) {\n var value = valToNumber(v);\n\n if (this.isNumericRefined(attribute, operator, value)) return this;\n\n var mod = merge({}, this.numericRefinements);\n\n mod[attribute] = merge({}, mod[attribute]);\n\n if (mod[attribute][operator]) {\n // Array copy\n mod[attribute][operator] = mod[attribute][operator].slice();\n // Add the element. Concat can't be used here because value can be an array.\n mod[attribute][operator].push(value);\n } else {\n mod[attribute][operator] = [value];\n }\n\n return this.setQueryParameters({\n numericRefinements: mod\n });\n },\n /**\n * Get the list of conjunctive refinements for a single facet\n * @param {string} facetName name of the attribute used for faceting\n * @return {string[]} list of refinements\n */\n getConjunctiveRefinements: function(facetName) {\n if (!this.isConjunctiveFacet(facetName)) {\n return [];\n }\n return this.facetsRefinements[facetName] || [];\n },\n /**\n * Get the list of disjunctive refinements for a single facet\n * @param {string} facetName name of the attribute used for faceting\n * @return {string[]} list of refinements\n */\n getDisjunctiveRefinements: function(facetName) {\n if (!this.isDisjunctiveFacet(facetName)) {\n return [];\n }\n return this.disjunctiveFacetsRefinements[facetName] || [];\n },\n /**\n * Get the list of hierarchical refinements for a single facet\n * @param {string} facetName name of the attribute used for faceting\n * @return {string[]} list of refinements\n */\n getHierarchicalRefinement: function(facetName) {\n // we send an array but we currently do not support multiple\n // hierarchicalRefinements for a hierarchicalFacet\n return this.hierarchicalFacetsRefinements[facetName] || [];\n },\n /**\n * Get the list of exclude refinements for a single facet\n * @param {string} facetName name of the attribute used for faceting\n * @return {string[]} list of refinements\n */\n getExcludeRefinements: function(facetName) {\n if (!this.isConjunctiveFacet(facetName)) {\n return [];\n }\n return this.facetsExcludes[facetName] || [];\n },\n\n /**\n * Remove all the numeric filter for a given (attribute, operator)\n * @method\n * @param {string} attribute attribute to set the filter on\n * @param {string} [operator] operator of the filter (possible values: =, >, >=, <, <=, !=)\n * @param {number} [number] the value to be removed\n * @return {SearchParameters}\n */\n removeNumericRefinement: function(attribute, operator, paramValue) {\n if (paramValue !== undefined) {\n if (!this.isNumericRefined(attribute, operator, paramValue)) {\n return this;\n }\n return this.setQueryParameters({\n numericRefinements: this._clearNumericRefinements(function(value, key) {\n return (\n key === attribute &&\n value.op === operator &&\n isEqualNumericRefinement(value.val, valToNumber(paramValue))\n );\n })\n });\n } else if (operator !== undefined) {\n if (!this.isNumericRefined(attribute, operator)) return this;\n return this.setQueryParameters({\n numericRefinements: this._clearNumericRefinements(function(value, key) {\n return key === attribute && value.op === operator;\n })\n });\n }\n\n if (!this.isNumericRefined(attribute)) return this;\n return this.setQueryParameters({\n numericRefinements: this._clearNumericRefinements(function(value, key) {\n return key === attribute;\n })\n });\n },\n /**\n * Get the list of numeric refinements for a single facet\n * @param {string} facetName name of the attribute used for faceting\n * @return {SearchParameters.OperatorList} list of refinements\n */\n getNumericRefinements: function(facetName) {\n return this.numericRefinements[facetName] || {};\n },\n /**\n * Return the current refinement for the (attribute, operator)\n * @param {string} attribute attribute in the record\n * @param {string} operator operator applied on the refined values\n * @return {Array.} refined values\n */\n getNumericRefinement: function(attribute, operator) {\n return this.numericRefinements[attribute] && this.numericRefinements[attribute][operator];\n },\n /**\n * Clear numeric filters.\n * @method\n * @private\n * @param {string|SearchParameters.clearCallback} [attribute] optional string or function\n * - If not given, means to clear all the filters.\n * - If `string`, means to clear all refinements for the `attribute` named filter.\n * - If `function`, means to clear all the refinements that return truthy values.\n * @return {Object.}\n */\n _clearNumericRefinements: function _clearNumericRefinements(attribute) {\n if (attribute === undefined) {\n if (!objectHasKeys(this.numericRefinements)) {\n return this.numericRefinements;\n }\n return {};\n } else if (typeof attribute === 'string') {\n return omit(this.numericRefinements, [attribute]);\n } else if (typeof attribute === 'function') {\n var hasChanged = false;\n var numericRefinements = this.numericRefinements;\n var newNumericRefinements = Object.keys(numericRefinements).reduce(function(memo, key) {\n var operators = numericRefinements[key];\n var operatorList = {};\n\n operators = operators || {};\n Object.keys(operators).forEach(function(operator) {\n var values = operators[operator] || [];\n var outValues = [];\n values.forEach(function(value) {\n var predicateResult = attribute({val: value, op: operator}, key, 'numeric');\n if (!predicateResult) outValues.push(value);\n });\n if (outValues.length !== values.length) {\n hasChanged = true;\n }\n operatorList[operator] = outValues;\n });\n\n memo[key] = operatorList;\n\n return memo;\n }, {});\n\n if (hasChanged) return newNumericRefinements;\n return this.numericRefinements;\n }\n },\n /**\n * Add a facet to the facets attribute of the helper configuration, if it\n * isn't already present.\n * @method\n * @param {string} facet facet name to add\n * @return {SearchParameters}\n */\n addFacet: function addFacet(facet) {\n if (this.isConjunctiveFacet(facet)) {\n return this;\n }\n\n return this.setQueryParameters({\n facets: this.facets.concat([facet])\n });\n },\n /**\n * Add a disjunctive facet to the disjunctiveFacets attribute of the helper\n * configuration, if it isn't already present.\n * @method\n * @param {string} facet disjunctive facet name to add\n * @return {SearchParameters}\n */\n addDisjunctiveFacet: function addDisjunctiveFacet(facet) {\n if (this.isDisjunctiveFacet(facet)) {\n return this;\n }\n\n return this.setQueryParameters({\n disjunctiveFacets: this.disjunctiveFacets.concat([facet])\n });\n },\n /**\n * Add a hierarchical facet to the hierarchicalFacets attribute of the helper\n * configuration.\n * @method\n * @param {object} hierarchicalFacet hierarchical facet to add\n * @return {SearchParameters}\n * @throws will throw an error if a hierarchical facet with the same name was already declared\n */\n addHierarchicalFacet: function addHierarchicalFacet(hierarchicalFacet) {\n if (this.isHierarchicalFacet(hierarchicalFacet.name)) {\n throw new Error(\n 'Cannot declare two hierarchical facets with the same name: `' + hierarchicalFacet.name + '`');\n }\n\n return this.setQueryParameters({\n hierarchicalFacets: this.hierarchicalFacets.concat([hierarchicalFacet])\n });\n },\n /**\n * Add a refinement on a \"normal\" facet\n * @method\n * @param {string} facet attribute to apply the faceting on\n * @param {string} value value of the attribute (will be converted to string)\n * @return {SearchParameters}\n */\n addFacetRefinement: function addFacetRefinement(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n throw new Error(facet + ' is not defined in the facets attribute of the helper configuration');\n }\n if (RefinementList.isRefined(this.facetsRefinements, facet, value)) return this;\n\n return this.setQueryParameters({\n facetsRefinements: RefinementList.addRefinement(this.facetsRefinements, facet, value)\n });\n },\n /**\n * Exclude a value from a \"normal\" facet\n * @method\n * @param {string} facet attribute to apply the exclusion on\n * @param {string} value value of the attribute (will be converted to string)\n * @return {SearchParameters}\n */\n addExcludeRefinement: function addExcludeRefinement(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n throw new Error(facet + ' is not defined in the facets attribute of the helper configuration');\n }\n if (RefinementList.isRefined(this.facetsExcludes, facet, value)) return this;\n\n return this.setQueryParameters({\n facetsExcludes: RefinementList.addRefinement(this.facetsExcludes, facet, value)\n });\n },\n /**\n * Adds a refinement on a disjunctive facet.\n * @method\n * @param {string} facet attribute to apply the faceting on\n * @param {string} value value of the attribute (will be converted to string)\n * @return {SearchParameters}\n */\n addDisjunctiveFacetRefinement: function addDisjunctiveFacetRefinement(facet, value) {\n if (!this.isDisjunctiveFacet(facet)) {\n throw new Error(\n facet + ' is not defined in the disjunctiveFacets attribute of the helper configuration');\n }\n\n if (RefinementList.isRefined(this.disjunctiveFacetsRefinements, facet, value)) return this;\n\n return this.setQueryParameters({\n disjunctiveFacetsRefinements: RefinementList.addRefinement(\n this.disjunctiveFacetsRefinements, facet, value)\n });\n },\n /**\n * addTagRefinement adds a tag to the list used to filter the results\n * @param {string} tag tag to be added\n * @return {SearchParameters}\n */\n addTagRefinement: function addTagRefinement(tag) {\n if (this.isTagRefined(tag)) return this;\n\n var modification = {\n tagRefinements: this.tagRefinements.concat(tag)\n };\n\n return this.setQueryParameters(modification);\n },\n /**\n * Remove a facet from the facets attribute of the helper configuration, if it\n * is present.\n * @method\n * @param {string} facet facet name to remove\n * @return {SearchParameters}\n */\n removeFacet: function removeFacet(facet) {\n if (!this.isConjunctiveFacet(facet)) {\n return this;\n }\n\n return this.clearRefinements(facet).setQueryParameters({\n facets: this.facets.filter(function(f) {\n return f !== facet;\n })\n });\n },\n /**\n * Remove a disjunctive facet from the disjunctiveFacets attribute of the\n * helper configuration, if it is present.\n * @method\n * @param {string} facet disjunctive facet name to remove\n * @return {SearchParameters}\n */\n removeDisjunctiveFacet: function removeDisjunctiveFacet(facet) {\n if (!this.isDisjunctiveFacet(facet)) {\n return this;\n }\n\n return this.clearRefinements(facet).setQueryParameters({\n disjunctiveFacets: this.disjunctiveFacets.filter(function(f) {\n return f !== facet;\n })\n });\n },\n /**\n * Remove a hierarchical facet from the hierarchicalFacets attribute of the\n * helper configuration, if it is present.\n * @method\n * @param {string} facet hierarchical facet name to remove\n * @return {SearchParameters}\n */\n removeHierarchicalFacet: function removeHierarchicalFacet(facet) {\n if (!this.isHierarchicalFacet(facet)) {\n return this;\n }\n\n return this.clearRefinements(facet).setQueryParameters({\n hierarchicalFacets: this.hierarchicalFacets.filter(function(f) {\n return f.name !== facet;\n })\n });\n },\n /**\n * Remove a refinement set on facet. If a value is provided, it will clear the\n * refinement for the given value, otherwise it will clear all the refinement\n * values for the faceted attribute.\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {string} [value] value used to filter\n * @return {SearchParameters}\n */\n removeFacetRefinement: function removeFacetRefinement(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n throw new Error(facet + ' is not defined in the facets attribute of the helper configuration');\n }\n if (!RefinementList.isRefined(this.facetsRefinements, facet, value)) return this;\n\n return this.setQueryParameters({\n facetsRefinements: RefinementList.removeRefinement(this.facetsRefinements, facet, value)\n });\n },\n /**\n * Remove a negative refinement on a facet\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {string} value value used to filter\n * @return {SearchParameters}\n */\n removeExcludeRefinement: function removeExcludeRefinement(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n throw new Error(facet + ' is not defined in the facets attribute of the helper configuration');\n }\n if (!RefinementList.isRefined(this.facetsExcludes, facet, value)) return this;\n\n return this.setQueryParameters({\n facetsExcludes: RefinementList.removeRefinement(this.facetsExcludes, facet, value)\n });\n },\n /**\n * Remove a refinement on a disjunctive facet\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {string} value value used to filter\n * @return {SearchParameters}\n */\n removeDisjunctiveFacetRefinement: function removeDisjunctiveFacetRefinement(facet, value) {\n if (!this.isDisjunctiveFacet(facet)) {\n throw new Error(\n facet + ' is not defined in the disjunctiveFacets attribute of the helper configuration');\n }\n if (!RefinementList.isRefined(this.disjunctiveFacetsRefinements, facet, value)) return this;\n\n return this.setQueryParameters({\n disjunctiveFacetsRefinements: RefinementList.removeRefinement(\n this.disjunctiveFacetsRefinements, facet, value)\n });\n },\n /**\n * Remove a tag from the list of tag refinements\n * @method\n * @param {string} tag the tag to remove\n * @return {SearchParameters}\n */\n removeTagRefinement: function removeTagRefinement(tag) {\n if (!this.isTagRefined(tag)) return this;\n\n var modification = {\n tagRefinements: this.tagRefinements.filter(function(t) {\n return t !== tag;\n })\n };\n\n return this.setQueryParameters(modification);\n },\n /**\n * Generic toggle refinement method to use with facet, disjunctive facets\n * and hierarchical facets\n * @param {string} facet the facet to refine\n * @param {string} value the associated value\n * @return {SearchParameters}\n * @throws will throw an error if the facet is not declared in the settings of the helper\n * @deprecated since version 2.19.0, see {@link SearchParameters#toggleFacetRefinement}\n */\n toggleRefinement: function toggleRefinement(facet, value) {\n return this.toggleFacetRefinement(facet, value);\n },\n /**\n * Generic toggle refinement method to use with facet, disjunctive facets\n * and hierarchical facets\n * @param {string} facet the facet to refine\n * @param {string} value the associated value\n * @return {SearchParameters}\n * @throws will throw an error if the facet is not declared in the settings of the helper\n */\n toggleFacetRefinement: function toggleFacetRefinement(facet, value) {\n if (this.isHierarchicalFacet(facet)) {\n return this.toggleHierarchicalFacetRefinement(facet, value);\n } else if (this.isConjunctiveFacet(facet)) {\n return this.toggleConjunctiveFacetRefinement(facet, value);\n } else if (this.isDisjunctiveFacet(facet)) {\n return this.toggleDisjunctiveFacetRefinement(facet, value);\n }\n\n throw new Error('Cannot refine the undeclared facet ' + facet +\n '; it should be added to the helper options facets, disjunctiveFacets or hierarchicalFacets');\n },\n /**\n * Switch the refinement applied over a facet/value\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {value} value value used for filtering\n * @return {SearchParameters}\n */\n toggleConjunctiveFacetRefinement: function toggleConjunctiveFacetRefinement(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n throw new Error(facet + ' is not defined in the facets attribute of the helper configuration');\n }\n\n return this.setQueryParameters({\n facetsRefinements: RefinementList.toggleRefinement(this.facetsRefinements, facet, value)\n });\n },\n /**\n * Switch the refinement applied over a facet/value\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {value} value value used for filtering\n * @return {SearchParameters}\n */\n toggleExcludeFacetRefinement: function toggleExcludeFacetRefinement(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n throw new Error(facet + ' is not defined in the facets attribute of the helper configuration');\n }\n\n return this.setQueryParameters({\n facetsExcludes: RefinementList.toggleRefinement(this.facetsExcludes, facet, value)\n });\n },\n /**\n * Switch the refinement applied over a facet/value\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {value} value value used for filtering\n * @return {SearchParameters}\n */\n toggleDisjunctiveFacetRefinement: function toggleDisjunctiveFacetRefinement(facet, value) {\n if (!this.isDisjunctiveFacet(facet)) {\n throw new Error(\n facet + ' is not defined in the disjunctiveFacets attribute of the helper configuration');\n }\n\n return this.setQueryParameters({\n disjunctiveFacetsRefinements: RefinementList.toggleRefinement(\n this.disjunctiveFacetsRefinements, facet, value)\n });\n },\n /**\n * Switch the refinement applied over a facet/value\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {value} value value used for filtering\n * @return {SearchParameters}\n */\n toggleHierarchicalFacetRefinement: function toggleHierarchicalFacetRefinement(facet, value) {\n if (!this.isHierarchicalFacet(facet)) {\n throw new Error(\n facet + ' is not defined in the hierarchicalFacets attribute of the helper configuration');\n }\n\n var separator = this._getHierarchicalFacetSeparator(this.getHierarchicalFacetByName(facet));\n\n var mod = {};\n\n var upOneOrMultipleLevel = this.hierarchicalFacetsRefinements[facet] !== undefined &&\n this.hierarchicalFacetsRefinements[facet].length > 0 && (\n // remove current refinement:\n // refinement was 'beer > IPA', call is toggleRefine('beer > IPA'), refinement should be `beer`\n this.hierarchicalFacetsRefinements[facet][0] === value ||\n // remove a parent refinement of the current refinement:\n // - refinement was 'beer > IPA > Flying dog'\n // - call is toggleRefine('beer > IPA')\n // - refinement should be `beer`\n this.hierarchicalFacetsRefinements[facet][0].indexOf(value + separator) === 0\n );\n\n if (upOneOrMultipleLevel) {\n if (value.indexOf(separator) === -1) {\n // go back to root level\n mod[facet] = [];\n } else {\n mod[facet] = [value.slice(0, value.lastIndexOf(separator))];\n }\n } else {\n mod[facet] = [value];\n }\n\n return this.setQueryParameters({\n hierarchicalFacetsRefinements: defaultsPure({}, mod, this.hierarchicalFacetsRefinements)\n });\n },\n\n /**\n * Adds a refinement on a hierarchical facet.\n * @param {string} facet the facet name\n * @param {string} path the hierarchical facet path\n * @return {SearchParameter} the new state\n * @throws Error if the facet is not defined or if the facet is refined\n */\n addHierarchicalFacetRefinement: function(facet, path) {\n if (this.isHierarchicalFacetRefined(facet)) {\n throw new Error(facet + ' is already refined.');\n }\n if (!this.isHierarchicalFacet(facet)) {\n throw new Error(facet + ' is not defined in the hierarchicalFacets attribute of the helper configuration.');\n }\n var mod = {};\n mod[facet] = [path];\n return this.setQueryParameters({\n hierarchicalFacetsRefinements: defaultsPure({}, mod, this.hierarchicalFacetsRefinements)\n });\n },\n\n /**\n * Removes the refinement set on a hierarchical facet.\n * @param {string} facet the facet name\n * @return {SearchParameter} the new state\n * @throws Error if the facet is not defined or if the facet is not refined\n */\n removeHierarchicalFacetRefinement: function(facet) {\n if (!this.isHierarchicalFacetRefined(facet)) {\n return this;\n }\n var mod = {};\n mod[facet] = [];\n return this.setQueryParameters({\n hierarchicalFacetsRefinements: defaultsPure({}, mod, this.hierarchicalFacetsRefinements)\n });\n },\n /**\n * Switch the tag refinement\n * @method\n * @param {string} tag the tag to remove or add\n * @return {SearchParameters}\n */\n toggleTagRefinement: function toggleTagRefinement(tag) {\n if (this.isTagRefined(tag)) {\n return this.removeTagRefinement(tag);\n }\n\n return this.addTagRefinement(tag);\n },\n /**\n * Test if the facet name is from one of the disjunctive facets\n * @method\n * @param {string} facet facet name to test\n * @return {boolean}\n */\n isDisjunctiveFacet: function(facet) {\n return this.disjunctiveFacets.indexOf(facet) > -1;\n },\n /**\n * Test if the facet name is from one of the hierarchical facets\n * @method\n * @param {string} facetName facet name to test\n * @return {boolean}\n */\n isHierarchicalFacet: function(facetName) {\n return this.getHierarchicalFacetByName(facetName) !== undefined;\n },\n /**\n * Test if the facet name is from one of the conjunctive/normal facets\n * @method\n * @param {string} facet facet name to test\n * @return {boolean}\n */\n isConjunctiveFacet: function(facet) {\n return this.facets.indexOf(facet) > -1;\n },\n /**\n * Returns true if the facet is refined, either for a specific value or in\n * general.\n * @method\n * @param {string} facet name of the attribute for used for faceting\n * @param {string} value, optional value. If passed will test that this value\n * is filtering the given facet.\n * @return {boolean} returns true if refined\n */\n isFacetRefined: function isFacetRefined(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n return false;\n }\n return RefinementList.isRefined(this.facetsRefinements, facet, value);\n },\n /**\n * Returns true if the facet contains exclusions or if a specific value is\n * excluded.\n *\n * @method\n * @param {string} facet name of the attribute for used for faceting\n * @param {string} [value] optional value. If passed will test that this value\n * is filtering the given facet.\n * @return {boolean} returns true if refined\n */\n isExcludeRefined: function isExcludeRefined(facet, value) {\n if (!this.isConjunctiveFacet(facet)) {\n return false;\n }\n return RefinementList.isRefined(this.facetsExcludes, facet, value);\n },\n /**\n * Returns true if the facet contains a refinement, or if a value passed is a\n * refinement for the facet.\n * @method\n * @param {string} facet name of the attribute for used for faceting\n * @param {string} value optional, will test if the value is used for refinement\n * if there is one, otherwise will test if the facet contains any refinement\n * @return {boolean}\n */\n isDisjunctiveFacetRefined: function isDisjunctiveFacetRefined(facet, value) {\n if (!this.isDisjunctiveFacet(facet)) {\n return false;\n }\n return RefinementList.isRefined(this.disjunctiveFacetsRefinements, facet, value);\n },\n /**\n * Returns true if the facet contains a refinement, or if a value passed is a\n * refinement for the facet.\n * @method\n * @param {string} facet name of the attribute for used for faceting\n * @param {string} value optional, will test if the value is used for refinement\n * if there is one, otherwise will test if the facet contains any refinement\n * @return {boolean}\n */\n isHierarchicalFacetRefined: function isHierarchicalFacetRefined(facet, value) {\n if (!this.isHierarchicalFacet(facet)) {\n return false;\n }\n\n var refinements = this.getHierarchicalRefinement(facet);\n\n if (!value) {\n return refinements.length > 0;\n }\n\n return refinements.indexOf(value) !== -1;\n },\n /**\n * Test if the triple (attribute, operator, value) is already refined.\n * If only the attribute and the operator are provided, it tests if the\n * contains any refinement value.\n * @method\n * @param {string} attribute attribute for which the refinement is applied\n * @param {string} [operator] operator of the refinement\n * @param {string} [value] value of the refinement\n * @return {boolean} true if it is refined\n */\n isNumericRefined: function isNumericRefined(attribute, operator, value) {\n if (value === undefined && operator === undefined) {\n return !!this.numericRefinements[attribute];\n }\n\n var isOperatorDefined =\n this.numericRefinements[attribute] &&\n this.numericRefinements[attribute][operator] !== undefined;\n\n if (value === undefined || !isOperatorDefined) {\n return isOperatorDefined;\n }\n\n var parsedValue = valToNumber(value);\n var isAttributeValueDefined =\n findArray(this.numericRefinements[attribute][operator], parsedValue) !==\n undefined;\n\n return isOperatorDefined && isAttributeValueDefined;\n },\n /**\n * Returns true if the tag refined, false otherwise\n * @method\n * @param {string} tag the tag to check\n * @return {boolean}\n */\n isTagRefined: function isTagRefined(tag) {\n return this.tagRefinements.indexOf(tag) !== -1;\n },\n /**\n * Returns the list of all disjunctive facets refined\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {value} value value used for filtering\n * @return {string[]}\n */\n getRefinedDisjunctiveFacets: function getRefinedDisjunctiveFacets() {\n var self = this;\n\n // attributes used for numeric filter can also be disjunctive\n var disjunctiveNumericRefinedFacets = intersection(\n Object.keys(this.numericRefinements).filter(function(facet) {\n return Object.keys(self.numericRefinements[facet]).length > 0;\n }),\n this.disjunctiveFacets\n );\n\n return Object.keys(this.disjunctiveFacetsRefinements).filter(function(facet) {\n return self.disjunctiveFacetsRefinements[facet].length > 0;\n })\n .concat(disjunctiveNumericRefinedFacets)\n .concat(this.getRefinedHierarchicalFacets());\n },\n /**\n * Returns the list of all disjunctive facets refined\n * @method\n * @param {string} facet name of the attribute used for faceting\n * @param {value} value value used for filtering\n * @return {string[]}\n */\n getRefinedHierarchicalFacets: function getRefinedHierarchicalFacets() {\n var self = this;\n return intersection(\n // enforce the order between the two arrays,\n // so that refinement name index === hierarchical facet index\n this.hierarchicalFacets.map(function(facet) { return facet.name; }),\n Object.keys(this.hierarchicalFacetsRefinements).filter(function(facet) {\n return self.hierarchicalFacetsRefinements[facet].length > 0;\n })\n );\n },\n /**\n * Returned the list of all disjunctive facets not refined\n * @method\n * @return {string[]}\n */\n getUnrefinedDisjunctiveFacets: function() {\n var refinedFacets = this.getRefinedDisjunctiveFacets();\n\n return this.disjunctiveFacets.filter(function(f) {\n return refinedFacets.indexOf(f) === -1;\n });\n },\n\n managedParameters: [\n 'index',\n\n 'facets',\n 'disjunctiveFacets',\n 'facetsRefinements',\n 'hierarchicalFacets',\n 'facetsExcludes',\n\n 'disjunctiveFacetsRefinements',\n 'numericRefinements',\n 'tagRefinements',\n 'hierarchicalFacetsRefinements'\n ],\n getQueryParams: function getQueryParams() {\n var managedParameters = this.managedParameters;\n\n var queryParams = {};\n\n var self = this;\n Object.keys(this).forEach(function(paramName) {\n var paramValue = self[paramName];\n if (managedParameters.indexOf(paramName) === -1 && paramValue !== undefined) {\n queryParams[paramName] = paramValue;\n }\n });\n\n return queryParams;\n },\n /**\n * Let the user set a specific value for a given parameter. Will return the\n * same instance if the parameter is invalid or if the value is the same as the\n * previous one.\n * @method\n * @param {string} parameter the parameter name\n * @param {any} value the value to be set, must be compliant with the definition\n * of the attribute on the object\n * @return {SearchParameters} the updated state\n */\n setQueryParameter: function setParameter(parameter, value) {\n if (this[parameter] === value) return this;\n\n var modification = {};\n\n modification[parameter] = value;\n\n return this.setQueryParameters(modification);\n },\n /**\n * Let the user set any of the parameters with a plain object.\n * @method\n * @param {object} params all the keys and the values to be updated\n * @return {SearchParameters} a new updated instance\n */\n setQueryParameters: function setQueryParameters(params) {\n if (!params) return this;\n\n var error = SearchParameters.validate(this, params);\n\n if (error) {\n throw error;\n }\n\n var self = this;\n var nextWithNumbers = SearchParameters._parseNumbers(params);\n var previousPlainObject = Object.keys(this).reduce(function(acc, key) {\n acc[key] = self[key];\n return acc;\n }, {});\n\n var nextPlainObject = Object.keys(nextWithNumbers).reduce(\n function(previous, key) {\n var isPreviousValueDefined = previous[key] !== undefined;\n var isNextValueDefined = nextWithNumbers[key] !== undefined;\n\n if (isPreviousValueDefined && !isNextValueDefined) {\n return omit(previous, [key]);\n }\n\n if (isNextValueDefined) {\n previous[key] = nextWithNumbers[key];\n }\n\n return previous;\n },\n previousPlainObject\n );\n\n return new this.constructor(nextPlainObject);\n },\n\n /**\n * Returns a new instance with the page reset. Two scenarios possible:\n * the page is omitted -> return the given instance\n * the page is set -> return a new instance with a page of 0\n * @return {SearchParameters} a new updated instance\n */\n resetPage: function() {\n if (this.page === undefined) {\n return this;\n }\n\n return this.setPage(0);\n },\n\n /**\n * Helper function to get the hierarchicalFacet separator or the default one (`>`)\n * @param {object} hierarchicalFacet\n * @return {string} returns the hierarchicalFacet.separator or `>` as default\n */\n _getHierarchicalFacetSortBy: function(hierarchicalFacet) {\n return hierarchicalFacet.sortBy || ['isRefined:desc', 'name:asc'];\n },\n\n /**\n * Helper function to get the hierarchicalFacet separator or the default one (`>`)\n * @private\n * @param {object} hierarchicalFacet\n * @return {string} returns the hierarchicalFacet.separator or `>` as default\n */\n _getHierarchicalFacetSeparator: function(hierarchicalFacet) {\n return hierarchicalFacet.separator || ' > ';\n },\n\n /**\n * Helper function to get the hierarchicalFacet prefix path or null\n * @private\n * @param {object} hierarchicalFacet\n * @return {string} returns the hierarchicalFacet.rootPath or null as default\n */\n _getHierarchicalRootPath: function(hierarchicalFacet) {\n return hierarchicalFacet.rootPath || null;\n },\n\n /**\n * Helper function to check if we show the parent level of the hierarchicalFacet\n * @private\n * @param {object} hierarchicalFacet\n * @return {string} returns the hierarchicalFacet.showParentLevel or true as default\n */\n _getHierarchicalShowParentLevel: function(hierarchicalFacet) {\n if (typeof hierarchicalFacet.showParentLevel === 'boolean') {\n return hierarchicalFacet.showParentLevel;\n }\n return true;\n },\n\n /**\n * Helper function to get the hierarchicalFacet by it's name\n * @param {string} hierarchicalFacetName\n * @return {object} a hierarchicalFacet\n */\n getHierarchicalFacetByName: function(hierarchicalFacetName) {\n return find(\n this.hierarchicalFacets,\n function(f) {\n return f.name === hierarchicalFacetName;\n }\n );\n },\n\n /**\n * Get the current breadcrumb for a hierarchical facet, as an array\n * @param {string} facetName Hierarchical facet name\n * @return {array.} the path as an array of string\n */\n getHierarchicalFacetBreadcrumb: function(facetName) {\n if (!this.isHierarchicalFacet(facetName)) {\n return [];\n }\n\n var refinement = this.getHierarchicalRefinement(facetName)[0];\n if (!refinement) return [];\n\n var separator = this._getHierarchicalFacetSeparator(\n this.getHierarchicalFacetByName(facetName)\n );\n var path = refinement.split(separator);\n return path.map(function(part) {\n return part.trim();\n });\n },\n\n toString: function() {\n return JSON.stringify(this, null, 2);\n }\n};\n\n/**\n * Callback used for clearRefinement method\n * @callback SearchParameters.clearCallback\n * @param {OperatorList|FacetList} value the value of the filter\n * @param {string} key the current attribute name\n * @param {string} type `numeric`, `disjunctiveFacet`, `conjunctiveFacet`, `hierarchicalFacet` or `exclude`\n * depending on the type of facet\n * @return {boolean} `true` if the element should be removed. `false` otherwise.\n */\nmodule.exports = SearchParameters;\n","'use strict';\n\nmodule.exports = generateTrees;\n\nvar orderBy = require('../functions/orderBy');\nvar find = require('../functions/find');\nvar prepareHierarchicalFacetSortBy = require('../functions/formatSort');\nvar fv = require('../functions/escapeFacetValue');\nvar escapeFacetValue = fv.escapeFacetValue;\nvar unescapeFacetValue = fv.unescapeFacetValue;\n\nfunction generateTrees(state) {\n return function generate(hierarchicalFacetResult, hierarchicalFacetIndex) {\n var hierarchicalFacet = state.hierarchicalFacets[hierarchicalFacetIndex];\n var hierarchicalFacetRefinement =\n (state.hierarchicalFacetsRefinements[hierarchicalFacet.name] &&\n state.hierarchicalFacetsRefinements[hierarchicalFacet.name][0]) ||\n '';\n var hierarchicalSeparator = state._getHierarchicalFacetSeparator(\n hierarchicalFacet\n );\n var hierarchicalRootPath = state._getHierarchicalRootPath(\n hierarchicalFacet\n );\n var hierarchicalShowParentLevel = state._getHierarchicalShowParentLevel(\n hierarchicalFacet\n );\n var sortBy = prepareHierarchicalFacetSortBy(\n state._getHierarchicalFacetSortBy(hierarchicalFacet)\n );\n\n var rootExhaustive = hierarchicalFacetResult.every(function(facetResult) {\n return facetResult.exhaustive;\n });\n\n var generateTreeFn = generateHierarchicalTree(\n sortBy,\n hierarchicalSeparator,\n hierarchicalRootPath,\n hierarchicalShowParentLevel,\n hierarchicalFacetRefinement\n );\n\n var results = hierarchicalFacetResult;\n\n if (hierarchicalRootPath) {\n results = hierarchicalFacetResult.slice(\n hierarchicalRootPath.split(hierarchicalSeparator).length\n );\n }\n\n return results.reduce(generateTreeFn, {\n name: state.hierarchicalFacets[hierarchicalFacetIndex].name,\n count: null, // root level, no count\n isRefined: true, // root level, always refined\n path: null, // root level, no path\n escapedValue: null,\n exhaustive: rootExhaustive,\n data: null\n });\n };\n}\n\nfunction generateHierarchicalTree(\n sortBy,\n hierarchicalSeparator,\n hierarchicalRootPath,\n hierarchicalShowParentLevel,\n currentRefinement\n) {\n return function generateTree(\n hierarchicalTree,\n hierarchicalFacetResult,\n currentHierarchicalLevel\n ) {\n var parent = hierarchicalTree;\n\n if (currentHierarchicalLevel > 0) {\n var level = 0;\n\n parent = hierarchicalTree;\n\n while (level < currentHierarchicalLevel) {\n /**\n * @type {object[]]} hierarchical data\n */\n var data = parent && Array.isArray(parent.data) ? parent.data : [];\n parent = find(data, function(subtree) {\n return subtree.isRefined;\n });\n level++;\n }\n }\n\n // we found a refined parent, let's add current level data under it\n if (parent) {\n // filter values in case an object has multiple categories:\n // {\n // categories: {\n // level0: ['beers', 'bières'],\n // level1: ['beers > IPA', 'bières > Belges']\n // }\n // }\n //\n // If parent refinement is `beers`, then we do not want to have `bières > Belges`\n // showing up\n\n var picked = Object.keys(hierarchicalFacetResult.data)\n .map(function(facetValue) {\n return [facetValue, hierarchicalFacetResult.data[facetValue]];\n })\n .filter(function(tuple) {\n var facetValue = tuple[0];\n return onlyMatchingTree(\n facetValue,\n parent.path || hierarchicalRootPath,\n currentRefinement,\n hierarchicalSeparator,\n hierarchicalRootPath,\n hierarchicalShowParentLevel\n );\n });\n\n parent.data = orderBy(\n picked.map(function(tuple) {\n var facetValue = tuple[0];\n var facetCount = tuple[1];\n\n return format(\n facetCount,\n facetValue,\n hierarchicalSeparator,\n unescapeFacetValue(currentRefinement),\n hierarchicalFacetResult.exhaustive\n );\n }),\n sortBy[0],\n sortBy[1]\n );\n }\n\n return hierarchicalTree;\n };\n}\n\nfunction onlyMatchingTree(\n facetValue,\n parentPath,\n currentRefinement,\n hierarchicalSeparator,\n hierarchicalRootPath,\n hierarchicalShowParentLevel\n) {\n // we want the facetValue is a child of hierarchicalRootPath\n if (\n hierarchicalRootPath &&\n (facetValue.indexOf(hierarchicalRootPath) !== 0 ||\n hierarchicalRootPath === facetValue)\n ) {\n return false;\n }\n\n // we always want root levels (only when there is no prefix path)\n return (\n (!hierarchicalRootPath &&\n facetValue.indexOf(hierarchicalSeparator) === -1) ||\n // if there is a rootPath, being root level mean 1 level under rootPath\n (hierarchicalRootPath &&\n facetValue.split(hierarchicalSeparator).length -\n hierarchicalRootPath.split(hierarchicalSeparator).length ===\n 1) ||\n // if current refinement is a root level and current facetValue is a root level,\n // keep the facetValue\n (facetValue.indexOf(hierarchicalSeparator) === -1 &&\n currentRefinement.indexOf(hierarchicalSeparator) === -1) ||\n // currentRefinement is a child of the facet value\n currentRefinement.indexOf(facetValue) === 0 ||\n // facetValue is a child of the current parent, add it\n (facetValue.indexOf(parentPath + hierarchicalSeparator) === 0 &&\n (hierarchicalShowParentLevel ||\n facetValue.indexOf(currentRefinement) === 0))\n );\n}\n\nfunction format(\n facetCount,\n facetValue,\n hierarchicalSeparator,\n currentRefinement,\n exhaustive\n) {\n var parts = facetValue.split(hierarchicalSeparator);\n return {\n name: parts[parts.length - 1].trim(),\n path: facetValue,\n escapedValue: escapeFacetValue(facetValue),\n count: facetCount,\n isRefined:\n currentRefinement === facetValue ||\n currentRefinement.indexOf(facetValue + hierarchicalSeparator) === 0,\n exhaustive: exhaustive,\n data: null\n };\n}\n","'use strict';\n\nvar merge = require('../functions/merge');\nvar defaultsPure = require('../functions/defaultsPure');\nvar orderBy = require('../functions/orderBy');\nvar compact = require('../functions/compact');\nvar find = require('../functions/find');\nvar findIndex = require('../functions/findIndex');\nvar formatSort = require('../functions/formatSort');\nvar fv = require('../functions/escapeFacetValue');\nvar escapeFacetValue = fv.escapeFacetValue;\nvar unescapeFacetValue = fv.unescapeFacetValue;\n\nvar generateHierarchicalTree = require('./generate-hierarchical-tree');\n\n/**\n * @typedef SearchResults.Facet\n * @type {object}\n * @property {string} name name of the attribute in the record\n * @property {object} data the faceting data: value, number of entries\n * @property {object} stats undefined unless facet_stats is retrieved from algolia\n */\n\n/**\n * @typedef SearchResults.HierarchicalFacet\n * @type {object}\n * @property {string} name name of the current value given the hierarchical level, trimmed.\n * If root node, you get the facet name\n * @property {number} count number of objects matching this hierarchical value\n * @property {string} path the current hierarchical value full path\n * @property {boolean} isRefined `true` if the current value was refined, `false` otherwise\n * @property {HierarchicalFacet[]} data sub values for the current level\n */\n\n/**\n * @typedef SearchResults.FacetValue\n * @type {object}\n * @property {string} name the facet value itself\n * @property {number} count times this facet appears in the results\n * @property {boolean} isRefined is the facet currently selected\n * @property {boolean} isExcluded is the facet currently excluded (only for conjunctive facets)\n */\n\n/**\n * @typedef Refinement\n * @type {object}\n * @property {string} type the type of filter used:\n * `numeric`, `facet`, `exclude`, `disjunctive`, `hierarchical`\n * @property {string} attributeName name of the attribute used for filtering\n * @property {string} name the value of the filter\n * @property {number} numericValue the value as a number. Only for numeric filters.\n * @property {string} operator the operator used. Only for numeric filters.\n * @property {number} count the number of computed hits for this filter. Only on facets.\n * @property {boolean} exhaustive if the count is exhaustive\n */\n\n/**\n * @param {string[]} attributes\n */\nfunction getIndices(attributes) {\n var indices = {};\n\n attributes.forEach(function(val, idx) {\n indices[val] = idx;\n });\n\n return indices;\n}\n\nfunction assignFacetStats(dest, facetStats, key) {\n if (facetStats && facetStats[key]) {\n dest.stats = facetStats[key];\n }\n}\n\n/**\n * @typedef {Object} HierarchicalFacet\n * @property {string} name\n * @property {string[]} attributes\n */\n\n/**\n * @param {HierarchicalFacet[]} hierarchicalFacets\n * @param {string} hierarchicalAttributeName\n */\nfunction findMatchingHierarchicalFacetFromAttributeName(\n hierarchicalFacets,\n hierarchicalAttributeName\n) {\n return find(hierarchicalFacets, function facetKeyMatchesAttribute(\n hierarchicalFacet\n ) {\n var facetNames = hierarchicalFacet.attributes || [];\n return facetNames.indexOf(hierarchicalAttributeName) > -1;\n });\n}\n\n/*eslint-disable */\n/**\n * Constructor for SearchResults\n * @class\n * @classdesc SearchResults contains the results of a query to Algolia using the\n * {@link AlgoliaSearchHelper}.\n * @param {SearchParameters} state state that led to the response\n * @param {array.} results the results from algolia client\n * @example SearchResults of the first query in\n * the instant search demo\n{\n \"hitsPerPage\": 10,\n \"processingTimeMS\": 2,\n \"facets\": [\n {\n \"name\": \"type\",\n \"data\": {\n \"HardGood\": 6627,\n \"BlackTie\": 550,\n \"Music\": 665,\n \"Software\": 131,\n \"Game\": 456,\n \"Movie\": 1571\n },\n \"exhaustive\": false\n },\n {\n \"exhaustive\": false,\n \"data\": {\n \"Free shipping\": 5507\n },\n \"name\": \"shipping\"\n }\n ],\n \"hits\": [\n {\n \"thumbnailImage\": \"http://img.bbystatic.com/BestBuy_US/images/products/1688/1688832_54x108_s.gif\",\n \"_highlightResult\": {\n \"shortDescription\": {\n \"matchLevel\": \"none\",\n \"value\": \"Safeguard your PC, Mac, Android and iOS devices with comprehensive Internet protection\",\n \"matchedWords\": []\n },\n \"category\": {\n \"matchLevel\": \"none\",\n \"value\": \"Computer Security Software\",\n \"matchedWords\": []\n },\n \"manufacturer\": {\n \"matchedWords\": [],\n \"value\": \"Webroot\",\n \"matchLevel\": \"none\"\n },\n \"name\": {\n \"value\": \"Webroot SecureAnywhere Internet Security (3-Device) (1-Year Subscription) - Mac/Windows\",\n \"matchedWords\": [],\n \"matchLevel\": \"none\"\n }\n },\n \"image\": \"http://img.bbystatic.com/BestBuy_US/images/products/1688/1688832_105x210_sc.jpg\",\n \"shipping\": \"Free shipping\",\n \"bestSellingRank\": 4,\n \"shortDescription\": \"Safeguard your PC, Mac, Android and iOS devices with comprehensive Internet protection\",\n \"url\": \"http://www.bestbuy.com/site/webroot-secureanywhere-internet-security-3-devi…d=1219060687969&skuId=1688832&cmp=RMX&ky=2d3GfEmNIzjA0vkzveHdZEBgpPCyMnLTJ\",\n \"name\": \"Webroot SecureAnywhere Internet Security (3-Device) (1-Year Subscription) - Mac/Windows\",\n \"category\": \"Computer Security Software\",\n \"salePrice_range\": \"1 - 50\",\n \"objectID\": \"1688832\",\n \"type\": \"Software\",\n \"customerReviewCount\": 5980,\n \"salePrice\": 49.99,\n \"manufacturer\": \"Webroot\"\n },\n ....\n ],\n \"nbHits\": 10000,\n \"disjunctiveFacets\": [\n {\n \"exhaustive\": false,\n \"data\": {\n \"5\": 183,\n \"12\": 112,\n \"7\": 149,\n ...\n },\n \"name\": \"customerReviewCount\",\n \"stats\": {\n \"max\": 7461,\n \"avg\": 157.939,\n \"min\": 1\n }\n },\n {\n \"data\": {\n \"Printer Ink\": 142,\n \"Wireless Speakers\": 60,\n \"Point & Shoot Cameras\": 48,\n ...\n },\n \"name\": \"category\",\n \"exhaustive\": false\n },\n {\n \"exhaustive\": false,\n \"data\": {\n \"> 5000\": 2,\n \"1 - 50\": 6524,\n \"501 - 2000\": 566,\n \"201 - 500\": 1501,\n \"101 - 200\": 1360,\n \"2001 - 5000\": 47\n },\n \"name\": \"salePrice_range\"\n },\n {\n \"data\": {\n \"Dynexâ„¢\": 202,\n \"Insigniaâ„¢\": 230,\n \"PNY\": 72,\n ...\n },\n \"name\": \"manufacturer\",\n \"exhaustive\": false\n }\n ],\n \"query\": \"\",\n \"nbPages\": 100,\n \"page\": 0,\n \"index\": \"bestbuy\"\n}\n **/\n/*eslint-enable */\nfunction SearchResults(state, results, options) {\n var mainSubResponse = results[0];\n\n this._rawResults = results;\n\n var self = this;\n\n // https://www.algolia.com/doc/api-reference/api-methods/search/#response\n Object.keys(mainSubResponse).forEach(function(key) {\n self[key] = mainSubResponse[key];\n });\n\n // Make every key of the result options reachable from the instance\n Object.keys(options || {}).forEach(function(key) {\n self[key] = options[key];\n });\n\n /**\n * query used to generate the results\n * @name query\n * @member {string}\n * @memberof SearchResults\n * @instance\n */\n /**\n * The query as parsed by the engine given all the rules.\n * @name parsedQuery\n * @member {string}\n * @memberof SearchResults\n * @instance\n */\n /**\n * all the records that match the search parameters. Each record is\n * augmented with a new attribute `_highlightResult`\n * which is an object keyed by attribute and with the following properties:\n * - `value` : the value of the facet highlighted (html)\n * - `matchLevel`: full, partial or none depending on how the query terms match\n * @name hits\n * @member {object[]}\n * @memberof SearchResults\n * @instance\n */\n /**\n * index where the results come from\n * @name index\n * @member {string}\n * @memberof SearchResults\n * @instance\n */\n /**\n * number of hits per page requested\n * @name hitsPerPage\n * @member {number}\n * @memberof SearchResults\n * @instance\n */\n /**\n * total number of hits of this query on the index\n * @name nbHits\n * @member {number}\n * @memberof SearchResults\n * @instance\n */\n /**\n * total number of pages with respect to the number of hits per page and the total number of hits\n * @name nbPages\n * @member {number}\n * @memberof SearchResults\n * @instance\n */\n /**\n * current page\n * @name page\n * @member {number}\n * @memberof SearchResults\n * @instance\n */\n /**\n * The position if the position was guessed by IP.\n * @name aroundLatLng\n * @member {string}\n * @memberof SearchResults\n * @instance\n * @example \"48.8637,2.3615\",\n */\n /**\n * The radius computed by Algolia.\n * @name automaticRadius\n * @member {string}\n * @memberof SearchResults\n * @instance\n * @example \"126792922\",\n */\n /**\n * String identifying the server used to serve this request.\n *\n * getRankingInfo needs to be set to `true` for this to be returned\n *\n * @name serverUsed\n * @member {string}\n * @memberof SearchResults\n * @instance\n * @example \"c7-use-2.algolia.net\",\n */\n /**\n * Boolean that indicates if the computation of the counts did time out.\n * @deprecated\n * @name timeoutCounts\n * @member {boolean}\n * @memberof SearchResults\n * @instance\n */\n /**\n * Boolean that indicates if the computation of the hits did time out.\n * @deprecated\n * @name timeoutHits\n * @member {boolean}\n * @memberof SearchResults\n * @instance\n */\n /**\n * True if the counts of the facets is exhaustive\n * @name exhaustiveFacetsCount\n * @member {boolean}\n * @memberof SearchResults\n * @instance\n */\n /**\n * True if the number of hits is exhaustive\n * @name exhaustiveNbHits\n * @member {boolean}\n * @memberof SearchResults\n * @instance\n */\n /**\n * Contains the userData if they are set by a [query rule](https://www.algolia.com/doc/guides/query-rules/query-rules-overview/).\n * @name userData\n * @member {object[]}\n * @memberof SearchResults\n * @instance\n */\n /**\n * queryID is the unique identifier of the query used to generate the current search results.\n * This value is only available if the `clickAnalytics` search parameter is set to `true`.\n * @name queryID\n * @member {string}\n * @memberof SearchResults\n * @instance\n */\n\n /**\n * sum of the processing time of all the queries\n * @member {number}\n */\n this.processingTimeMS = results.reduce(function(sum, result) {\n return result.processingTimeMS === undefined\n ? sum\n : sum + result.processingTimeMS;\n }, 0);\n\n /**\n * disjunctive facets results\n * @member {SearchResults.Facet[]}\n */\n this.disjunctiveFacets = [];\n /**\n * disjunctive facets results\n * @member {SearchResults.HierarchicalFacet[]}\n */\n this.hierarchicalFacets = state.hierarchicalFacets.map(function initFutureTree() {\n return [];\n });\n /**\n * other facets results\n * @member {SearchResults.Facet[]}\n */\n this.facets = [];\n\n var disjunctiveFacets = state.getRefinedDisjunctiveFacets();\n\n var facetsIndices = getIndices(state.facets);\n var disjunctiveFacetsIndices = getIndices(state.disjunctiveFacets);\n var nextDisjunctiveResult = 1;\n\n // Since we send request only for disjunctive facets that have been refined,\n // we get the facets information from the first, general, response.\n\n var mainFacets = mainSubResponse.facets || {};\n\n Object.keys(mainFacets).forEach(function(facetKey) {\n var facetValueObject = mainFacets[facetKey];\n\n var hierarchicalFacet = findMatchingHierarchicalFacetFromAttributeName(\n state.hierarchicalFacets,\n facetKey\n );\n\n if (hierarchicalFacet) {\n // Place the hierarchicalFacet data at the correct index depending on\n // the attributes order that was defined at the helper initialization\n var facetIndex = hierarchicalFacet.attributes.indexOf(facetKey);\n var idxAttributeName = findIndex(state.hierarchicalFacets, function(f) {\n return f.name === hierarchicalFacet.name;\n });\n self.hierarchicalFacets[idxAttributeName][facetIndex] = {\n attribute: facetKey,\n data: facetValueObject,\n exhaustive: mainSubResponse.exhaustiveFacetsCount\n };\n } else {\n var isFacetDisjunctive = state.disjunctiveFacets.indexOf(facetKey) !== -1;\n var isFacetConjunctive = state.facets.indexOf(facetKey) !== -1;\n var position;\n\n if (isFacetDisjunctive) {\n position = disjunctiveFacetsIndices[facetKey];\n self.disjunctiveFacets[position] = {\n name: facetKey,\n data: facetValueObject,\n exhaustive: mainSubResponse.exhaustiveFacetsCount\n };\n assignFacetStats(self.disjunctiveFacets[position], mainSubResponse.facets_stats, facetKey);\n }\n if (isFacetConjunctive) {\n position = facetsIndices[facetKey];\n self.facets[position] = {\n name: facetKey,\n data: facetValueObject,\n exhaustive: mainSubResponse.exhaustiveFacetsCount\n };\n assignFacetStats(self.facets[position], mainSubResponse.facets_stats, facetKey);\n }\n }\n });\n\n // Make sure we do not keep holes within the hierarchical facets\n this.hierarchicalFacets = compact(this.hierarchicalFacets);\n\n // aggregate the refined disjunctive facets\n disjunctiveFacets.forEach(function(disjunctiveFacet) {\n var result = results[nextDisjunctiveResult];\n var facets = result && result.facets ? result.facets : {};\n var hierarchicalFacet = state.getHierarchicalFacetByName(disjunctiveFacet);\n\n // There should be only item in facets.\n Object.keys(facets).forEach(function(dfacet) {\n var facetResults = facets[dfacet];\n\n var position;\n\n if (hierarchicalFacet) {\n position = findIndex(state.hierarchicalFacets, function(f) {\n return f.name === hierarchicalFacet.name;\n });\n var attributeIndex = findIndex(self.hierarchicalFacets[position], function(f) {\n return f.attribute === dfacet;\n });\n\n // previous refinements and no results so not able to find it\n if (attributeIndex === -1) {\n return;\n }\n\n self.hierarchicalFacets[position][attributeIndex].data = merge(\n {},\n self.hierarchicalFacets[position][attributeIndex].data,\n facetResults\n );\n } else {\n position = disjunctiveFacetsIndices[dfacet];\n\n var dataFromMainRequest = mainSubResponse.facets && mainSubResponse.facets[dfacet] || {};\n\n self.disjunctiveFacets[position] = {\n name: dfacet,\n data: defaultsPure({}, facetResults, dataFromMainRequest),\n exhaustive: result.exhaustiveFacetsCount\n };\n assignFacetStats(self.disjunctiveFacets[position], result.facets_stats, dfacet);\n\n if (state.disjunctiveFacetsRefinements[dfacet]) {\n state.disjunctiveFacetsRefinements[dfacet].forEach(function(refinementValue) {\n // add the disjunctive refinements if it is no more retrieved\n if (!self.disjunctiveFacets[position].data[refinementValue] &&\n state.disjunctiveFacetsRefinements[dfacet].indexOf(unescapeFacetValue(refinementValue)) > -1) {\n self.disjunctiveFacets[position].data[refinementValue] = 0;\n }\n });\n }\n }\n });\n nextDisjunctiveResult++;\n });\n\n // if we have some parent level values for hierarchical facets, merge them\n state.getRefinedHierarchicalFacets().forEach(function(refinedFacet) {\n var hierarchicalFacet = state.getHierarchicalFacetByName(refinedFacet);\n var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet);\n\n var currentRefinement = state.getHierarchicalRefinement(refinedFacet);\n // if we are already at a root refinement (or no refinement at all), there is no\n // root level values request\n if (currentRefinement.length === 0 || currentRefinement[0].split(separator).length < 2) {\n return;\n }\n\n results.slice(nextDisjunctiveResult).forEach(function(result) {\n var facets = result && result.facets\n ? result.facets\n : {};\n\n Object.keys(facets).forEach(function(dfacet) {\n var facetResults = facets[dfacet];\n var position = findIndex(state.hierarchicalFacets, function(f) {\n return f.name === hierarchicalFacet.name;\n });\n var attributeIndex = findIndex(self.hierarchicalFacets[position], function(f) {\n return f.attribute === dfacet;\n });\n\n // previous refinements and no results so not able to find it\n if (attributeIndex === -1) {\n return;\n }\n\n // when we always get root levels, if the hits refinement is `beers > IPA` (count: 5),\n // then the disjunctive values will be `beers` (count: 100),\n // but we do not want to display\n // | beers (100)\n // > IPA (5)\n // We want\n // | beers (5)\n // > IPA (5)\n var defaultData = {};\n\n if (currentRefinement.length > 0) {\n var root = currentRefinement[0].split(separator)[0];\n defaultData[root] = self.hierarchicalFacets[position][attributeIndex].data[root];\n }\n\n self.hierarchicalFacets[position][attributeIndex].data = defaultsPure(\n defaultData,\n facetResults,\n self.hierarchicalFacets[position][attributeIndex].data\n );\n });\n\n nextDisjunctiveResult++;\n });\n });\n\n // add the excludes\n Object.keys(state.facetsExcludes).forEach(function(facetName) {\n var excludes = state.facetsExcludes[facetName];\n var position = facetsIndices[facetName];\n\n self.facets[position] = {\n name: facetName,\n data: mainSubResponse.facets[facetName],\n exhaustive: mainSubResponse.exhaustiveFacetsCount\n };\n excludes.forEach(function(facetValue) {\n self.facets[position] = self.facets[position] || {name: facetName};\n self.facets[position].data = self.facets[position].data || {};\n self.facets[position].data[facetValue] = 0;\n });\n });\n\n /**\n * @type {Array}\n */\n this.hierarchicalFacets = this.hierarchicalFacets.map(generateHierarchicalTree(state));\n\n /**\n * @type {Array}\n */\n this.facets = compact(this.facets);\n /**\n * @type {Array}\n */\n this.disjunctiveFacets = compact(this.disjunctiveFacets);\n\n this._state = state;\n}\n\n/**\n * Get a facet object with its name\n * @deprecated\n * @param {string} name name of the faceted attribute\n * @return {SearchResults.Facet} the facet object\n */\nSearchResults.prototype.getFacetByName = function(name) {\n function predicate(facet) {\n return facet.name === name;\n }\n\n return find(this.facets, predicate) ||\n find(this.disjunctiveFacets, predicate) ||\n find(this.hierarchicalFacets, predicate);\n};\n\n/**\n * Get the facet values of a specified attribute from a SearchResults object.\n * @private\n * @param {SearchResults} results the search results to search in\n * @param {string} attribute name of the faceted attribute to search for\n * @return {array|object} facet values. For the hierarchical facets it is an object.\n */\nfunction extractNormalizedFacetValues(results, attribute) {\n function predicate(facet) {\n return facet.name === attribute;\n }\n\n if (results._state.isConjunctiveFacet(attribute)) {\n var facet = find(results.facets, predicate);\n if (!facet) return [];\n\n return Object.keys(facet.data).map(function(name) {\n var value = escapeFacetValue(name);\n return {\n name: name,\n escapedValue: value,\n count: facet.data[name],\n isRefined: results._state.isFacetRefined(attribute, value),\n isExcluded: results._state.isExcludeRefined(attribute, name)\n };\n });\n } else if (results._state.isDisjunctiveFacet(attribute)) {\n var disjunctiveFacet = find(results.disjunctiveFacets, predicate);\n if (!disjunctiveFacet) return [];\n\n return Object.keys(disjunctiveFacet.data).map(function(name) {\n var value = escapeFacetValue(name);\n return {\n name: name,\n escapedValue: value,\n count: disjunctiveFacet.data[name],\n isRefined: results._state.isDisjunctiveFacetRefined(attribute, value)\n };\n });\n } else if (results._state.isHierarchicalFacet(attribute)) {\n var hierarchicalFacetValues = find(results.hierarchicalFacets, predicate);\n if (!hierarchicalFacetValues) return hierarchicalFacetValues;\n\n var hierarchicalFacet = results._state.getHierarchicalFacetByName(attribute);\n var currentRefinementSplit = unescapeFacetValue(\n results._state.getHierarchicalRefinement(attribute)[0] || ''\n ).split(results._state._getHierarchicalFacetSeparator(hierarchicalFacet));\n currentRefinementSplit.unshift(attribute);\n\n setIsRefined(hierarchicalFacetValues, currentRefinementSplit, 0);\n\n return hierarchicalFacetValues;\n }\n}\n\n/**\n * Set the isRefined of a hierarchical facet result based on the current state.\n * @param {SearchResults.HierarchicalFacet} item Hierarchical facet to fix\n * @param {string[]} currentRefinementSplit array of parts of the current hierarchical refinement\n * @param {number} depth recursion depth in the currentRefinement\n */\nfunction setIsRefined(item, currentRefinement, depth) {\n item.isRefined = item.name === currentRefinement[depth];\n if (item.data) {\n item.data.forEach(function(child) {\n setIsRefined(child, currentRefinement, depth + 1);\n });\n }\n}\n\n/**\n * Sort nodes of a hierarchical or disjunctive facet results\n * @private\n * @param {function} sortFn\n * @param {HierarchicalFacet|Array} node node upon which we want to apply the sort\n * @param {string[]} names attribute names\n * @param {number} [level=0] current index in the names array\n */\nfunction recSort(sortFn, node, names, level) {\n level = level || 0;\n\n if (Array.isArray(node)) {\n return sortFn(node, names[level]);\n }\n\n if (!node.data || node.data.length === 0) {\n return node;\n }\n\n var children = node.data.map(function(childNode) {\n return recSort(sortFn, childNode, names, level + 1);\n });\n var sortedChildren = sortFn(children, names[level]);\n var newNode = defaultsPure({data: sortedChildren}, node);\n return newNode;\n}\n\nSearchResults.DEFAULT_SORT = ['isRefined:desc', 'count:desc', 'name:asc'];\n\nfunction vanillaSortFn(order, data) {\n return data.sort(order);\n}\n\n/**\n * @typedef FacetOrdering\n * @type {Object}\n * @property {string[]} [order]\n * @property {'count' | 'alpha' | 'hidden'} [sortRemainingBy]\n */\n\n/**\n * Sorts facet arrays via their facet ordering\n * @param {Array} facetValues the values\n * @param {FacetOrdering} facetOrdering the ordering\n * @returns {Array}\n */\nfunction sortViaFacetOrdering(facetValues, facetOrdering) {\n var orderedFacets = [];\n var remainingFacets = [];\n\n var order = facetOrdering.order || [];\n /**\n * an object with the keys being the values in order, the values their index:\n * ['one', 'two'] -> { one: 0, two: 1 }\n */\n var reverseOrder = order.reduce(function(acc, name, i) {\n acc[name] = i;\n return acc;\n }, {});\n\n facetValues.forEach(function(item) {\n // hierarchical facets get sorted using their raw name\n var name = item.path || item.name;\n if (reverseOrder[name] !== undefined) {\n orderedFacets[reverseOrder[name]] = item;\n } else {\n remainingFacets.push(item);\n }\n });\n\n orderedFacets = orderedFacets.filter(function(facet) {\n return facet;\n });\n\n var sortRemainingBy = facetOrdering.sortRemainingBy;\n var ordering;\n if (sortRemainingBy === 'hidden') {\n return orderedFacets;\n } else if (sortRemainingBy === 'alpha') {\n ordering = [['path', 'name'], ['asc', 'asc']];\n } else {\n ordering = [['count'], ['desc']];\n }\n\n return orderedFacets.concat(\n orderBy(remainingFacets, ordering[0], ordering[1])\n );\n}\n\n/**\n * @param {SearchResults} results the search results class\n * @param {string} attribute the attribute to retrieve ordering of\n * @returns {FacetOrdering=}\n */\nfunction getFacetOrdering(results, attribute) {\n return (\n results.renderingContent &&\n results.renderingContent.facetOrdering &&\n results.renderingContent.facetOrdering.values &&\n results.renderingContent.facetOrdering.values[attribute]\n );\n}\n\n/**\n * Get a the list of values for a given facet attribute. Those values are sorted\n * refinement first, descending count (bigger value on top), and name ascending\n * (alphabetical order). The sort formula can overridden using either string based\n * predicates or a function.\n *\n * This method will return all the values returned by the Algolia engine plus all\n * the values already refined. This means that it can happen that the\n * `maxValuesPerFacet` [configuration](https://www.algolia.com/doc/rest-api/search#param-maxValuesPerFacet)\n * might not be respected if you have facet values that are already refined.\n * @param {string} attribute attribute name\n * @param {object} opts configuration options.\n * @param {boolean} [opts.facetOrdering]\n * Force the use of facetOrdering from the result if a sortBy is present. If\n * sortBy isn't present, facetOrdering will be used automatically.\n * @param {Array. | function} opts.sortBy\n * When using strings, it consists of\n * the name of the [FacetValue](#SearchResults.FacetValue) or the\n * [HierarchicalFacet](#SearchResults.HierarchicalFacet) attributes with the\n * order (`asc` or `desc`). For example to order the value by count, the\n * argument would be `['count:asc']`.\n *\n * If only the attribute name is specified, the ordering defaults to the one\n * specified in the default value for this attribute.\n *\n * When not specified, the order is\n * ascending. This parameter can also be a function which takes two facet\n * values and should return a number, 0 if equal, 1 if the first argument is\n * bigger or -1 otherwise.\n *\n * The default value for this attribute `['isRefined:desc', 'count:desc', 'name:asc']`\n * @return {FacetValue[]|HierarchicalFacet|undefined} depending on the type of facet of\n * the attribute requested (hierarchical, disjunctive or conjunctive)\n * @example\n * helper.on('result', function(event){\n * //get values ordered only by name ascending using the string predicate\n * event.results.getFacetValues('city', {sortBy: ['name:asc']});\n * //get values ordered only by count ascending using a function\n * event.results.getFacetValues('city', {\n * // this is equivalent to ['count:asc']\n * sortBy: function(a, b) {\n * if (a.count === b.count) return 0;\n * if (a.count > b.count) return 1;\n * if (b.count > a.count) return -1;\n * }\n * });\n * });\n */\nSearchResults.prototype.getFacetValues = function(attribute, opts) {\n var facetValues = extractNormalizedFacetValues(this, attribute);\n if (!facetValues) {\n return undefined;\n }\n\n var options = defaultsPure({}, opts, {\n sortBy: SearchResults.DEFAULT_SORT,\n // if no sortBy is given, attempt to sort based on facetOrdering\n // if it is given, we still allow to sort via facet ordering first\n facetOrdering: !(opts && opts.sortBy)\n });\n\n var results = this;\n var attributes;\n if (Array.isArray(facetValues)) {\n attributes = [attribute];\n } else {\n var config = results._state.getHierarchicalFacetByName(facetValues.name);\n attributes = config.attributes;\n }\n\n return recSort(function(data, facetName) {\n if (options.facetOrdering) {\n var facetOrdering = getFacetOrdering(results, facetName);\n if (Boolean(facetOrdering)) {\n return sortViaFacetOrdering(data, facetOrdering);\n }\n }\n\n if (Array.isArray(options.sortBy)) {\n var order = formatSort(options.sortBy, SearchResults.DEFAULT_SORT);\n return orderBy(data, order[0], order[1]);\n } else if (typeof options.sortBy === 'function') {\n return vanillaSortFn(options.sortBy, data);\n }\n throw new Error(\n 'options.sortBy is optional but if defined it must be ' +\n 'either an array of string (predicates) or a sorting function'\n );\n }, facetValues, attributes);\n};\n\n/**\n * Returns the facet stats if attribute is defined and the facet contains some.\n * Otherwise returns undefined.\n * @param {string} attribute name of the faceted attribute\n * @return {object} The stats of the facet\n */\nSearchResults.prototype.getFacetStats = function(attribute) {\n if (this._state.isConjunctiveFacet(attribute)) {\n return getFacetStatsIfAvailable(this.facets, attribute);\n } else if (this._state.isDisjunctiveFacet(attribute)) {\n return getFacetStatsIfAvailable(this.disjunctiveFacets, attribute);\n }\n\n return undefined;\n};\n\n/**\n * @typedef {Object} FacetListItem\n * @property {string} name\n */\n\n/**\n * @param {FacetListItem[]} facetList (has more items, but enough for here)\n * @param {string} facetName\n */\nfunction getFacetStatsIfAvailable(facetList, facetName) {\n var data = find(facetList, function(facet) {\n return facet.name === facetName;\n });\n return data && data.stats;\n}\n\n/**\n * Returns all refinements for all filters + tags. It also provides\n * additional information: count and exhaustiveness for each filter.\n *\n * See the [refinement type](#Refinement) for an exhaustive view of the available\n * data.\n *\n * Note that for a numeric refinement, results are grouped per operator, this\n * means that it will return responses for operators which are empty.\n *\n * @return {Array.} all the refinements\n */\nSearchResults.prototype.getRefinements = function() {\n var state = this._state;\n var results = this;\n var res = [];\n\n Object.keys(state.facetsRefinements).forEach(function(attributeName) {\n state.facetsRefinements[attributeName].forEach(function(name) {\n res.push(getRefinement(state, 'facet', attributeName, name, results.facets));\n });\n });\n\n Object.keys(state.facetsExcludes).forEach(function(attributeName) {\n state.facetsExcludes[attributeName].forEach(function(name) {\n res.push(getRefinement(state, 'exclude', attributeName, name, results.facets));\n });\n });\n\n Object.keys(state.disjunctiveFacetsRefinements).forEach(function(attributeName) {\n state.disjunctiveFacetsRefinements[attributeName].forEach(function(name) {\n res.push(getRefinement(state, 'disjunctive', attributeName, name, results.disjunctiveFacets));\n });\n });\n\n Object.keys(state.hierarchicalFacetsRefinements).forEach(function(attributeName) {\n state.hierarchicalFacetsRefinements[attributeName].forEach(function(name) {\n res.push(getHierarchicalRefinement(state, attributeName, name, results.hierarchicalFacets));\n });\n });\n\n\n Object.keys(state.numericRefinements).forEach(function(attributeName) {\n var operators = state.numericRefinements[attributeName];\n Object.keys(operators).forEach(function(operator) {\n operators[operator].forEach(function(value) {\n res.push({\n type: 'numeric',\n attributeName: attributeName,\n name: value,\n numericValue: value,\n operator: operator\n });\n });\n });\n });\n\n state.tagRefinements.forEach(function(name) {\n res.push({type: 'tag', attributeName: '_tags', name: name});\n });\n\n return res;\n};\n\n/**\n * @typedef {Object} Facet\n * @property {string} name\n * @property {Object} data\n * @property {boolean} exhaustive\n */\n\n/**\n * @param {*} state\n * @param {*} type\n * @param {string} attributeName\n * @param {*} name\n * @param {Facet[]} resultsFacets\n */\nfunction getRefinement(state, type, attributeName, name, resultsFacets) {\n var facet = find(resultsFacets, function(f) {\n return f.name === attributeName;\n });\n var count = facet && facet.data && facet.data[name] ? facet.data[name] : 0;\n var exhaustive = (facet && facet.exhaustive) || false;\n\n return {\n type: type,\n attributeName: attributeName,\n name: name,\n count: count,\n exhaustive: exhaustive\n };\n}\n\n/**\n * @param {*} state\n * @param {string} attributeName\n * @param {*} name\n * @param {Facet[]} resultsFacets\n */\nfunction getHierarchicalRefinement(state, attributeName, name, resultsFacets) {\n var facetDeclaration = state.getHierarchicalFacetByName(attributeName);\n var separator = state._getHierarchicalFacetSeparator(facetDeclaration);\n var split = name.split(separator);\n var rootFacet = find(resultsFacets, function(facet) {\n return facet.name === attributeName;\n });\n\n var facet = split.reduce(function(intermediateFacet, part) {\n var newFacet =\n intermediateFacet && find(intermediateFacet.data, function(f) {\n return f.name === part;\n });\n return newFacet !== undefined ? newFacet : intermediateFacet;\n }, rootFacet);\n\n var count = (facet && facet.count) || 0;\n var exhaustive = (facet && facet.exhaustive) || false;\n var path = (facet && facet.path) || '';\n\n return {\n type: 'hierarchical',\n attributeName: attributeName,\n name: path,\n count: count,\n exhaustive: exhaustive\n };\n}\n\nmodule.exports = SearchResults;\n","'use strict';\n\nvar SearchParameters = require('./SearchParameters');\nvar SearchResults = require('./SearchResults');\nvar DerivedHelper = require('./DerivedHelper');\nvar requestBuilder = require('./requestBuilder');\n\nvar EventEmitter = require('@algolia/events');\nvar inherits = require('./functions/inherits');\nvar objectHasKeys = require('./functions/objectHasKeys');\nvar omit = require('./functions/omit');\nvar merge = require('./functions/merge');\n\nvar version = require('./version');\nvar escapeFacetValue = require('./functions/escapeFacetValue').escapeFacetValue;\n\n/**\n * Event triggered when a parameter is set or updated\n * @event AlgoliaSearchHelper#event:change\n * @property {object} event\n * @property {SearchParameters} event.state the current parameters with the latest changes applied\n * @property {SearchResults} event.results the previous results received from Algolia. `null` before the first request\n * @example\n * helper.on('change', function(event) {\n * console.log('The parameters have changed');\n * });\n */\n\n/**\n * Event triggered when a main search is sent to Algolia\n * @event AlgoliaSearchHelper#event:search\n * @property {object} event\n * @property {SearchParameters} event.state the parameters used for this search\n * @property {SearchResults} event.results the results from the previous search. `null` if it is the first search.\n * @example\n * helper.on('search', function(event) {\n * console.log('Search sent');\n * });\n */\n\n/**\n * Event triggered when a search using `searchForFacetValues` is sent to Algolia\n * @event AlgoliaSearchHelper#event:searchForFacetValues\n * @property {object} event\n * @property {SearchParameters} event.state the parameters used for this search it is the first search.\n * @property {string} event.facet the facet searched into\n * @property {string} event.query the query used to search in the facets\n * @example\n * helper.on('searchForFacetValues', function(event) {\n * console.log('searchForFacetValues sent');\n * });\n */\n\n/**\n * Event triggered when a search using `searchOnce` is sent to Algolia\n * @event AlgoliaSearchHelper#event:searchOnce\n * @property {object} event\n * @property {SearchParameters} event.state the parameters used for this search it is the first search.\n * @example\n * helper.on('searchOnce', function(event) {\n * console.log('searchOnce sent');\n * });\n */\n\n/**\n * Event triggered when the results are retrieved from Algolia\n * @event AlgoliaSearchHelper#event:result\n * @property {object} event\n * @property {SearchResults} event.results the results received from Algolia\n * @property {SearchParameters} event.state the parameters used to query Algolia. Those might be different from the one in the helper instance (for example if the network is unreliable).\n * @example\n * helper.on('result', function(event) {\n * console.log('Search results received');\n * });\n */\n\n/**\n * Event triggered when Algolia sends back an error. For example, if an unknown parameter is\n * used, the error can be caught using this event.\n * @event AlgoliaSearchHelper#event:error\n * @property {object} event\n * @property {Error} event.error the error returned by the Algolia.\n * @example\n * helper.on('error', function(event) {\n * console.log('Houston we got a problem.');\n * });\n */\n\n/**\n * Event triggered when the queue of queries have been depleted (with any result or outdated queries)\n * @event AlgoliaSearchHelper#event:searchQueueEmpty\n * @example\n * helper.on('searchQueueEmpty', function() {\n * console.log('No more search pending');\n * // This is received before the result event if we're not expecting new results\n * });\n *\n * helper.search();\n */\n\n/**\n * Initialize a new AlgoliaSearchHelper\n * @class\n * @classdesc The AlgoliaSearchHelper is a class that ease the management of the\n * search. It provides an event based interface for search callbacks:\n * - change: when the internal search state is changed.\n * This event contains a {@link SearchParameters} object and the\n * {@link SearchResults} of the last result if any.\n * - search: when a search is triggered using the `search()` method.\n * - result: when the response is retrieved from Algolia and is processed.\n * This event contains a {@link SearchResults} object and the\n * {@link SearchParameters} corresponding to this answer.\n * - error: when the response is an error. This event contains the error returned by the server.\n * @param {AlgoliaSearch} client an AlgoliaSearch client\n * @param {string} index the index name to query\n * @param {SearchParameters | object} options an object defining the initial\n * config of the search. It doesn't have to be a {SearchParameters},\n * just an object containing the properties you need from it.\n */\nfunction AlgoliaSearchHelper(client, index, options) {\n if (typeof client.addAlgoliaAgent === 'function') {\n client.addAlgoliaAgent('JS Helper (' + version + ')');\n }\n\n this.setClient(client);\n var opts = options || {};\n opts.index = index;\n this.state = SearchParameters.make(opts);\n this.lastResults = null;\n this._queryId = 0;\n this._lastQueryIdReceived = -1;\n this.derivedHelpers = [];\n this._currentNbQueries = 0;\n}\n\ninherits(AlgoliaSearchHelper, EventEmitter);\n\n/**\n * Start the search with the parameters set in the state. When the\n * method is called, it triggers a `search` event. The results will\n * be available through the `result` event. If an error occurs, an\n * `error` will be fired instead.\n * @return {AlgoliaSearchHelper}\n * @fires search\n * @fires result\n * @fires error\n * @chainable\n */\nAlgoliaSearchHelper.prototype.search = function() {\n this._search({onlyWithDerivedHelpers: false});\n return this;\n};\n\nAlgoliaSearchHelper.prototype.searchOnlyWithDerivedHelpers = function() {\n this._search({onlyWithDerivedHelpers: true});\n return this;\n};\n\n/**\n * Gets the search query parameters that would be sent to the Algolia Client\n * for the hits\n * @return {object} Query Parameters\n */\nAlgoliaSearchHelper.prototype.getQuery = function() {\n var state = this.state;\n return requestBuilder._getHitsSearchParams(state);\n};\n\n/**\n * Start a search using a modified version of the current state. This method does\n * not trigger the helper lifecycle and does not modify the state kept internally\n * by the helper. This second aspect means that the next search call will be the\n * same as a search call before calling searchOnce.\n * @param {object} options can contain all the parameters that can be set to SearchParameters\n * plus the index\n * @param {function} [callback] optional callback executed when the response from the\n * server is back.\n * @return {promise|undefined} if a callback is passed the method returns undefined\n * otherwise it returns a promise containing an object with two keys :\n * - content with a SearchResults\n * - state with the state used for the query as a SearchParameters\n * @example\n * // Changing the number of records returned per page to 1\n * // This example uses the callback API\n * var state = helper.searchOnce({hitsPerPage: 1},\n * function(error, content, state) {\n * // if an error occurred it will be passed in error, otherwise its value is null\n * // content contains the results formatted as a SearchResults\n * // state is the instance of SearchParameters used for this search\n * });\n * @example\n * // Changing the number of records returned per page to 1\n * // This example uses the promise API\n * var state1 = helper.searchOnce({hitsPerPage: 1})\n * .then(promiseHandler);\n *\n * function promiseHandler(res) {\n * // res contains\n * // {\n * // content : SearchResults\n * // state : SearchParameters (the one used for this specific search)\n * // }\n * }\n */\nAlgoliaSearchHelper.prototype.searchOnce = function(options, cb) {\n var tempState = !options ? this.state : this.state.setQueryParameters(options);\n var queries = requestBuilder._getQueries(tempState.index, tempState);\n var self = this;\n\n this._currentNbQueries++;\n\n this.emit('searchOnce', {\n state: tempState\n });\n\n if (cb) {\n this.client\n .search(queries)\n .then(function(content) {\n self._currentNbQueries--;\n if (self._currentNbQueries === 0) {\n self.emit('searchQueueEmpty');\n }\n\n cb(null, new SearchResults(tempState, content.results), tempState);\n })\n .catch(function(err) {\n self._currentNbQueries--;\n if (self._currentNbQueries === 0) {\n self.emit('searchQueueEmpty');\n }\n\n cb(err, null, tempState);\n });\n\n return undefined;\n }\n\n return this.client.search(queries).then(function(content) {\n self._currentNbQueries--;\n if (self._currentNbQueries === 0) self.emit('searchQueueEmpty');\n return {\n content: new SearchResults(tempState, content.results),\n state: tempState,\n _originalResponse: content\n };\n }, function(e) {\n self._currentNbQueries--;\n if (self._currentNbQueries === 0) self.emit('searchQueueEmpty');\n throw e;\n });\n};\n\n /**\n * Start the search for answers with the parameters set in the state.\n * This method returns a promise.\n * @param {Object} options - the options for answers API call\n * @param {string[]} options.attributesForPrediction - Attributes to use for predictions. If empty, `searchableAttributes` is used instead.\n * @param {string[]} options.queryLanguages - The languages in the query. Currently only supports ['en'].\n * @param {number} options.nbHits - Maximum number of answers to retrieve from the Answers Engine. Cannot be greater than 1000.\n *\n * @return {promise} the answer results\n * @deprecated answers is deprecated and will be replaced with new initiatives\n */\nAlgoliaSearchHelper.prototype.findAnswers = function(options) {\n console.warn('[algoliasearch-helper] answers is no longer supported');\n var state = this.state;\n var derivedHelper = this.derivedHelpers[0];\n if (!derivedHelper) {\n return Promise.resolve([]);\n }\n var derivedState = derivedHelper.getModifiedState(state);\n var data = merge(\n {\n attributesForPrediction: options.attributesForPrediction,\n nbHits: options.nbHits\n },\n {\n params: omit(requestBuilder._getHitsSearchParams(derivedState), [\n 'attributesToSnippet',\n 'hitsPerPage',\n 'restrictSearchableAttributes',\n 'snippetEllipsisText' // FIXME remove this line once the engine is fixed.\n ])\n }\n );\n\n var errorMessage = 'search for answers was called, but this client does not have a function client.initIndex(index).findAnswers';\n if (typeof this.client.initIndex !== 'function') {\n throw new Error(errorMessage);\n }\n var index = this.client.initIndex(derivedState.index);\n if (typeof index.findAnswers !== 'function') {\n throw new Error(errorMessage);\n }\n return index.findAnswers(derivedState.query, options.queryLanguages, data);\n};\n\n/**\n * Structure of each result when using\n * [`searchForFacetValues()`](reference.html#AlgoliaSearchHelper#searchForFacetValues)\n * @typedef FacetSearchHit\n * @type {object}\n * @property {string} value the facet value\n * @property {string} highlighted the facet value highlighted with the query string\n * @property {number} count number of occurrence of this facet value\n * @property {boolean} isRefined true if the value is already refined\n */\n\n/**\n * Structure of the data resolved by the\n * [`searchForFacetValues()`](reference.html#AlgoliaSearchHelper#searchForFacetValues)\n * promise.\n * @typedef FacetSearchResult\n * @type {object}\n * @property {FacetSearchHit} facetHits the results for this search for facet values\n * @property {number} processingTimeMS time taken by the query inside the engine\n */\n\n/**\n * Search for facet values based on an query and the name of a faceted attribute. This\n * triggers a search and will return a promise. On top of using the query, it also sends\n * the parameters from the state so that the search is narrowed down to only the possible values.\n *\n * See the description of [FacetSearchResult](reference.html#FacetSearchResult)\n * @param {string} facet the name of the faceted attribute\n * @param {string} query the string query for the search\n * @param {number} [maxFacetHits] the maximum number values returned. Should be > 0 and <= 100\n * @param {object} [userState] the set of custom parameters to use on top of the current state. Setting a property to `undefined` removes\n * it in the generated query.\n * @return {promise.} the results of the search\n */\nAlgoliaSearchHelper.prototype.searchForFacetValues = function(facet, query, maxFacetHits, userState) {\n var clientHasSFFV = typeof this.client.searchForFacetValues === 'function';\n var clientHasInitIndex = typeof this.client.initIndex === 'function';\n if (\n !clientHasSFFV &&\n !clientHasInitIndex &&\n typeof this.client.search !== 'function'\n ) {\n throw new Error(\n 'search for facet values (searchable) was called, but this client does not have a function client.searchForFacetValues or client.initIndex(index).searchForFacetValues'\n );\n }\n\n var state = this.state.setQueryParameters(userState || {});\n var isDisjunctive = state.isDisjunctiveFacet(facet);\n var algoliaQuery = requestBuilder.getSearchForFacetQuery(facet, query, maxFacetHits, state);\n\n this._currentNbQueries++;\n var self = this;\n var searchForFacetValuesPromise;\n // newer algoliasearch ^3.27.1 - ~4.0.0\n if (clientHasSFFV) {\n searchForFacetValuesPromise = this.client.searchForFacetValues([\n {indexName: state.index, params: algoliaQuery}\n ]);\n // algoliasearch < 3.27.1\n } else if (clientHasInitIndex) {\n searchForFacetValuesPromise = this.client\n .initIndex(state.index)\n .searchForFacetValues(algoliaQuery);\n // algoliasearch ~5.0.0\n } else {\n // @MAJOR only use client.search\n delete algoliaQuery.facetName;\n searchForFacetValuesPromise = this.client\n .search([\n {\n type: 'facet',\n facet: facet,\n indexName: state.index,\n params: algoliaQuery\n }\n ])\n .then(function processResponse(response) {\n return response.results[0];\n });\n }\n\n this.emit('searchForFacetValues', {\n state: state,\n facet: facet,\n query: query\n });\n\n return searchForFacetValuesPromise.then(function addIsRefined(content) {\n self._currentNbQueries--;\n if (self._currentNbQueries === 0) self.emit('searchQueueEmpty');\n\n content = Array.isArray(content) ? content[0] : content;\n\n content.facetHits.forEach(function(f) {\n f.escapedValue = escapeFacetValue(f.value);\n f.isRefined = isDisjunctive\n ? state.isDisjunctiveFacetRefined(facet, f.escapedValue)\n : state.isFacetRefined(facet, f.escapedValue);\n });\n\n return content;\n }, function(e) {\n self._currentNbQueries--;\n if (self._currentNbQueries === 0) self.emit('searchQueueEmpty');\n throw e;\n });\n};\n\n/**\n * Sets the text query used for the search.\n *\n * This method resets the current page to 0.\n * @param {string} q the user query\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.setQuery = function(q) {\n this._change({\n state: this.state.resetPage().setQuery(q),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Remove all the types of refinements except tags. A string can be provided to remove\n * only the refinements of a specific attribute. For more advanced use case, you can\n * provide a function instead. This function should follow the\n * [clearCallback definition](#SearchParameters.clearCallback).\n *\n * This method resets the current page to 0.\n * @param {string} [name] optional name of the facet / attribute on which we want to remove all refinements\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n * @example\n * // Removing all the refinements\n * helper.clearRefinements().search();\n * @example\n * // Removing all the filters on a the category attribute.\n * helper.clearRefinements('category').search();\n * @example\n * // Removing only the exclude filters on the category facet.\n * helper.clearRefinements(function(value, attribute, type) {\n * return type === 'exclude' && attribute === 'category';\n * }).search();\n */\nAlgoliaSearchHelper.prototype.clearRefinements = function(name) {\n this._change({\n state: this.state.resetPage().clearRefinements(name),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Remove all the tag filters.\n *\n * This method resets the current page to 0.\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.clearTags = function() {\n this._change({\n state: this.state.resetPage().clearTags(),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Adds a disjunctive filter to a faceted attribute with the `value` provided. If the\n * filter is already set, it doesn't change the filters.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} value the associated value (will be converted to string)\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.addDisjunctiveFacetRefinement = function(facet, value) {\n this._change({\n state: this.state.resetPage().addDisjunctiveFacetRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#addDisjunctiveFacetRefinement}\n */\nAlgoliaSearchHelper.prototype.addDisjunctiveRefine = function() {\n return this.addDisjunctiveFacetRefinement.apply(this, arguments);\n};\n\n/**\n * Adds a refinement on a hierarchical facet. It will throw\n * an exception if the facet is not defined or if the facet\n * is already refined.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet name\n * @param {string} path the hierarchical facet path\n * @return {AlgoliaSearchHelper}\n * @throws Error if the facet is not defined or if the facet is refined\n * @chainable\n * @fires change\n */\nAlgoliaSearchHelper.prototype.addHierarchicalFacetRefinement = function(facet, value) {\n this._change({\n state: this.state.resetPage().addHierarchicalFacetRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Adds a an numeric filter to an attribute with the `operator` and `value` provided. If the\n * filter is already set, it doesn't change the filters.\n *\n * This method resets the current page to 0.\n * @param {string} attribute the attribute on which the numeric filter applies\n * @param {string} operator the operator of the filter\n * @param {number} value the value of the filter\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.addNumericRefinement = function(attribute, operator, value) {\n this._change({\n state: this.state.resetPage().addNumericRefinement(attribute, operator, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Adds a filter to a faceted attribute with the `value` provided. If the\n * filter is already set, it doesn't change the filters.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} value the associated value (will be converted to string)\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.addFacetRefinement = function(facet, value) {\n this._change({\n state: this.state.resetPage().addFacetRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#addFacetRefinement}\n */\nAlgoliaSearchHelper.prototype.addRefine = function() {\n return this.addFacetRefinement.apply(this, arguments);\n};\n\n\n/**\n * Adds a an exclusion filter to a faceted attribute with the `value` provided. If the\n * filter is already set, it doesn't change the filters.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} value the associated value (will be converted to string)\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.addFacetExclusion = function(facet, value) {\n this._change({\n state: this.state.resetPage().addExcludeRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#addFacetExclusion}\n */\nAlgoliaSearchHelper.prototype.addExclude = function() {\n return this.addFacetExclusion.apply(this, arguments);\n};\n\n/**\n * Adds a tag filter with the `tag` provided. If the\n * filter is already set, it doesn't change the filters.\n *\n * This method resets the current page to 0.\n * @param {string} tag the tag to add to the filter\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.addTag = function(tag) {\n this._change({\n state: this.state.resetPage().addTagRefinement(tag),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Removes an numeric filter to an attribute with the `operator` and `value` provided. If the\n * filter is not set, it doesn't change the filters.\n *\n * Some parameters are optional, triggering different behavior:\n * - if the value is not provided, then all the numeric value will be removed for the\n * specified attribute/operator couple.\n * - if the operator is not provided either, then all the numeric filter on this attribute\n * will be removed.\n *\n * This method resets the current page to 0.\n * @param {string} attribute the attribute on which the numeric filter applies\n * @param {string} [operator] the operator of the filter\n * @param {number} [value] the value of the filter\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.removeNumericRefinement = function(attribute, operator, value) {\n this._change({\n state: this.state.resetPage().removeNumericRefinement(attribute, operator, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Removes a disjunctive filter to a faceted attribute with the `value` provided. If the\n * filter is not set, it doesn't change the filters.\n *\n * If the value is omitted, then this method will remove all the filters for the\n * attribute.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} [value] the associated value\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.removeDisjunctiveFacetRefinement = function(facet, value) {\n this._change({\n state: this.state.resetPage().removeDisjunctiveFacetRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#removeDisjunctiveFacetRefinement}\n */\nAlgoliaSearchHelper.prototype.removeDisjunctiveRefine = function() {\n return this.removeDisjunctiveFacetRefinement.apply(this, arguments);\n};\n\n/**\n * Removes the refinement set on a hierarchical facet.\n * @param {string} facet the facet name\n * @return {AlgoliaSearchHelper}\n * @throws Error if the facet is not defined or if the facet is not refined\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.removeHierarchicalFacetRefinement = function(facet) {\n this._change({\n state: this.state.resetPage().removeHierarchicalFacetRefinement(facet),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Removes a filter to a faceted attribute with the `value` provided. If the\n * filter is not set, it doesn't change the filters.\n *\n * If the value is omitted, then this method will remove all the filters for the\n * attribute.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} [value] the associated value\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.removeFacetRefinement = function(facet, value) {\n this._change({\n state: this.state.resetPage().removeFacetRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#removeFacetRefinement}\n */\nAlgoliaSearchHelper.prototype.removeRefine = function() {\n return this.removeFacetRefinement.apply(this, arguments);\n};\n\n/**\n * Removes an exclusion filter to a faceted attribute with the `value` provided. If the\n * filter is not set, it doesn't change the filters.\n *\n * If the value is omitted, then this method will remove all the filters for the\n * attribute.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} [value] the associated value\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.removeFacetExclusion = function(facet, value) {\n this._change({\n state: this.state.resetPage().removeExcludeRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#removeFacetExclusion}\n */\nAlgoliaSearchHelper.prototype.removeExclude = function() {\n return this.removeFacetExclusion.apply(this, arguments);\n};\n\n/**\n * Removes a tag filter with the `tag` provided. If the\n * filter is not set, it doesn't change the filters.\n *\n * This method resets the current page to 0.\n * @param {string} tag tag to remove from the filter\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.removeTag = function(tag) {\n this._change({\n state: this.state.resetPage().removeTagRefinement(tag),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Adds or removes an exclusion filter to a faceted attribute with the `value` provided. If\n * the value is set then it removes it, otherwise it adds the filter.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} value the associated value\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.toggleFacetExclusion = function(facet, value) {\n this._change({\n state: this.state.resetPage().toggleExcludeFacetRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#toggleFacetExclusion}\n */\nAlgoliaSearchHelper.prototype.toggleExclude = function() {\n return this.toggleFacetExclusion.apply(this, arguments);\n};\n\n/**\n * Adds or removes a filter to a faceted attribute with the `value` provided. If\n * the value is set then it removes it, otherwise it adds the filter.\n *\n * This method can be used for conjunctive, disjunctive and hierarchical filters.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} value the associated value\n * @return {AlgoliaSearchHelper}\n * @throws Error will throw an error if the facet is not declared in the settings of the helper\n * @fires change\n * @chainable\n * @deprecated since version 2.19.0, see {@link AlgoliaSearchHelper#toggleFacetRefinement}\n */\nAlgoliaSearchHelper.prototype.toggleRefinement = function(facet, value) {\n return this.toggleFacetRefinement(facet, value);\n};\n\n/**\n * Adds or removes a filter to a faceted attribute with the `value` provided. If\n * the value is set then it removes it, otherwise it adds the filter.\n *\n * This method can be used for conjunctive, disjunctive and hierarchical filters.\n *\n * This method resets the current page to 0.\n * @param {string} facet the facet to refine\n * @param {string} value the associated value\n * @return {AlgoliaSearchHelper}\n * @throws Error will throw an error if the facet is not declared in the settings of the helper\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.toggleFacetRefinement = function(facet, value) {\n this._change({\n state: this.state.resetPage().toggleFacetRefinement(facet, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * @deprecated since version 2.4.0, see {@link AlgoliaSearchHelper#toggleFacetRefinement}\n */\nAlgoliaSearchHelper.prototype.toggleRefine = function() {\n return this.toggleFacetRefinement.apply(this, arguments);\n};\n\n/**\n * Adds or removes a tag filter with the `value` provided. If\n * the value is set then it removes it, otherwise it adds the filter.\n *\n * This method resets the current page to 0.\n * @param {string} tag tag to remove or add\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.toggleTag = function(tag) {\n this._change({\n state: this.state.resetPage().toggleTagRefinement(tag),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Increments the page number by one.\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n * @example\n * helper.setPage(0).nextPage().getPage();\n * // returns 1\n */\nAlgoliaSearchHelper.prototype.nextPage = function() {\n var page = this.state.page || 0;\n return this.setPage(page + 1);\n};\n\n/**\n * Decrements the page number by one.\n * @fires change\n * @return {AlgoliaSearchHelper}\n * @chainable\n * @example\n * helper.setPage(1).previousPage().getPage();\n * // returns 0\n */\nAlgoliaSearchHelper.prototype.previousPage = function() {\n var page = this.state.page || 0;\n return this.setPage(page - 1);\n};\n\n/**\n * @private\n */\nfunction setCurrentPage(page) {\n if (page < 0) throw new Error('Page requested below 0.');\n\n this._change({\n state: this.state.setPage(page),\n isPageReset: false\n });\n\n return this;\n}\n\n/**\n * Change the current page\n * @deprecated\n * @param {number} page The page number\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.setCurrentPage = setCurrentPage;\n\n/**\n * Updates the current page.\n * @function\n * @param {number} page The page number\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.setPage = setCurrentPage;\n\n/**\n * Updates the name of the index that will be targeted by the query.\n *\n * This method resets the current page to 0.\n * @param {string} name the index name\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.setIndex = function(name) {\n this._change({\n state: this.state.resetPage().setIndex(name),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Update a parameter of the search. This method reset the page\n *\n * The complete list of parameters is available on the\n * [Algolia website](https://www.algolia.com/doc/rest#query-an-index).\n * The most commonly used parameters have their own [shortcuts](#query-parameters-shortcuts)\n * or benefit from higher-level APIs (all the kind of filters and facets have their own API)\n *\n * This method resets the current page to 0.\n * @param {string} parameter name of the parameter to update\n * @param {any} value new value of the parameter\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n * @example\n * helper.setQueryParameter('hitsPerPage', 20).search();\n */\nAlgoliaSearchHelper.prototype.setQueryParameter = function(parameter, value) {\n this._change({\n state: this.state.resetPage().setQueryParameter(parameter, value),\n isPageReset: true\n });\n\n return this;\n};\n\n/**\n * Set the whole state (warning: will erase previous state)\n * @param {SearchParameters} newState the whole new state\n * @return {AlgoliaSearchHelper}\n * @fires change\n * @chainable\n */\nAlgoliaSearchHelper.prototype.setState = function(newState) {\n this._change({\n state: SearchParameters.make(newState),\n isPageReset: false\n });\n\n return this;\n};\n\n/**\n * Override the current state without triggering a change event.\n * Do not use this method unless you know what you are doing. (see the example\n * for a legit use case)\n * @param {SearchParameters} newState the whole new state\n * @return {AlgoliaSearchHelper}\n * @example\n * helper.on('change', function(state){\n * // In this function you might want to find a way to store the state in the url/history\n * updateYourURL(state)\n * })\n * window.onpopstate = function(event){\n * // This is naive though as you should check if the state is really defined etc.\n * helper.overrideStateWithoutTriggeringChangeEvent(event.state).search()\n * }\n * @chainable\n */\nAlgoliaSearchHelper.prototype.overrideStateWithoutTriggeringChangeEvent = function(newState) {\n this.state = new SearchParameters(newState);\n return this;\n};\n\n/**\n * Check if an attribute has any numeric, conjunctive, disjunctive or hierarchical filters.\n * @param {string} attribute the name of the attribute\n * @return {boolean} true if the attribute is filtered by at least one value\n * @example\n * // hasRefinements works with numeric, conjunctive, disjunctive and hierarchical filters\n * helper.hasRefinements('price'); // false\n * helper.addNumericRefinement('price', '>', 100);\n * helper.hasRefinements('price'); // true\n *\n * helper.hasRefinements('color'); // false\n * helper.addFacetRefinement('color', 'blue');\n * helper.hasRefinements('color'); // true\n *\n * helper.hasRefinements('material'); // false\n * helper.addDisjunctiveFacetRefinement('material', 'plastic');\n * helper.hasRefinements('material'); // true\n *\n * helper.hasRefinements('categories'); // false\n * helper.toggleFacetRefinement('categories', 'kitchen > knife');\n * helper.hasRefinements('categories'); // true\n *\n */\nAlgoliaSearchHelper.prototype.hasRefinements = function(attribute) {\n if (objectHasKeys(this.state.getNumericRefinements(attribute))) {\n return true;\n } else if (this.state.isConjunctiveFacet(attribute)) {\n return this.state.isFacetRefined(attribute);\n } else if (this.state.isDisjunctiveFacet(attribute)) {\n return this.state.isDisjunctiveFacetRefined(attribute);\n } else if (this.state.isHierarchicalFacet(attribute)) {\n return this.state.isHierarchicalFacetRefined(attribute);\n }\n\n // there's currently no way to know that the user did call `addNumericRefinement` at some point\n // thus we cannot distinguish if there once was a numeric refinement that was cleared\n // so we will return false in every other situations to be consistent\n // while what we should do here is throw because we did not find the attribute in any type\n // of refinement\n return false;\n};\n\n/**\n * Check if a value is excluded for a specific faceted attribute. If the value\n * is omitted then the function checks if there is any excluding refinements.\n *\n * @param {string} facet name of the attribute for used for faceting\n * @param {string} [value] optional value. If passed will test that this value\n * is filtering the given facet.\n * @return {boolean} true if refined\n * @example\n * helper.isExcludeRefined('color'); // false\n * helper.isExcludeRefined('color', 'blue') // false\n * helper.isExcludeRefined('color', 'red') // false\n *\n * helper.addFacetExclusion('color', 'red');\n *\n * helper.isExcludeRefined('color'); // true\n * helper.isExcludeRefined('color', 'blue') // false\n * helper.isExcludeRefined('color', 'red') // true\n */\nAlgoliaSearchHelper.prototype.isExcluded = function(facet, value) {\n return this.state.isExcludeRefined(facet, value);\n};\n\n/**\n * @deprecated since 2.4.0, see {@link AlgoliaSearchHelper#hasRefinements}\n */\nAlgoliaSearchHelper.prototype.isDisjunctiveRefined = function(facet, value) {\n return this.state.isDisjunctiveFacetRefined(facet, value);\n};\n\n/**\n * Check if the string is a currently filtering tag.\n * @param {string} tag tag to check\n * @return {boolean}\n */\nAlgoliaSearchHelper.prototype.hasTag = function(tag) {\n return this.state.isTagRefined(tag);\n};\n\n/**\n * @deprecated since 2.4.0, see {@link AlgoliaSearchHelper#hasTag}\n */\nAlgoliaSearchHelper.prototype.isTagRefined = function() {\n return this.hasTagRefinements.apply(this, arguments);\n};\n\n\n/**\n * Get the name of the currently used index.\n * @return {string}\n * @example\n * helper.setIndex('highestPrice_products').getIndex();\n * // returns 'highestPrice_products'\n */\nAlgoliaSearchHelper.prototype.getIndex = function() {\n return this.state.index;\n};\n\nfunction getCurrentPage() {\n return this.state.page;\n}\n\n/**\n * Get the currently selected page\n * @deprecated\n * @return {number} the current page\n */\nAlgoliaSearchHelper.prototype.getCurrentPage = getCurrentPage;\n/**\n * Get the currently selected page\n * @function\n * @return {number} the current page\n */\nAlgoliaSearchHelper.prototype.getPage = getCurrentPage;\n\n/**\n * Get all the tags currently set to filters the results.\n *\n * @return {string[]} The list of tags currently set.\n */\nAlgoliaSearchHelper.prototype.getTags = function() {\n return this.state.tagRefinements;\n};\n\n/**\n * Get the list of refinements for a given attribute. This method works with\n * conjunctive, disjunctive, excluding and numerical filters.\n *\n * See also SearchResults#getRefinements\n *\n * @param {string} facetName attribute name used for faceting\n * @return {Array.} All Refinement are objects that contain a value, and\n * a type. Numeric also contains an operator.\n * @example\n * helper.addNumericRefinement('price', '>', 100);\n * helper.getRefinements('price');\n * // [\n * // {\n * // \"value\": [\n * // 100\n * // ],\n * // \"operator\": \">\",\n * // \"type\": \"numeric\"\n * // }\n * // ]\n * @example\n * helper.addFacetRefinement('color', 'blue');\n * helper.addFacetExclusion('color', 'red');\n * helper.getRefinements('color');\n * // [\n * // {\n * // \"value\": \"blue\",\n * // \"type\": \"conjunctive\"\n * // },\n * // {\n * // \"value\": \"red\",\n * // \"type\": \"exclude\"\n * // }\n * // ]\n * @example\n * helper.addDisjunctiveFacetRefinement('material', 'plastic');\n * // [\n * // {\n * // \"value\": \"plastic\",\n * // \"type\": \"disjunctive\"\n * // }\n * // ]\n */\nAlgoliaSearchHelper.prototype.getRefinements = function(facetName) {\n var refinements = [];\n\n if (this.state.isConjunctiveFacet(facetName)) {\n var conjRefinements = this.state.getConjunctiveRefinements(facetName);\n\n conjRefinements.forEach(function(r) {\n refinements.push({\n value: r,\n type: 'conjunctive'\n });\n });\n\n var excludeRefinements = this.state.getExcludeRefinements(facetName);\n\n excludeRefinements.forEach(function(r) {\n refinements.push({\n value: r,\n type: 'exclude'\n });\n });\n } else if (this.state.isDisjunctiveFacet(facetName)) {\n var disjRefinements = this.state.getDisjunctiveRefinements(facetName);\n\n disjRefinements.forEach(function(r) {\n refinements.push({\n value: r,\n type: 'disjunctive'\n });\n });\n }\n\n var numericRefinements = this.state.getNumericRefinements(facetName);\n\n Object.keys(numericRefinements).forEach(function(operator) {\n var value = numericRefinements[operator];\n\n refinements.push({\n value: value,\n operator: operator,\n type: 'numeric'\n });\n });\n\n return refinements;\n};\n\n/**\n * Return the current refinement for the (attribute, operator)\n * @param {string} attribute attribute in the record\n * @param {string} operator operator applied on the refined values\n * @return {Array.} refined values\n */\nAlgoliaSearchHelper.prototype.getNumericRefinement = function(attribute, operator) {\n return this.state.getNumericRefinement(attribute, operator);\n};\n\n/**\n * Get the current breadcrumb for a hierarchical facet, as an array\n * @param {string} facetName Hierarchical facet name\n * @return {array.} the path as an array of string\n */\nAlgoliaSearchHelper.prototype.getHierarchicalFacetBreadcrumb = function(facetName) {\n return this.state.getHierarchicalFacetBreadcrumb(facetName);\n};\n\n// /////////// PRIVATE\n\n/**\n * Perform the underlying queries\n * @private\n * @return {undefined}\n * @fires search\n * @fires result\n * @fires error\n */\nAlgoliaSearchHelper.prototype._search = function(options) {\n var state = this.state;\n var states = [];\n var mainQueries = [];\n\n if (!options.onlyWithDerivedHelpers) {\n mainQueries = requestBuilder._getQueries(state.index, state);\n\n states.push({\n state: state,\n queriesCount: mainQueries.length,\n helper: this\n });\n\n this.emit('search', {\n state: state,\n results: this.lastResults\n });\n }\n\n var derivedQueries = this.derivedHelpers.map(function(derivedHelper) {\n var derivedState = derivedHelper.getModifiedState(state);\n var derivedStateQueries = requestBuilder._getQueries(derivedState.index, derivedState);\n\n states.push({\n state: derivedState,\n queriesCount: derivedStateQueries.length,\n helper: derivedHelper\n });\n\n derivedHelper.emit('search', {\n state: derivedState,\n results: derivedHelper.lastResults\n });\n\n return derivedStateQueries;\n });\n\n var queries = Array.prototype.concat.apply(mainQueries, derivedQueries);\n var queryId = this._queryId++;\n\n this._currentNbQueries++;\n\n try {\n this.client.search(queries)\n .then(this._dispatchAlgoliaResponse.bind(this, states, queryId))\n .catch(this._dispatchAlgoliaError.bind(this, queryId));\n } catch (error) {\n // If we reach this part, we're in an internal error state\n this.emit('error', {\n error: error\n });\n }\n};\n\n/**\n * Transform the responses as sent by the server and transform them into a user\n * usable object that merge the results of all the batch requests. It will dispatch\n * over the different helper + derived helpers (when there are some).\n * @private\n * @param {array.<{SearchParameters, AlgoliaQueries, AlgoliaSearchHelper}>}\n * state state used for to generate the request\n * @param {number} queryId id of the current request\n * @param {object} content content of the response\n * @return {undefined}\n */\nAlgoliaSearchHelper.prototype._dispatchAlgoliaResponse = function(states, queryId, content) {\n // FIXME remove the number of outdated queries discarded instead of just one\n\n if (queryId < this._lastQueryIdReceived) {\n // Outdated answer\n return;\n }\n\n this._currentNbQueries -= (queryId - this._lastQueryIdReceived);\n this._lastQueryIdReceived = queryId;\n\n if (this._currentNbQueries === 0) this.emit('searchQueueEmpty');\n\n var results = content.results.slice();\n\n states.forEach(function(s) {\n var state = s.state;\n var queriesCount = s.queriesCount;\n var helper = s.helper;\n var specificResults = results.splice(0, queriesCount);\n\n var formattedResponse = helper.lastResults = new SearchResults(state, specificResults);\n\n helper.emit('result', {\n results: formattedResponse,\n state: state\n });\n });\n};\n\nAlgoliaSearchHelper.prototype._dispatchAlgoliaError = function(queryId, error) {\n if (queryId < this._lastQueryIdReceived) {\n // Outdated answer\n return;\n }\n\n this._currentNbQueries -= queryId - this._lastQueryIdReceived;\n this._lastQueryIdReceived = queryId;\n\n this.emit('error', {\n error: error\n });\n\n if (this._currentNbQueries === 0) this.emit('searchQueueEmpty');\n};\n\nAlgoliaSearchHelper.prototype.containsRefinement = function(query, facetFilters, numericFilters, tagFilters) {\n return query ||\n facetFilters.length !== 0 ||\n numericFilters.length !== 0 ||\n tagFilters.length !== 0;\n};\n\n/**\n * Test if there are some disjunctive refinements on the facet\n * @private\n * @param {string} facet the attribute to test\n * @return {boolean}\n */\nAlgoliaSearchHelper.prototype._hasDisjunctiveRefinements = function(facet) {\n return this.state.disjunctiveRefinements[facet] &&\n this.state.disjunctiveRefinements[facet].length > 0;\n};\n\nAlgoliaSearchHelper.prototype._change = function(event) {\n var state = event.state;\n var isPageReset = event.isPageReset;\n\n if (state !== this.state) {\n this.state = state;\n\n this.emit('change', {\n state: this.state,\n results: this.lastResults,\n isPageReset: isPageReset\n });\n }\n};\n\n/**\n * Clears the cache of the underlying Algolia client.\n * @return {AlgoliaSearchHelper}\n */\nAlgoliaSearchHelper.prototype.clearCache = function() {\n this.client.clearCache && this.client.clearCache();\n return this;\n};\n\n/**\n * Updates the internal client instance. If the reference of the clients\n * are equal then no update is actually done.\n * @param {AlgoliaSearch} newClient an AlgoliaSearch client\n * @return {AlgoliaSearchHelper}\n */\nAlgoliaSearchHelper.prototype.setClient = function(newClient) {\n if (this.client === newClient) return this;\n\n if (typeof newClient.addAlgoliaAgent === 'function') {\n newClient.addAlgoliaAgent('JS Helper (' + version + ')');\n }\n this.client = newClient;\n\n return this;\n};\n\n/**\n * Gets the instance of the currently used client.\n * @return {AlgoliaSearch}\n */\nAlgoliaSearchHelper.prototype.getClient = function() {\n return this.client;\n};\n\n/**\n * Creates an derived instance of the Helper. A derived helper\n * is a way to request other indices synchronised with the lifecycle\n * of the main Helper. This mechanism uses the multiqueries feature\n * of Algolia to aggregate all the requests in a single network call.\n *\n * This method takes a function that is used to create a new SearchParameter\n * that will be used to create requests to Algolia. Those new requests\n * are created just before the `search` event. The signature of the function\n * is `SearchParameters -> SearchParameters`.\n *\n * This method returns a new DerivedHelper which is an EventEmitter\n * that fires the same `search`, `result` and `error` events. Those\n * events, however, will receive data specific to this DerivedHelper\n * and the SearchParameters that is returned by the call of the\n * parameter function.\n * @param {function} fn SearchParameters -> SearchParameters\n * @return {DerivedHelper}\n */\nAlgoliaSearchHelper.prototype.derive = function(fn) {\n var derivedHelper = new DerivedHelper(this, fn);\n this.derivedHelpers.push(derivedHelper);\n return derivedHelper;\n};\n\n/**\n * This method detaches a derived Helper from the main one. Prefer using the one from the\n * derived helper itself, to remove the event listeners too.\n * @private\n * @return {undefined}\n * @throws Error\n */\nAlgoliaSearchHelper.prototype.detachDerivedHelper = function(derivedHelper) {\n var pos = this.derivedHelpers.indexOf(derivedHelper);\n if (pos === -1) throw new Error('Derived helper already detached');\n this.derivedHelpers.splice(pos, 1);\n};\n\n/**\n * This method returns true if there is currently at least one on-going search.\n * @return {boolean} true if there is a search pending\n */\nAlgoliaSearchHelper.prototype.hasPendingRequests = function() {\n return this._currentNbQueries > 0;\n};\n\n/**\n * @typedef AlgoliaSearchHelper.NumericRefinement\n * @type {object}\n * @property {number[]} value the numbers that are used for filtering this attribute with\n * the operator specified.\n * @property {string} operator the faceting data: value, number of entries\n * @property {string} type will be 'numeric'\n */\n\n/**\n * @typedef AlgoliaSearchHelper.FacetRefinement\n * @type {object}\n * @property {string} value the string use to filter the attribute\n * @property {string} type the type of filter: 'conjunctive', 'disjunctive', 'exclude'\n */\n\nmodule.exports = AlgoliaSearchHelper;\n","'use strict';\n\nmodule.exports = function compact(array) {\n if (!Array.isArray(array)) {\n return [];\n }\n\n return array.filter(Boolean);\n};\n","'use strict';\n\n// NOTE: this behaves like lodash/defaults, but doesn't mutate the target\n// it also preserve keys order\nmodule.exports = function defaultsPure() {\n var sources = Array.prototype.slice.call(arguments);\n\n return sources.reduceRight(function(acc, source) {\n Object.keys(Object(source)).forEach(function(key) {\n if (source[key] === undefined) {\n return;\n }\n if (acc[key] !== undefined) {\n // remove if already added, so that we can add it in correct order\n delete acc[key];\n }\n acc[key] = source[key];\n });\n return acc;\n }, {});\n};\n","'use strict';\n\n/**\n * Replaces a leading - with \\-\n * @private\n * @param {any} value the facet value to replace\n * @returns any\n */\nfunction escapeFacetValue(value) {\n if (typeof value !== 'string') return value;\n\n return String(value).replace(/^-/, '\\\\-');\n}\n\n/**\n * Replaces a leading \\- with -\n * @private\n * @param {any} value the escaped facet value\n * @returns any\n */\nfunction unescapeFacetValue(value) {\n if (typeof value !== 'string') return value;\n\n return value.replace(/^\\\\-/, '-');\n}\n\nmodule.exports = {\n escapeFacetValue: escapeFacetValue,\n unescapeFacetValue: unescapeFacetValue\n};\n","'use strict';\n\n// @MAJOR can be replaced by native Array#find when we change support\nmodule.exports = function find(array, comparator) {\n if (!Array.isArray(array)) {\n return undefined;\n }\n\n for (var i = 0; i < array.length; i++) {\n if (comparator(array[i])) {\n return array[i];\n }\n }\n};\n","'use strict';\n\n// @MAJOR can be replaced by native Array#findIndex when we change support\nmodule.exports = function find(array, comparator) {\n if (!Array.isArray(array)) {\n return -1;\n }\n\n for (var i = 0; i < array.length; i++) {\n if (comparator(array[i])) {\n return i;\n }\n }\n return -1;\n};\n","'use strict';\n\nvar find = require('./find');\n\n/**\n * Transform sort format from user friendly notation to lodash format\n * @param {string[]} sortBy array of predicate of the form \"attribute:order\"\n * @param {string[]} [defaults] array of predicate of the form \"attribute:order\"\n * @return {array.} array containing 2 elements : attributes, orders\n */\nmodule.exports = function formatSort(sortBy, defaults) {\n var defaultInstructions = (defaults || []).map(function(sort) {\n return sort.split(':');\n });\n\n return sortBy.reduce(\n function preparePredicate(out, sort) {\n var sortInstruction = sort.split(':');\n\n var matchingDefault = find(defaultInstructions, function(\n defaultInstruction\n ) {\n return defaultInstruction[0] === sortInstruction[0];\n });\n\n if (sortInstruction.length > 1 || !matchingDefault) {\n out[0].push(sortInstruction[0]);\n out[1].push(sortInstruction[1]);\n return out;\n }\n\n out[0].push(matchingDefault[0]);\n out[1].push(matchingDefault[1]);\n return out;\n },\n [[], []]\n );\n};\n","'use strict';\n\nfunction inherits(ctor, 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\nmodule.exports = inherits;\n","'use strict';\n\nfunction intersection(arr1, arr2) {\n return arr1.filter(function(value, index) {\n return (\n arr2.indexOf(value) > -1 &&\n arr1.indexOf(value) === index /* skips duplicates */\n );\n });\n}\n\nmodule.exports = intersection;\n","'use strict';\n\nfunction clone(value) {\n if (typeof value === 'object' && value !== null) {\n return _merge(Array.isArray(value) ? [] : {}, value);\n }\n return value;\n}\n\nfunction isObjectOrArrayOrFunction(value) {\n return (\n typeof value === 'function' ||\n Array.isArray(value) ||\n Object.prototype.toString.call(value) === '[object Object]'\n );\n}\n\nfunction _merge(target, source) {\n if (target === source) {\n return target;\n }\n\n for (var key in source) {\n if (\n !Object.prototype.hasOwnProperty.call(source, key) ||\n key === '__proto__' ||\n key === 'constructor'\n ) {\n continue;\n }\n\n var sourceVal = source[key];\n var targetVal = target[key];\n\n if (typeof targetVal !== 'undefined' && typeof sourceVal === 'undefined') {\n continue;\n }\n\n if (\n isObjectOrArrayOrFunction(targetVal) &&\n isObjectOrArrayOrFunction(sourceVal)\n ) {\n target[key] = _merge(targetVal, sourceVal);\n } else {\n target[key] = clone(sourceVal);\n }\n }\n return target;\n}\n\n/**\n * This method is like Object.assign, but recursively merges own and inherited\n * enumerable keyed properties of source objects into the destination object.\n *\n * NOTE: this behaves like lodash/merge, but:\n * - does mutate functions if they are a source\n * - treats non-plain objects as plain\n * - does not work for circular objects\n * - treats sparse arrays as sparse\n * - does not convert Array-like objects (Arguments, NodeLists, etc.) to arrays\n *\n * @param {Object} object The destination object.\n * @param {...Object} [sources] The source objects.\n * @returns {Object} Returns `object`.\n */\n\nfunction merge(target) {\n if (!isObjectOrArrayOrFunction(target)) {\n target = {};\n }\n\n for (var i = 1, l = arguments.length; i < l; i++) {\n var source = arguments[i];\n\n if (isObjectOrArrayOrFunction(source)) {\n _merge(target, source);\n }\n }\n return target;\n}\n\nmodule.exports = merge;\n","'use strict';\n\nfunction objectHasKeys(obj) {\n return obj && Object.keys(obj).length > 0;\n}\n\nmodule.exports = objectHasKeys;\n","'use strict';\n\n// https://github.com/babel/babel/blob/3aaafae053fa75febb3aa45d45b6f00646e30ba4/packages/babel-helpers/src/helpers.js#L604-L620\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source === null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key;\n var i;\n for (i = 0; i < sourceKeys.length; i++) {\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\n\nmodule.exports = _objectWithoutPropertiesLoose;\n","'use strict';\n\nfunction compareAscending(value, other) {\n if (value !== other) {\n var valIsDefined = value !== undefined;\n var valIsNull = value === null;\n\n var othIsDefined = other !== undefined;\n var othIsNull = other === null;\n\n if (\n (!othIsNull && value > other) ||\n (valIsNull && othIsDefined) ||\n !valIsDefined\n ) {\n return 1;\n }\n if (\n (!valIsNull && value < other) ||\n (othIsNull && valIsDefined) ||\n !othIsDefined\n ) {\n return -1;\n }\n }\n return 0;\n}\n\n/**\n * @param {Array} collection object with keys in attributes\n * @param {Array} iteratees attributes\n * @param {Array} orders asc | desc\n */\nfunction orderBy(collection, iteratees, orders) {\n if (!Array.isArray(collection)) {\n return [];\n }\n\n if (!Array.isArray(orders)) {\n orders = [];\n }\n\n var result = collection.map(function(value, index) {\n return {\n criteria: iteratees.map(function(iteratee) {\n return value[iteratee];\n }),\n index: index,\n value: value\n };\n });\n\n result.sort(function comparer(object, other) {\n var index = -1;\n\n while (++index < object.criteria.length) {\n var res = compareAscending(object.criteria[index], other.criteria[index]);\n if (res) {\n if (index >= orders.length) {\n return res;\n }\n if (orders[index] === 'desc') {\n return -res;\n }\n return res;\n }\n }\n\n // This ensures a stable sort in V8 and other engines.\n // See https://bugs.chromium.org/p/v8/issues/detail?id=90 for more details.\n return object.index - other.index;\n });\n\n return result.map(function(res) {\n return res.value;\n });\n}\n\nmodule.exports = orderBy;\n","'use strict';\n\nfunction valToNumber(v) {\n if (typeof v === 'number') {\n return v;\n } else if (typeof v === 'string') {\n return parseFloat(v);\n } else if (Array.isArray(v)) {\n return v.map(valToNumber);\n }\n\n throw new Error('The value should be a number, a parsable string or an array of those.');\n}\n\nmodule.exports = valToNumber;\n","'use strict';\n\nvar merge = require('./functions/merge');\n\nfunction sortObject(obj) {\n return Object.keys(obj)\n .sort(function(a, b) {\n return a.localeCompare(b);\n })\n .reduce(function(acc, curr) {\n acc[curr] = obj[curr];\n return acc;\n }, {});\n}\n\nvar requestBuilder = {\n /**\n * Get all the queries to send to the client, those queries can used directly\n * with the Algolia client.\n * @private\n * @return {object[]} The queries\n */\n _getQueries: function getQueries(index, state) {\n var queries = [];\n\n // One query for the hits\n queries.push({\n indexName: index,\n params: requestBuilder._getHitsSearchParams(state)\n });\n\n // One for each disjunctive facets\n state.getRefinedDisjunctiveFacets().forEach(function(refinedFacet) {\n queries.push({\n indexName: index,\n params: requestBuilder._getDisjunctiveFacetSearchParams(state, refinedFacet)\n });\n });\n\n // More to get the parent levels of the hierarchical facets when refined\n state.getRefinedHierarchicalFacets().forEach(function(refinedFacet) {\n var hierarchicalFacet = state.getHierarchicalFacetByName(refinedFacet);\n var currentRefinement = state.getHierarchicalRefinement(refinedFacet);\n var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet);\n\n // If we are deeper than level 0 (starting from `beer > IPA`)\n // we want to get all parent values\n if (currentRefinement.length > 0 && currentRefinement[0].split(separator).length > 1) {\n // We generate a map of the filters we will use for our facet values queries\n var filtersMap = currentRefinement[0].split(separator).slice(0, -1).reduce(\n function createFiltersMap(map, segment, level) {\n return map.concat({\n attribute: hierarchicalFacet.attributes[level],\n value: level === 0\n ? segment\n : [map[map.length - 1].value, segment].join(separator)\n });\n }\n , []);\n\n filtersMap.forEach(function(filter, level) {\n var params = requestBuilder._getDisjunctiveFacetSearchParams(\n state,\n filter.attribute,\n level === 0\n );\n\n // Keep facet filters unrelated to current hierarchical attributes\n function hasHierarchicalFacetFilter(value) {\n return hierarchicalFacet.attributes.some(function(attribute) {\n return attribute === value.split(':')[0];\n });\n }\n\n var filteredFacetFilters = (params.facetFilters || []).reduce(function(acc, facetFilter) {\n if (Array.isArray(facetFilter)) {\n var filtered = facetFilter.filter(function(filterValue) {\n return !hasHierarchicalFacetFilter(filterValue);\n });\n\n if (filtered.length > 0) {\n acc.push(filtered);\n }\n }\n\n if (typeof facetFilter === 'string' && !hasHierarchicalFacetFilter(facetFilter)) {\n acc.push(facetFilter);\n }\n\n return acc;\n }, []);\n\n var parent = filtersMap[level - 1];\n if (level > 0) {\n params.facetFilters = filteredFacetFilters.concat(parent.attribute + ':' + parent.value);\n } else {\n params.facetFilters = filteredFacetFilters.length > 0 ? filteredFacetFilters : undefined;\n }\n\n queries.push({indexName: index, params: params});\n });\n }\n });\n\n return queries;\n },\n\n /**\n * Build search parameters used to fetch hits\n * @private\n * @return {object.}\n */\n _getHitsSearchParams: function(state) {\n var facets = state.facets\n .concat(state.disjunctiveFacets)\n .concat(requestBuilder._getHitsHierarchicalFacetsAttributes(state));\n\n\n var facetFilters = requestBuilder._getFacetFilters(state);\n var numericFilters = requestBuilder._getNumericFilters(state);\n var tagFilters = requestBuilder._getTagFilters(state);\n var additionalParams = {\n facets: facets.indexOf('*') > -1 ? ['*'] : facets,\n tagFilters: tagFilters\n };\n\n if (facetFilters.length > 0) {\n additionalParams.facetFilters = facetFilters;\n }\n\n if (numericFilters.length > 0) {\n additionalParams.numericFilters = numericFilters;\n }\n\n return sortObject(merge({}, state.getQueryParams(), additionalParams));\n },\n\n /**\n * Build search parameters used to fetch a disjunctive facet\n * @private\n * @param {string} facet the associated facet name\n * @param {boolean} hierarchicalRootLevel ?? FIXME\n * @return {object}\n */\n _getDisjunctiveFacetSearchParams: function(state, facet, hierarchicalRootLevel) {\n var facetFilters = requestBuilder._getFacetFilters(state, facet, hierarchicalRootLevel);\n var numericFilters = requestBuilder._getNumericFilters(state, facet);\n var tagFilters = requestBuilder._getTagFilters(state);\n var additionalParams = {\n hitsPerPage: 0,\n page: 0,\n analytics: false,\n clickAnalytics: false\n };\n\n if (tagFilters.length > 0) {\n additionalParams.tagFilters = tagFilters;\n }\n\n var hierarchicalFacet = state.getHierarchicalFacetByName(facet);\n\n if (hierarchicalFacet) {\n additionalParams.facets = requestBuilder._getDisjunctiveHierarchicalFacetAttribute(\n state,\n hierarchicalFacet,\n hierarchicalRootLevel\n );\n } else {\n additionalParams.facets = facet;\n }\n\n if (numericFilters.length > 0) {\n additionalParams.numericFilters = numericFilters;\n }\n\n if (facetFilters.length > 0) {\n additionalParams.facetFilters = facetFilters;\n }\n\n return sortObject(merge({}, state.getQueryParams(), additionalParams));\n },\n\n /**\n * Return the numeric filters in an algolia request fashion\n * @private\n * @param {string} [facetName] the name of the attribute for which the filters should be excluded\n * @return {string[]} the numeric filters in the algolia format\n */\n _getNumericFilters: function(state, facetName) {\n if (state.numericFilters) {\n return state.numericFilters;\n }\n\n var numericFilters = [];\n\n Object.keys(state.numericRefinements).forEach(function(attribute) {\n var operators = state.numericRefinements[attribute] || {};\n Object.keys(operators).forEach(function(operator) {\n var values = operators[operator] || [];\n if (facetName !== attribute) {\n values.forEach(function(value) {\n if (Array.isArray(value)) {\n var vs = value.map(function(v) {\n return attribute + operator + v;\n });\n numericFilters.push(vs);\n } else {\n numericFilters.push(attribute + operator + value);\n }\n });\n }\n });\n });\n\n return numericFilters;\n },\n\n /**\n * Return the tags filters depending\n * @private\n * @return {string}\n */\n _getTagFilters: function(state) {\n if (state.tagFilters) {\n return state.tagFilters;\n }\n\n return state.tagRefinements.join(',');\n },\n\n\n /**\n * Build facetFilters parameter based on current refinements. The array returned\n * contains strings representing the facet filters in the algolia format.\n * @private\n * @param {string} [facet] if set, the current disjunctive facet\n * @return {array.}\n */\n _getFacetFilters: function(state, facet, hierarchicalRootLevel) {\n var facetFilters = [];\n\n var facetsRefinements = state.facetsRefinements || {};\n Object.keys(facetsRefinements).forEach(function(facetName) {\n var facetValues = facetsRefinements[facetName] || [];\n facetValues.forEach(function(facetValue) {\n facetFilters.push(facetName + ':' + facetValue);\n });\n });\n\n var facetsExcludes = state.facetsExcludes || {};\n Object.keys(facetsExcludes).forEach(function(facetName) {\n var facetValues = facetsExcludes[facetName] || [];\n facetValues.forEach(function(facetValue) {\n facetFilters.push(facetName + ':-' + facetValue);\n });\n });\n\n var disjunctiveFacetsRefinements = state.disjunctiveFacetsRefinements || {};\n Object.keys(disjunctiveFacetsRefinements).forEach(function(facetName) {\n var facetValues = disjunctiveFacetsRefinements[facetName] || [];\n if (facetName === facet || !facetValues || facetValues.length === 0) {\n return;\n }\n var orFilters = [];\n\n facetValues.forEach(function(facetValue) {\n orFilters.push(facetName + ':' + facetValue);\n });\n\n facetFilters.push(orFilters);\n });\n\n var hierarchicalFacetsRefinements = state.hierarchicalFacetsRefinements || {};\n Object.keys(hierarchicalFacetsRefinements).forEach(function(facetName) {\n var facetValues = hierarchicalFacetsRefinements[facetName] || [];\n var facetValue = facetValues[0];\n\n if (facetValue === undefined) {\n return;\n }\n\n var hierarchicalFacet = state.getHierarchicalFacetByName(facetName);\n var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet);\n var rootPath = state._getHierarchicalRootPath(hierarchicalFacet);\n var attributeToRefine;\n var attributesIndex;\n\n // we ask for parent facet values only when the `facet` is the current hierarchical facet\n if (facet === facetName) {\n // if we are at the root level already, no need to ask for facet values, we get them from\n // the hits query\n if (facetValue.indexOf(separator) === -1 || (!rootPath && hierarchicalRootLevel === true) ||\n (rootPath && rootPath.split(separator).length === facetValue.split(separator).length)) {\n return;\n }\n\n if (!rootPath) {\n attributesIndex = facetValue.split(separator).length - 2;\n facetValue = facetValue.slice(0, facetValue.lastIndexOf(separator));\n } else {\n attributesIndex = rootPath.split(separator).length - 1;\n facetValue = rootPath;\n }\n\n attributeToRefine = hierarchicalFacet.attributes[attributesIndex];\n } else {\n attributesIndex = facetValue.split(separator).length - 1;\n\n attributeToRefine = hierarchicalFacet.attributes[attributesIndex];\n }\n\n if (attributeToRefine) {\n facetFilters.push([attributeToRefine + ':' + facetValue]);\n }\n });\n\n return facetFilters;\n },\n\n _getHitsHierarchicalFacetsAttributes: function(state) {\n var out = [];\n\n return state.hierarchicalFacets.reduce(\n // ask for as much levels as there's hierarchical refinements\n function getHitsAttributesForHierarchicalFacet(allAttributes, hierarchicalFacet) {\n var hierarchicalRefinement = state.getHierarchicalRefinement(hierarchicalFacet.name)[0];\n\n // if no refinement, ask for root level\n if (!hierarchicalRefinement) {\n allAttributes.push(hierarchicalFacet.attributes[0]);\n return allAttributes;\n }\n\n var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet);\n var level = hierarchicalRefinement.split(separator).length;\n var newAttributes = hierarchicalFacet.attributes.slice(0, level + 1);\n\n return allAttributes.concat(newAttributes);\n }, out);\n },\n\n _getDisjunctiveHierarchicalFacetAttribute: function(state, hierarchicalFacet, rootLevel) {\n var separator = state._getHierarchicalFacetSeparator(hierarchicalFacet);\n if (rootLevel === true) {\n var rootPath = state._getHierarchicalRootPath(hierarchicalFacet);\n var attributeIndex = 0;\n\n if (rootPath) {\n attributeIndex = rootPath.split(separator).length;\n }\n return [hierarchicalFacet.attributes[attributeIndex]];\n }\n\n var hierarchicalRefinement = state.getHierarchicalRefinement(hierarchicalFacet.name)[0] || '';\n // if refinement is 'beers > IPA > Flying dog',\n // then we want `facets: ['beers > IPA']` as disjunctive facet (parent level values)\n\n var parentLevel = hierarchicalRefinement.split(separator).length - 1;\n return hierarchicalFacet.attributes.slice(0, parentLevel + 1);\n },\n\n getSearchForFacetQuery: function(facetName, query, maxFacetHits, state) {\n var stateForSearchForFacetValues = state.isDisjunctiveFacet(facetName) ?\n state.clearRefinements(facetName) :\n state;\n var searchForFacetSearchParameters = {\n facetQuery: query,\n facetName: facetName\n };\n if (typeof maxFacetHits === 'number') {\n searchForFacetSearchParameters.maxFacetHits = maxFacetHits;\n }\n return sortObject(merge(\n {},\n requestBuilder._getHitsSearchParams(stateForSearchForFacetValues),\n searchForFacetSearchParameters\n ));\n }\n};\n\nmodule.exports = requestBuilder;\n","'use strict';\n\nmodule.exports = function isValidUserToken(userToken) {\n if (userToken === null) {\n return false;\n }\n return /^[a-zA-Z0-9_-]{1,64}$/.test(userToken);\n};\n","'use strict';\n\nmodule.exports = '3.12.0';\n","/*! algoliasearch.umd.js | 4.17.0 | © Algolia, inc. | https://github.com/algolia/algoliasearch-client-javascript */\n!function(t,e){\"object\"==typeof exports&&\"undefined\"!=typeof module?module.exports=e():\"function\"==typeof define&&define.amd?define(e):(t=t||self).algoliasearch=e()}(this,(function(){\"use strict\";function t(t,e,r){return e in t?Object.defineProperty(t,e,{value:r,enumerable:!0,configurable:!0,writable:!0}):t[e]=r,t}function e(t,e){var r=Object.keys(t);if(Object.getOwnPropertySymbols){var n=Object.getOwnPropertySymbols(t);e&&(n=n.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),r.push.apply(r,n)}return r}function r(r){for(var n=1;n=0||(a[r]=t[r]);return a}(t,e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(t);for(n=0;n=0||Object.prototype.propertyIsEnumerable.call(t,r)&&(a[r]=t[r])}return a}function a(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){if(!(Symbol.iterator in Object(t)||\"[object Arguments]\"===Object.prototype.toString.call(t)))return;var r=[],n=!0,a=!1,o=void 0;try{for(var i,u=t[Symbol.iterator]();!(n=(i=u.next()).done)&&(r.push(i.value),!e||r.length!==e);n=!0);}catch(t){a=!0,o=t}finally{try{n||null==u.return||u.return()}finally{if(a)throw o}}return r}(t,e)||function(){throw new TypeError(\"Invalid attempt to destructure non-iterable instance\")}()}function o(t){return function(t){if(Array.isArray(t)){for(var e=0,r=new Array(t.length);e2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}};return Promise.resolve().then((function(){var r=JSON.stringify(t),n=o()[r];return Promise.all([n||e(),void 0!==n])})).then((function(t){var e=a(t,2),n=e[0],o=e[1];return Promise.all([n,o||r.miss(n)])})).then((function(t){return a(t,1)[0]}))},set:function(t,e){return Promise.resolve().then((function(){var a=o();return a[JSON.stringify(t)]=e,n().setItem(r,JSON.stringify(a)),e}))},delete:function(t){return Promise.resolve().then((function(){var e=o();delete e[JSON.stringify(t)],n().setItem(r,JSON.stringify(e))}))},clear:function(){return Promise.resolve().then((function(){n().removeItem(r)}))}}}function u(t){var e=o(t.caches),r=e.shift();return void 0===r?{get:function(t,e){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}},n=e();return n.then((function(t){return Promise.all([t,r.miss(t)])})).then((function(t){return a(t,1)[0]}))},set:function(t,e){return Promise.resolve(e)},delete:function(t){return Promise.resolve()},clear:function(){return Promise.resolve()}}:{get:function(t,n){var a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}};return r.get(t,n,a).catch((function(){return u({caches:e}).get(t,n,a)}))},set:function(t,n){return r.set(t,n).catch((function(){return u({caches:e}).set(t,n)}))},delete:function(t){return r.delete(t).catch((function(){return u({caches:e}).delete(t)}))},clear:function(){return r.clear().catch((function(){return u({caches:e}).clear()}))}}}function s(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{serializable:!0},e={};return{get:function(r,n){var a=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{miss:function(){return Promise.resolve()}},o=JSON.stringify(r);if(o in e)return Promise.resolve(t.serializable?JSON.parse(e[o]):e[o]);var i=n(),u=a&&a.miss||function(){return Promise.resolve()};return i.then((function(t){return u(t)})).then((function(){return i}))},set:function(r,n){return e[JSON.stringify(r)]=t.serializable?JSON.stringify(n):n,Promise.resolve(n)},delete:function(t){return delete e[JSON.stringify(t)],Promise.resolve()},clear:function(){return e={},Promise.resolve()}}}function c(t,e,r){var n={\"x-algolia-api-key\":r,\"x-algolia-application-id\":e};return{headers:function(){return t===m.WithinHeaders?n:{}},queryParameters:function(){return t===m.WithinQueryParameters?n:{}}}}function f(t){var e=0;return t((function r(){return e++,new Promise((function(n){setTimeout((function(){n(t(r))}),Math.min(100*e,1e3))}))}))}function d(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:function(t,e){return Promise.resolve()};return Object.assign(t,{wait:function(r){return d(t.then((function(t){return Promise.all([e(t,r),t])})).then((function(t){return t[1]})))}})}function l(t){for(var e=t.length-1;e>0;e--){var r=Math.floor(Math.random()*(e+1)),n=t[e];t[e]=t[r],t[r]=n}return t}function p(t,e){return e?(Object.keys(e).forEach((function(r){t[r]=e[r](t)})),t):t}function h(t){for(var e=arguments.length,r=new Array(e>1?e-1:0),n=1;n0?n:void 0,timeout:r.timeout||e,headers:r.headers||{},queryParameters:r.queryParameters||{},cacheable:r.cacheable}}var g={Read:1,Write:2,Any:3},v=1,b=2,P=3;function w(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:v;return r(r({},t),{},{status:e,lastUpdate:Date.now()})}function O(t){return\"string\"==typeof t?{protocol:\"https\",url:t,accept:g.Any}:{protocol:t.protocol||\"https\",url:t.url,accept:t.accept||g.Any}}var I=\"DELETE\",x=\"GET\",j=\"POST\",D=\"PUT\";function q(t,e){return Promise.all(e.map((function(e){return t.get(e,(function(){return Promise.resolve(w(e))}))}))).then((function(t){var r=t.filter((function(t){return function(t){return t.status===v||Date.now()-t.lastUpdate>12e4}(t)})),n=t.filter((function(t){return function(t){return t.status===P&&Date.now()-t.lastUpdate<=12e4}(t)})),a=[].concat(o(r),o(n));return{getTimeout:function(t,e){return(0===n.length&&0===t?1:n.length+3+t)*e},statelessHosts:a.length>0?a.map((function(t){return O(t)})):e}}))}function S(t,e,n,a){var i=[],u=function(t,e){if(t.method===x||void 0===t.data&&void 0===e.data)return;var n=Array.isArray(t.data)?t.data:r(r({},t.data),e.data);return JSON.stringify(n)}(n,a),s=function(t,e){var n=r(r({},t.headers),e.headers),a={};return Object.keys(n).forEach((function(t){var e=n[t];a[t.toLowerCase()]=e})),a}(t,a),c=n.method,f=n.method!==x?{}:r(r({},n.data),a.data),d=r(r(r({\"x-algolia-agent\":t.userAgent.value},t.queryParameters),f),a.queryParameters),l=0,p=function e(r,o){var f=r.pop();if(void 0===f)throw{name:\"RetryError\",message:\"Unreachable hosts - your application id may be incorrect. If the error persists, contact support@algolia.com.\",transporterStackTrace:R(i)};var p={data:u,headers:s,method:c,url:N(f,n.path,d),connectTimeout:o(l,t.timeouts.connect),responseTimeout:o(l,a.timeout)},h=function(t){var e={request:p,response:t,host:f,triesLeft:r.length};return i.push(e),e},m={onSuccess:function(t){return function(t){try{return JSON.parse(t.content)}catch(e){throw function(t,e){return{name:\"DeserializationError\",message:t,response:e}}(e.message,t)}}(t)},onRetry:function(n){var a=h(n);return n.isTimedOut&&l++,Promise.all([t.logger.info(\"Retryable failure\",A(a)),t.hostsCache.set(f,w(f,n.isTimedOut?P:b))]).then((function(){return e(r,o)}))},onFail:function(t){throw h(t),function(t,e){var r=t.content,n=t.status,a=r;try{a=JSON.parse(r).message}catch(t){}return function(t,e,r){return{name:\"ApiError\",message:t,status:e,transporterStackTrace:r}}(a,n,e)}(t,R(i))}};return t.requester.send(p).then((function(t){return function(t,e){return function(t){var e=t.status;return t.isTimedOut||function(t){var e=t.isTimedOut,r=t.status;return!e&&0==~~r}(t)||2!=~~(e/100)&&4!=~~(e/100)}(t)?e.onRetry(t):2==~~(t.status/100)?e.onSuccess(t):e.onFail(t)}(t,m)}))};return q(t.hostsCache,e).then((function(t){return p(o(t.statelessHosts).reverse(),t.getTimeout)}))}function k(t){var e=t.hostsCache,r=t.logger,n=t.requester,o=t.requestsCache,i=t.responsesCache,u=t.timeouts,s=t.userAgent,c=t.hosts,f=t.queryParameters,d={hostsCache:e,logger:r,requester:n,requestsCache:o,responsesCache:i,timeouts:u,userAgent:s,headers:t.headers,queryParameters:f,hosts:c.map((function(t){return O(t)})),read:function(t,e){var r=y(e,d.timeouts.read),n=function(){return S(d,d.hosts.filter((function(t){return 0!=(t.accept&g.Read)})),t,r)};if(!0!==(void 0!==r.cacheable?r.cacheable:t.cacheable))return n();var o={request:t,mappedRequestOptions:r,transporter:{queryParameters:d.queryParameters,headers:d.headers}};return d.responsesCache.get(o,(function(){return d.requestsCache.get(o,(function(){return d.requestsCache.set(o,n()).then((function(t){return Promise.all([d.requestsCache.delete(o),t])}),(function(t){return Promise.all([d.requestsCache.delete(o),Promise.reject(t)])})).then((function(t){var e=a(t,2);e[0];return e[1]}))}))}),{miss:function(t){return d.responsesCache.set(o,t)}})},write:function(t,e){return S(d,d.hosts.filter((function(t){return 0!=(t.accept&g.Write)})),t,y(e,d.timeouts.write))}};return d}function T(t){var e={value:\"Algolia for JavaScript (\".concat(t,\")\"),add:function(t){var r=\"; \".concat(t.segment).concat(void 0!==t.version?\" (\".concat(t.version,\")\"):\"\");return-1===e.value.indexOf(r)&&(e.value=\"\".concat(e.value).concat(r)),e}};return e}function N(t,e,r){var n=E(r),a=\"\".concat(t.protocol,\"://\").concat(t.url,\"/\").concat(\"/\"===e.charAt(0)?e.substr(1):e);return n.length&&(a+=\"?\".concat(n)),a}function E(t){return Object.keys(t).map((function(e){return h(\"%s=%s\",e,(r=t[e],\"[object Object]\"===Object.prototype.toString.call(r)||\"[object Array]\"===Object.prototype.toString.call(r)?JSON.stringify(t[e]):t[e]));var r})).join(\"&\")}function R(t){return t.map((function(t){return A(t)}))}function A(t){var e=t.request.headers[\"x-algolia-api-key\"]?{\"x-algolia-api-key\":\"*****\"}:{};return r(r({},t),{},{request:r(r({},t.request),{},{headers:r(r({},t.request.headers),e)})})}var C=function(t){return function(e,r){return t.transporter.write({method:j,path:\"2/abtests\",data:e},r)}},U=function(t){return function(e,r){return t.transporter.write({method:I,path:h(\"2/abtests/%s\",e)},r)}},z=function(t){return function(e,r){return t.transporter.read({method:x,path:h(\"2/abtests/%s\",e)},r)}},J=function(t){return function(e){return t.transporter.read({method:x,path:\"2/abtests\"},e)}},F=function(t){return function(e,r){return t.transporter.write({method:j,path:h(\"2/abtests/%s/stop\",e)},r)}},H=function(t){return function(e){return t.transporter.read({method:x,path:\"1/strategies/personalization\"},e)}},M=function(t){return function(e,r){return t.transporter.write({method:j,path:\"1/strategies/personalization\",data:e},r)}};function K(t){return function e(r){return t.request(r).then((function(n){if(void 0!==t.batch&&t.batch(n.hits),!t.shouldStop(n))return n.cursor?e({cursor:n.cursor}):e({page:(r.page||0)+1})}))}({})}var W=function(t){return function(e,a){var o=a||{},i=o.queryParameters,u=n(o,[\"queryParameters\"]),s=r({acl:e},void 0!==i?{queryParameters:i}:{});return d(t.transporter.write({method:j,path:\"1/keys\",data:s},u),(function(e,r){return f((function(n){return tt(t)(e.key,r).catch((function(t){if(404!==t.status)throw t;return n()}))}))}))}},B=function(t){return function(e,r,n){var a=y(n);return a.queryParameters[\"X-Algolia-User-ID\"]=e,t.transporter.write({method:j,path:\"1/clusters/mapping\",data:{cluster:r}},a)}},Q=function(t){return function(e,r,n){return t.transporter.write({method:j,path:\"1/clusters/mapping/batch\",data:{users:e,cluster:r}},n)}},G=function(t){return function(e,r){return d(t.transporter.write({method:j,path:h(\"/1/dictionaries/%s/batch\",e),data:{clearExistingDictionaryEntries:!0,requests:{action:\"addEntry\",body:[]}}},r),(function(e,r){return jt(t)(e.taskID,r)}))}},L=function(t){return function(e,r,n){return d(t.transporter.write({method:j,path:h(\"1/indexes/%s/operation\",e),data:{operation:\"copy\",destination:r}},n),(function(r,n){return ut(t)(e,{methods:{waitTask:de}}).waitTask(r.taskID,n)}))}},V=function(t){return function(e,n,a){return L(t)(e,n,r(r({},a),{},{scope:[pe.Rules]}))}},_=function(t){return function(e,n,a){return L(t)(e,n,r(r({},a),{},{scope:[pe.Settings]}))}},X=function(t){return function(e,n,a){return L(t)(e,n,r(r({},a),{},{scope:[pe.Synonyms]}))}},Y=function(t){return function(e,r){return e.method===x?t.transporter.read(e,r):t.transporter.write(e,r)}},Z=function(t){return function(e,r){return d(t.transporter.write({method:I,path:h(\"1/keys/%s\",e)},r),(function(r,n){return f((function(r){return tt(t)(e,n).then(r).catch((function(t){if(404!==t.status)throw t}))}))}))}},$=function(t){return function(e,r,n){var a=r.map((function(t){return{action:\"deleteEntry\",body:{objectID:t}}}));return d(t.transporter.write({method:j,path:h(\"/1/dictionaries/%s/batch\",e),data:{clearExistingDictionaryEntries:!1,requests:a}},n),(function(e,r){return jt(t)(e.taskID,r)}))}},tt=function(t){return function(e,r){return t.transporter.read({method:x,path:h(\"1/keys/%s\",e)},r)}},et=function(t){return function(e,r){return t.transporter.read({method:x,path:h(\"1/task/%s\",e.toString())},r)}},rt=function(t){return function(e){return t.transporter.read({method:x,path:\"/1/dictionaries/*/settings\"},e)}},nt=function(t){return function(e){return t.transporter.read({method:x,path:\"1/logs\"},e)}},at=function(t){return function(e){return t.transporter.read({method:x,path:\"1/clusters/mapping/top\"},e)}},ot=function(t){return function(e,r){return t.transporter.read({method:x,path:h(\"1/clusters/mapping/%s\",e)},r)}},it=function(t){return function(e){var r=e||{},a=r.retrieveMappings,o=n(r,[\"retrieveMappings\"]);return!0===a&&(o.getClusters=!0),t.transporter.read({method:x,path:\"1/clusters/mapping/pending\"},o)}},ut=function(t){return function(e){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n={transporter:t.transporter,appId:t.appId,indexName:e};return p(n,r.methods)}},st=function(t){return function(e){return t.transporter.read({method:x,path:\"1/keys\"},e)}},ct=function(t){return function(e){return t.transporter.read({method:x,path:\"1/clusters\"},e)}},ft=function(t){return function(e){return t.transporter.read({method:x,path:\"1/indexes\"},e)}},dt=function(t){return function(e){return t.transporter.read({method:x,path:\"1/clusters/mapping\"},e)}},lt=function(t){return function(e,r,n){return d(t.transporter.write({method:j,path:h(\"1/indexes/%s/operation\",e),data:{operation:\"move\",destination:r}},n),(function(r,n){return ut(t)(e,{methods:{waitTask:de}}).waitTask(r.taskID,n)}))}},pt=function(t){return function(e,r){return d(t.transporter.write({method:j,path:\"1/indexes/*/batch\",data:{requests:e}},r),(function(e,r){return Promise.all(Object.keys(e.taskID).map((function(n){return ut(t)(n,{methods:{waitTask:de}}).waitTask(e.taskID[n],r)})))}))}},ht=function(t){return function(e,r){return t.transporter.read({method:j,path:\"1/indexes/*/objects\",data:{requests:e}},r)}},mt=function(t){return function(e,n){var a=e.map((function(t){return r(r({},t),{},{params:E(t.params||{})})}));return t.transporter.read({method:j,path:\"1/indexes/*/queries\",data:{requests:a},cacheable:!0},n)}},yt=function(t){return function(e,a){return Promise.all(e.map((function(e){var o=e.params,i=o.facetName,u=o.facetQuery,s=n(o,[\"facetName\",\"facetQuery\"]);return ut(t)(e.indexName,{methods:{searchForFacetValues:ue}}).searchForFacetValues(i,u,r(r({},a),s))})))}},gt=function(t){return function(e,r){var n=y(r);return n.queryParameters[\"X-Algolia-User-ID\"]=e,t.transporter.write({method:I,path:\"1/clusters/mapping\"},n)}},vt=function(t){return function(e,r,n){var a=r.map((function(t){return{action:\"addEntry\",body:t}}));return d(t.transporter.write({method:j,path:h(\"/1/dictionaries/%s/batch\",e),data:{clearExistingDictionaryEntries:!0,requests:a}},n),(function(e,r){return jt(t)(e.taskID,r)}))}},bt=function(t){return function(e,r){return d(t.transporter.write({method:j,path:h(\"1/keys/%s/restore\",e)},r),(function(r,n){return f((function(r){return tt(t)(e,n).catch((function(t){if(404!==t.status)throw t;return r()}))}))}))}},Pt=function(t){return function(e,r,n){var a=r.map((function(t){return{action:\"addEntry\",body:t}}));return d(t.transporter.write({method:j,path:h(\"/1/dictionaries/%s/batch\",e),data:{clearExistingDictionaryEntries:!1,requests:a}},n),(function(e,r){return jt(t)(e.taskID,r)}))}},wt=function(t){return function(e,r,n){return t.transporter.read({method:j,path:h(\"/1/dictionaries/%s/search\",e),data:{query:r},cacheable:!0},n)}},Ot=function(t){return function(e,r){return t.transporter.read({method:j,path:\"1/clusters/mapping/search\",data:{query:e}},r)}},It=function(t){return function(e,r){return d(t.transporter.write({method:D,path:\"/1/dictionaries/*/settings\",data:e},r),(function(e,r){return jt(t)(e.taskID,r)}))}},xt=function(t){return function(e,r){var a=Object.assign({},r),o=r||{},i=o.queryParameters,u=n(o,[\"queryParameters\"]),s=i?{queryParameters:i}:{},c=[\"acl\",\"indexes\",\"referers\",\"restrictSources\",\"queryParameters\",\"description\",\"maxQueriesPerIPPerHour\",\"maxHitsPerQuery\"];return d(t.transporter.write({method:D,path:h(\"1/keys/%s\",e),data:s},u),(function(r,n){return f((function(r){return tt(t)(e,n).then((function(t){return function(t){return Object.keys(a).filter((function(t){return-1!==c.indexOf(t)})).every((function(e){return t[e]===a[e]}))}(t)?Promise.resolve():r()}))}))}))}},jt=function(t){return function(e,r){return f((function(n){return et(t)(e,r).then((function(t){return\"published\"!==t.status?n():void 0}))}))}},Dt=function(t){return function(e,r){return d(t.transporter.write({method:j,path:h(\"1/indexes/%s/batch\",t.indexName),data:{requests:e}},r),(function(e,r){return de(t)(e.taskID,r)}))}},qt=function(t){return function(e){return K(r(r({shouldStop:function(t){return void 0===t.cursor}},e),{},{request:function(r){return t.transporter.read({method:j,path:h(\"1/indexes/%s/browse\",t.indexName),data:r},e)}}))}},St=function(t){return function(e){var n=r({hitsPerPage:1e3},e);return K(r(r({shouldStop:function(t){return t.hits.length0&&void 0!==arguments[0]?arguments[0]:0,c=[];for(a=o;a=t.nbPages)throw{name:\"ObjectNotFoundError\",message:\"Object not found.\"};return n()}))}()}},Wt=function(t){return function(e,r){return t.transporter.read({method:x,path:h(\"1/indexes/%s/%s\",t.indexName,e)},r)}},Bt=function(){return function(t,e){for(var r=0,n=Object.entries(t.hits);rr.OPENED&&void 0===n&&(clearTimeout(o),n=a(t.responseTimeout,\"Socket timeout\"))},r.onerror=function(){0===r.status&&(clearTimeout(o),clearTimeout(n),e({content:r.responseText||\"Network request failed\",status:r.status,isTimedOut:!1}))},r.onload=function(){clearTimeout(o),clearTimeout(n),e({content:r.responseText,status:r.status,isTimedOut:!1})},r.send(t.data)}))}},logger:(a=ye,{debug:function(t,e){return he>=a&&console.debug(t,e),Promise.resolve()},info:function(t,e){return me>=a&&console.info(t,e),Promise.resolve()},error:function(t,e){return console.error(t,e),Promise.resolve()}}),responsesCache:s(),requestsCache:s({serializable:!1}),hostsCache:u({caches:[i({key:\"\".concat(\"4.17.0\",\"-\").concat(t)}),s()]}),userAgent:T(\"4.17.0\").add({segment:\"Browser\"})},f=r(r({},o),n),d=function(){return function(t){return function(t){var e=t.region||\"us\",n=c(m.WithinHeaders,t.appId,t.apiKey),a=k(r(r({hosts:[{url:\"personalization.\".concat(e,\".algolia.com\")}]},t),{},{headers:r(r(r({},n.headers()),{\"content-type\":\"application/json\"}),t.headers),queryParameters:r(r({},n.queryParameters()),t.queryParameters)}));return p({appId:t.appId,transporter:a},t.methods)}(r(r(r({},o),t),{},{methods:{getPersonalizationStrategy:H,setPersonalizationStrategy:M}}))}};return function(t){var e=t.appId,n=c(void 0!==t.authMode?t.authMode:m.WithinHeaders,e,t.apiKey),a=k(r(r({hosts:[{url:\"\".concat(e,\"-dsn.algolia.net\"),accept:g.Read},{url:\"\".concat(e,\".algolia.net\"),accept:g.Write}].concat(l([{url:\"\".concat(e,\"-1.algolianet.com\")},{url:\"\".concat(e,\"-2.algolianet.com\")},{url:\"\".concat(e,\"-3.algolianet.com\")}]))},t),{},{headers:r(r(r({},n.headers()),{\"content-type\":\"application/x-www-form-urlencoded\"}),t.headers),queryParameters:r(r({},n.queryParameters()),t.queryParameters)}));return p({transporter:a,appId:e,addAlgoliaAgent:function(t,e){a.userAgent.add({segment:t,version:e})},clearCache:function(){return Promise.all([a.requestsCache.clear(),a.responsesCache.clear()]).then((function(){}))}},t.methods)}(r(r({},f),{},{methods:{search:mt,searchForFacetValues:yt,multipleBatch:pt,multipleGetObjects:ht,multipleQueries:mt,copyIndex:L,copySettings:_,copySynonyms:X,copyRules:V,moveIndex:lt,listIndices:ft,getLogs:nt,listClusters:ct,multipleSearchForFacetValues:yt,getApiKey:tt,addApiKey:W,listApiKeys:st,updateApiKey:xt,deleteApiKey:Z,restoreApiKey:bt,assignUserID:B,assignUserIDs:Q,getUserID:ot,searchUserIDs:Ot,listUserIDs:dt,getTopUserIDs:at,removeUserID:gt,hasPendingMappings:it,clearDictionaryEntries:G,deleteDictionaryEntries:$,getDictionarySettings:rt,getAppTask:et,replaceDictionaryEntries:vt,saveDictionaryEntries:Pt,searchDictionaryEntries:wt,setDictionarySettings:It,waitAppTask:jt,customRequest:Y,initIndex:function(t){return function(e){return ut(t)(e,{methods:{batch:Dt,delete:Ct,findAnswers:Mt,getObject:Wt,getObjects:Qt,saveObject:te,saveObjects:ee,search:ie,searchForFacetValues:ue,waitTask:de,setSettings:fe,getSettings:Lt,partialUpdateObject:_t,partialUpdateObjects:Xt,deleteObject:Ut,deleteObjects:zt,deleteBy:At,clearObjects:Nt,browseObjects:qt,getObjectPosition:Bt,findObject:Kt,exists:Ht,saveSynonym:ae,saveSynonyms:oe,getSynonym:Vt,searchSynonyms:ce,browseSynonyms:kt,deleteSynonym:Ft,clearSynonyms:Rt,replaceAllObjects:Yt,replaceAllSynonyms:$t,searchRules:se,getRule:Gt,deleteRule:Jt,saveRule:re,saveRules:ne,replaceAllRules:Zt,browseRules:St,clearRules:Et}})}},initAnalytics:function(){return function(t){return function(t){var e=t.region||\"us\",n=c(m.WithinHeaders,t.appId,t.apiKey),a=k(r(r({hosts:[{url:\"analytics.\".concat(e,\".algolia.com\")}]},t),{},{headers:r(r(r({},n.headers()),{\"content-type\":\"application/json\"}),t.headers),queryParameters:r(r({},n.queryParameters()),t.queryParameters)}));return p({appId:t.appId,transporter:a},t.methods)}(r(r(r({},o),t),{},{methods:{addABTest:C,getABTest:z,getABTests:J,stopABTest:F,deleteABTest:U}}))}},initPersonalization:d,initRecommendation:function(){return function(t){return f.logger.info(\"The `initRecommendation` method is deprecated. Use `initPersonalization` instead.\"),d()(t)}}}}))}return ge.version=\"4.17.0\",ge}));\n","import { ReactComponent as Go } from \"../icons/go.svg\";\n\nexport const AlgoliaResult = ({ searchTitle, onGo }) => {\n return (\n <>\n \n

{searchTitle}

\n
\n \n
\n \n \n );\n};\n","import { useEffect, useState, useRef } from \"@wordpress/element\";\nimport { __ } from \"@wordpress/i18n\";\n//\nimport { Analytics, InteractionAPIs } from \"../utils\";\n\nconst Feedback = ({ postId }) => {\n const [status, setStatus] = useState(\"\");\n const yesButtonRef = useRef(null);\n const noButtonRef = useRef(null);\n\n const postFeedback = async () => {\n if (status === \"helpful\" || status === \"notHelpful\") {\n InteractionAPIs.postFeedback(postId, status);\n Analytics.sendEvent('feedback', 'status');\n }\n };\n\n useEffect(() => {\n setStatus(\"\");\n noButtonRef.current.className = \"feedback-button no\";\n yesButtonRef.current.className = \"feedback-button yes\";\n }, [postId]);\n\n useEffect(() => {\n postFeedback();\n if (status === \"helpful\") {\n yesButtonRef.current.className = \"feedback-button yes selected-yes\";\n noButtonRef.current.className = \"feedback-button no\";\n }\n if (status === \"notHelpful\") {\n noButtonRef.current.className = \"feedback-button no selected-no\";\n yesButtonRef.current.className = \"feedback-button yes\";\n }\n }, [status]);\n\n return (\n
\n
\n

\n {__('Did this result help you ?', 'wp-module-help-center')}\n

\n
\n
\n {\n setStatus(\"helpful\");\n }}\n class=\"feedback-button yes\"\n >\n {status === \"helpful\" && <>🥳} Yes\n \n {\n setStatus(\"notHelpful\");\n }}\n ref={noButtonRef}\n class=\"feedback-button no\"\n >\n {status === \"notHelpful\" && <>😭} No\n \n
\n
\n );\n};\n\nexport default Feedback;\n","import SearchResults from \"./SearchResults\";\nimport algoliasearch from \"algoliasearch\";\nimport { Configure, Index, InstantSearch } from \"react-instantsearch-hooks-web\";\n\nconst HelpCenter = (props) => {\n // Set up the instant search results\n const searchClient = algoliasearch(\n \"AVE0JWZU92\",\n \"eef54890add97ea2583ff1e417ff86ea\"\n );\n\n return (\n
\n \n \n \n \n \n \n
\n );\n};\n\nexport default HelpCenter;\n","import { ReactComponent as LoaderIcon } from \"../icons/loader.svg\";\n\nconst Loader = () => {\n return (\n <>\n \n \n );\n};\nexport default Loader;\n","import { useEffect } from \"@wordpress/element\";\nimport { __ } from \"@wordpress/i18n\";\n//\nimport { ReactComponent as CloseIcon } from \"../icons/close.svg\";\nimport { ReactComponent as Help } from \"../icons/help.svg\";\nimport HelpCenter from \"./HelpCenter\";\n\nimport { toggleHelp } from \"..\";\nimport { LocalStorageUtils } from \"../utils\";\n\nconst Modal = ({ onClose }) => {\n useEffect(() => {\n const helpVisible = LocalStorageUtils.getHelpVisible();\n toggleHelp(helpVisible);\n }, []);\n\n return (\n
\n
\n

\n \n \n \n {__('Help Center', 'wp-module-help-center')}\n

\n \n
\n \n
\n );\n};\n\nexport default Modal;\n","import { __ } from \"@wordpress/i18n\";\nimport { ReactComponent as NoResultIllustration } from \"../icons/no-result.svg\";\n\nconst NoResults = () => {\n return (\n
\n

{__(\"Result based on your search:\", \"wp-module-help-center\")}

\n

\n {__(\n \"Sorry, we don't have any content for that yet.\",\n \"wp-module-help-center\"\n )}\n

\n
\n \n

\n {__(\n \"This tool is being built and doesn't always have a match.\",\n \"wp-module-help-center\"\n )}\n

\n

\n {__(\"In the meantime, try searching our\", \"wp-module-help-center\")}{\" \"}\n \n {__(\"Resource center.\", \"wp-module-help-center\")}\n \n

\n
\n
\n );\n};\n\nexport default NoResults;\n","import { __ } from \"@wordpress/i18n\";\n//\nimport Feedback from \"./Feedback\";\nimport NoResults from \"./NoResults\";\n\nexport const ResultContent = ({ content, noResult, postId }) => {\n if (noResult) {\n return ;\n }\n\n if (content && content.length > 0) {\n return (\n <>\n

{__('Follow these steps:', 'wp-module-help-center')}

\n

\n {content && content.length > 0 && }\n \n );\n }\n\n return <>;\n};\n","import { debounce } from \"lodash\";\nimport { useEffect, useState, useMemo } from \"@wordpress/element\";\nimport { useInstantSearch, useSearchBox } from \"react-instantsearch-hooks-web\";\nimport moduleAI from \"@newfold-labs/wp-module-ai\";\n//\nimport { ReactComponent as SearchIcon } from \"../icons/search.svg\";\n//\nimport { AlgoliaResult } from \"./AlgoliaResult\";\nimport { ResultContent } from \"./ResultContent\";\nimport { Analytics, LocalStorageUtils } from \"../utils\";\nimport Loader from \"./Loader\";\n\nconst SearchResults = () => {\n const [isLoading, setIsLoading] = useState(false);\n const [noResult, setNoResult] = useState(false);\n const [searchInput, setSearchInput] = useState(\"\");\n const [resultContent, setResultContent] = useState(\"\");\n const [postId, setPostId] = useState();\n const { query, refine, clear } = useSearchBox();\n const { results } = useInstantSearch();\n\n const populateSearchResult = (resultContent, postId, searchInput) => {\n const resultContentFormatted = resultContent.replace(/\\n/g, \"

\");\n setResultContent(resultContentFormatted);\n setPostId(postId);\n LocalStorageUtils.persistResult(resultContentFormatted, postId);\n LocalStorageUtils.persistSearchInput(searchInput);\n Analytics.sendEvent('search', postId);\n };\n\n useEffect(() => {\n // Populate the results from local storage if they exist\n const {\n content: currentResultContent, postId: currentResultPostId\n } = LocalStorageUtils.getResultInfo();\n if (currentResultContent) {\n setResultContent(currentResultContent);\n }\n if (currentResultPostId) {\n setPostId(currentResultPostId);\n }\n\n const input = LocalStorageUtils.getSearchInput();\n if (input) {\n setSearchInput(input);\n refine(input);\n }\n }, []);\n\n const getResultMatches = (proximity, words) => {\n return (proximity / words) >= 0.75;\n }\n\n const getAIResult = async () => {\n setIsLoading(true);\n try {\n // Check if the algolia results are close enough\n const hits = results.hits;\n const resultMatches = hits.length > 0 ? getResultMatches(hits[0]._rankingInfo.proximityDistance, hits[0]._rankingInfo.words) : false;\n if (resultMatches) {\n populateSearchResult(hits[0].content, hits[0].post_id, searchInput);\n return;\n }\n const result = await moduleAI.search.getSearchResult(query, \"helpcenter\");\n populateSearchResult(result[\"result\"], result[\"post_id\"], searchInput);\n } catch (exception) {\n console.log(exception);\n setNoResult(true);\n } finally {\n setIsLoading(false);\n }\n };\n\n const debouncedResults = useMemo(() => {\n return debounce(function (query) {\n if (query && query.length === 0) {\n clear();\n }\n refine(query);\n }, 300);\n }, []);\n\n // Clear any debounce problems\n useEffect(() => {\n debouncedResults.cancel();\n }, []);\n\n if (isLoading) {\n return (\n <>\n \n \n );\n }\n\n return (\n <>\n

\n {\n document.getElementById(\"search-input-box\").focus();\n }}\n >\n \n \n {\n setSearchInput(e.target.value);\n populateSearchResult(\"\", undefined, e.target.value);\n setNoResult(false);\n debouncedResults(e.target.value);\n }}\n onKeyDown={async (e) => {\n if (e.key === \"Enter\") {\n await getAIResult();\n }\n }}\n />\n
\n
\n

\n {searchInput ? searchInput.length : 0}/144\n

\n
\n \n\n {results.hits.length > 0 && (\n

\n \n {resultContent.length > 0\n ? \"Other Resources\"\n : \"Search Suggestions\"}\n \n

\n )}\n {results.hits.map((result) => {\n return (\n <>\n {\n setSearchInput(result.post_title);\n populateSearchResult(result.content, result.post_id, result.post_title);\n }}\n />\n \n );\n })}\n \n );\n};\n\nexport default SearchResults;\n","import { PluginSidebar } from \"@wordpress/edit-post\";\nimport React, { render } from \"@wordpress/element\";\nimport { registerPlugin } from \"@wordpress/plugins\";\nimport { HiiveAnalytics, HiiveEvent } from \"@newfold-labs/js-utility-ui-analytics\";\nimport \"../styles.scss\";\nimport HelpCenter from \"./components/HelpCenter\";\nimport Modal from \"./components/Modal\";\nimport { ReactComponent as Help } from \"./icons/help.svg\";\nimport { Analytics, LocalStorageUtils } from \"./utils\";\n\nHiiveAnalytics.initialize({\n urls: {\n single: window.nfdHelpCenter.restUrl + \"/newfold-data/v1/events\",\n },\n});\n\nconst wpContentContainer = document.getElementById(\"wpcontent\");\n\nexport const toggleHelp = (visible) => {\n wpContentContainer.classList.toggle(\"wpcontent-container\", visible);\n let nfdHelpContainer = document.getElementById(\"nfd-help-center\");\n nfdHelpContainer.classList.toggle(\"help-container\", visible);\n LocalStorageUtils.updateHelpVisible(visible);\n};\n\nwindow.newfoldEmbeddedHelp = {};\nwindow.newfoldEmbeddedHelp.toggleNFDLaunchedEmbeddedHelp = () => {\n const helpVisible = LocalStorageUtils.getHelpVisible();\n if (Object.is(helpVisible, undefined)) {\n toggleHelp(true);\n Analytics.sendEvent(\"page\", \"opened\");\n return;\n }\n toggleHelp(!helpVisible);\n Analytics.sendEvent(\"page\", \"closed\");\n};\n\nwindow.newfoldEmbeddedHelp.toggleNFDUnlaunchedEmbeddedHelp =\n function toggleNFDUnlaunchedEmbeddedHelp() {\n let helpContainer = document.getElementById(\"nfd-help-center\");\n wpContentContainer.removeChild(helpContainer);\n newfoldEmbeddedHelp.renderEmbeddedHelp();\n };\n\n//For rendering embedded help in Add, edit and View Pages\nconst HelpCenterPluginSidebar = () => {\n return (\n }>\n \n \n );\n};\n\nregisterPlugin(\"nfd-help-panel\", {\n render: HelpCenterPluginSidebar,\n});\n\n//For rendering embedded help in Admin Pages\nwindow.newfoldEmbeddedHelp.renderEmbeddedHelp = function renderEmbeddedHelp() {\n let helpContainer = document.createElement(\"div\");\n helpContainer.id = \"nfd-help-center\";\n helpContainer.style.display = \"none\";\n wpContentContainer.appendChild(helpContainer);\n const DOM_TARGET = document.getElementById(\"nfd-help-center\");\n render(\n {\n toggleHelp(false);\n }}\n />,\n DOM_TARGET\n );\n};\n\nnewfoldEmbeddedHelp.renderEmbeddedHelp();\n","import { HiiveAnalytics, HiiveEvent } from \"@newfold-labs/js-utility-ui-analytics\";\nimport apiFetch from \"@wordpress/api-fetch\";\n\nconst base = \"nfd-help-center/v1\";\n\nexport const InteractionAPIs = {\n postFeedback: (postId, status) =>\n apiFetch({\n path: base + \"/feedback\",\n method: \"POST\",\n data: {\n post_id: postId,\n status: status,\n },\n }),\n};\n\n// A wrapper to get and set things more easily\nexport const LocalStorageUtils = {\n updateHelpVisible: (visible) => {\n localStorage.setItem(\"helpVisible\", visible ? \"true\" : \"false\");\n },\n getHelpVisible: () => {\n return localStorage.getItem(\"helpVisible\") === \"true\";\n },\n persistResult: (resultContent, postId) => {\n localStorage.setItem(\"helpResultContent\", resultContent);\n localStorage.setItem(\"helpPostId\", postId);\n },\n persistSearchInput: (searchInput) => {\n localStorage.setItem(\"searchInput\", searchInput);\n },\n getResultInfo: () => {\n return {\n content: localStorage.getItem(\"helpResultContent\"),\n postId: localStorage.getItem(\"helpPostId\")\n };\n },\n getSearchInput: () => {\n return localStorage.getItem(\"searchInput\");\n }\n}\n\nexport const Analytics = {\n sendEvent: (event, data) => {\n const hiiveEvent = new HiiveEvent('nfd-help-center', event, { value: data, time: new Date() });\n HiiveAnalytics.send(hiiveEvent);\n }\n}\n","'use strict';\n\nvar replace = String.prototype.replace;\nvar percentTwenties = /%20/g;\n\nvar Format = {\n RFC1738: 'RFC1738',\n RFC3986: 'RFC3986'\n};\n\nmodule.exports = {\n 'default': Format.RFC3986,\n formatters: {\n RFC1738: function (value) {\n return replace.call(value, percentTwenties, '+');\n },\n RFC3986: function (value) {\n return String(value);\n }\n },\n RFC1738: Format.RFC1738,\n RFC3986: Format.RFC3986\n};\n","'use strict';\n\nvar stringify = require('./stringify');\nvar parse = require('./parse');\nvar formats = require('./formats');\n\nmodule.exports = {\n formats: formats,\n parse: parse,\n stringify: stringify\n};\n","'use strict';\n\nvar utils = require('./utils');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar defaults = {\n allowDots: false,\n allowPrototypes: false,\n arrayLimit: 20,\n charset: 'utf-8',\n charsetSentinel: false,\n comma: false,\n decoder: utils.decode,\n delimiter: '&',\n depth: 5,\n ignoreQueryPrefix: false,\n interpretNumericEntities: false,\n parameterLimit: 1000,\n parseArrays: true,\n plainObjects: false,\n strictNullHandling: false\n};\n\nvar interpretNumericEntities = function (str) {\n return str.replace(/&#(\\d+);/g, function ($0, numberStr) {\n return String.fromCharCode(parseInt(numberStr, 10));\n });\n};\n\nvar parseArrayValue = function (val, options) {\n if (val && typeof val === 'string' && options.comma && val.indexOf(',') > -1) {\n return val.split(',');\n }\n\n return val;\n};\n\n// This is what browsers will submit when the ✓ character occurs in an\n// application/x-www-form-urlencoded body and the encoding of the page containing\n// the form is iso-8859-1, or when the submitted form has an accept-charset\n// attribute of iso-8859-1. Presumably also with other charsets that do not contain\n// the ✓ character, such as us-ascii.\nvar isoSentinel = 'utf8=%26%2310003%3B'; // encodeURIComponent('✓')\n\n// These are the percent-encoded utf-8 octets representing a checkmark, indicating that the request actually is utf-8 encoded.\nvar charsetSentinel = 'utf8=%E2%9C%93'; // encodeURIComponent('✓')\n\nvar parseValues = function parseQueryStringValues(str, options) {\n var obj = {};\n var cleanStr = options.ignoreQueryPrefix ? str.replace(/^\\?/, '') : str;\n var limit = options.parameterLimit === Infinity ? undefined : options.parameterLimit;\n var parts = cleanStr.split(options.delimiter, limit);\n var skipIndex = -1; // Keep track of where the utf8 sentinel was found\n var i;\n\n var charset = options.charset;\n if (options.charsetSentinel) {\n for (i = 0; i < parts.length; ++i) {\n if (parts[i].indexOf('utf8=') === 0) {\n if (parts[i] === charsetSentinel) {\n charset = 'utf-8';\n } else if (parts[i] === isoSentinel) {\n charset = 'iso-8859-1';\n }\n skipIndex = i;\n i = parts.length; // The eslint settings do not allow break;\n }\n }\n }\n\n for (i = 0; i < parts.length; ++i) {\n if (i === skipIndex) {\n continue;\n }\n var part = parts[i];\n\n var bracketEqualsPos = part.indexOf(']=');\n var pos = bracketEqualsPos === -1 ? part.indexOf('=') : bracketEqualsPos + 1;\n\n var key, val;\n if (pos === -1) {\n key = options.decoder(part, defaults.decoder, charset, 'key');\n val = options.strictNullHandling ? null : '';\n } else {\n key = options.decoder(part.slice(0, pos), defaults.decoder, charset, 'key');\n val = utils.maybeMap(\n parseArrayValue(part.slice(pos + 1), options),\n function (encodedVal) {\n return options.decoder(encodedVal, defaults.decoder, charset, 'value');\n }\n );\n }\n\n if (val && options.interpretNumericEntities && charset === 'iso-8859-1') {\n val = interpretNumericEntities(val);\n }\n\n if (part.indexOf('[]=') > -1) {\n val = isArray(val) ? [val] : val;\n }\n\n if (has.call(obj, key)) {\n obj[key] = utils.combine(obj[key], val);\n } else {\n obj[key] = val;\n }\n }\n\n return obj;\n};\n\nvar parseObject = function (chain, val, options, valuesParsed) {\n var leaf = valuesParsed ? val : parseArrayValue(val, options);\n\n for (var i = chain.length - 1; i >= 0; --i) {\n var obj;\n var root = chain[i];\n\n if (root === '[]' && options.parseArrays) {\n obj = [].concat(leaf);\n } else {\n obj = options.plainObjects ? Object.create(null) : {};\n var cleanRoot = root.charAt(0) === '[' && root.charAt(root.length - 1) === ']' ? root.slice(1, -1) : root;\n var index = parseInt(cleanRoot, 10);\n if (!options.parseArrays && cleanRoot === '') {\n obj = { 0: leaf };\n } else if (\n !isNaN(index)\n && root !== cleanRoot\n && String(index) === cleanRoot\n && index >= 0\n && (options.parseArrays && index <= options.arrayLimit)\n ) {\n obj = [];\n obj[index] = leaf;\n } else if (cleanRoot !== '__proto__') {\n obj[cleanRoot] = leaf;\n }\n }\n\n leaf = obj;\n }\n\n return leaf;\n};\n\nvar parseKeys = function parseQueryStringKeys(givenKey, val, options, valuesParsed) {\n if (!givenKey) {\n return;\n }\n\n // Transform dot notation to bracket notation\n var key = options.allowDots ? givenKey.replace(/\\.([^.[]+)/g, '[$1]') : givenKey;\n\n // The regex chunks\n\n var brackets = /(\\[[^[\\]]*])/;\n var child = /(\\[[^[\\]]*])/g;\n\n // Get the parent\n\n var segment = options.depth > 0 && brackets.exec(key);\n var parent = segment ? key.slice(0, segment.index) : key;\n\n // Stash the parent if it exists\n\n var keys = [];\n if (parent) {\n // If we aren't using plain objects, optionally prefix keys that would overwrite object prototype properties\n if (!options.plainObjects && has.call(Object.prototype, parent)) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n\n keys.push(parent);\n }\n\n // Loop through children appending to the array until we hit depth\n\n var i = 0;\n while (options.depth > 0 && (segment = child.exec(key)) !== null && i < options.depth) {\n i += 1;\n if (!options.plainObjects && has.call(Object.prototype, segment[1].slice(1, -1))) {\n if (!options.allowPrototypes) {\n return;\n }\n }\n keys.push(segment[1]);\n }\n\n // If there's a remainder, just add whatever is left\n\n if (segment) {\n keys.push('[' + key.slice(segment.index) + ']');\n }\n\n return parseObject(keys, val, options, valuesParsed);\n};\n\nvar normalizeParseOptions = function normalizeParseOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.decoder !== null && opts.decoder !== undefined && typeof opts.decoder !== 'function') {\n throw new TypeError('Decoder has to be a function.');\n }\n\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n var charset = typeof opts.charset === 'undefined' ? defaults.charset : opts.charset;\n\n return {\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n allowPrototypes: typeof opts.allowPrototypes === 'boolean' ? opts.allowPrototypes : defaults.allowPrototypes,\n arrayLimit: typeof opts.arrayLimit === 'number' ? opts.arrayLimit : defaults.arrayLimit,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n comma: typeof opts.comma === 'boolean' ? opts.comma : defaults.comma,\n decoder: typeof opts.decoder === 'function' ? opts.decoder : defaults.decoder,\n delimiter: typeof opts.delimiter === 'string' || utils.isRegExp(opts.delimiter) ? opts.delimiter : defaults.delimiter,\n // eslint-disable-next-line no-implicit-coercion, no-extra-parens\n depth: (typeof opts.depth === 'number' || opts.depth === false) ? +opts.depth : defaults.depth,\n ignoreQueryPrefix: opts.ignoreQueryPrefix === true,\n interpretNumericEntities: typeof opts.interpretNumericEntities === 'boolean' ? opts.interpretNumericEntities : defaults.interpretNumericEntities,\n parameterLimit: typeof opts.parameterLimit === 'number' ? opts.parameterLimit : defaults.parameterLimit,\n parseArrays: opts.parseArrays !== false,\n plainObjects: typeof opts.plainObjects === 'boolean' ? opts.plainObjects : defaults.plainObjects,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (str, opts) {\n var options = normalizeParseOptions(opts);\n\n if (str === '' || str === null || typeof str === 'undefined') {\n return options.plainObjects ? Object.create(null) : {};\n }\n\n var tempObj = typeof str === 'string' ? parseValues(str, options) : str;\n var obj = options.plainObjects ? Object.create(null) : {};\n\n // Iterate over the keys and setup the new object\n\n var keys = Object.keys(tempObj);\n for (var i = 0; i < keys.length; ++i) {\n var key = keys[i];\n var newObj = parseKeys(key, tempObj[key], options, typeof str === 'string');\n obj = utils.merge(obj, newObj, options);\n }\n\n return utils.compact(obj);\n};\n","'use strict';\n\nvar utils = require('./utils');\nvar formats = require('./formats');\nvar has = Object.prototype.hasOwnProperty;\n\nvar arrayPrefixGenerators = {\n brackets: function brackets(prefix) {\n return prefix + '[]';\n },\n comma: 'comma',\n indices: function indices(prefix, key) {\n return prefix + '[' + key + ']';\n },\n repeat: function repeat(prefix) {\n return prefix;\n }\n};\n\nvar isArray = Array.isArray;\nvar split = String.prototype.split;\nvar push = Array.prototype.push;\nvar pushToArray = function (arr, valueOrArray) {\n push.apply(arr, isArray(valueOrArray) ? valueOrArray : [valueOrArray]);\n};\n\nvar toISO = Date.prototype.toISOString;\n\nvar defaultFormat = formats['default'];\nvar defaults = {\n addQueryPrefix: false,\n allowDots: false,\n charset: 'utf-8',\n charsetSentinel: false,\n delimiter: '&',\n encode: true,\n encoder: utils.encode,\n encodeValuesOnly: false,\n format: defaultFormat,\n formatter: formats.formatters[defaultFormat],\n // deprecated\n indices: false,\n serializeDate: function serializeDate(date) {\n return toISO.call(date);\n },\n skipNulls: false,\n strictNullHandling: false\n};\n\nvar isNonNullishPrimitive = function isNonNullishPrimitive(v) {\n return typeof v === 'string'\n || typeof v === 'number'\n || typeof v === 'boolean'\n || typeof v === 'symbol'\n || typeof v === 'bigint';\n};\n\nvar stringify = function stringify(\n object,\n prefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n format,\n formatter,\n encodeValuesOnly,\n charset\n) {\n var obj = object;\n if (typeof filter === 'function') {\n obj = filter(prefix, obj);\n } else if (obj instanceof Date) {\n obj = serializeDate(obj);\n } else if (generateArrayPrefix === 'comma' && isArray(obj)) {\n obj = utils.maybeMap(obj, function (value) {\n if (value instanceof Date) {\n return serializeDate(value);\n }\n return value;\n });\n }\n\n if (obj === null) {\n if (strictNullHandling) {\n return encoder && !encodeValuesOnly ? encoder(prefix, defaults.encoder, charset, 'key', format) : prefix;\n }\n\n obj = '';\n }\n\n if (isNonNullishPrimitive(obj) || utils.isBuffer(obj)) {\n if (encoder) {\n var keyValue = encodeValuesOnly ? prefix : encoder(prefix, defaults.encoder, charset, 'key', format);\n if (generateArrayPrefix === 'comma' && encodeValuesOnly) {\n var valuesArray = split.call(String(obj), ',');\n var valuesJoined = '';\n for (var i = 0; i < valuesArray.length; ++i) {\n valuesJoined += (i === 0 ? '' : ',') + formatter(encoder(valuesArray[i], defaults.encoder, charset, 'value', format));\n }\n return [formatter(keyValue) + '=' + valuesJoined];\n }\n return [formatter(keyValue) + '=' + formatter(encoder(obj, defaults.encoder, charset, 'value', format))];\n }\n return [formatter(prefix) + '=' + formatter(String(obj))];\n }\n\n var values = [];\n\n if (typeof obj === 'undefined') {\n return values;\n }\n\n var objKeys;\n if (generateArrayPrefix === 'comma' && isArray(obj)) {\n // we need to join elements in\n objKeys = [{ value: obj.length > 0 ? obj.join(',') || null : void undefined }];\n } else if (isArray(filter)) {\n objKeys = filter;\n } else {\n var keys = Object.keys(obj);\n objKeys = sort ? keys.sort(sort) : keys;\n }\n\n for (var j = 0; j < objKeys.length; ++j) {\n var key = objKeys[j];\n var value = typeof key === 'object' && typeof key.value !== 'undefined' ? key.value : obj[key];\n\n if (skipNulls && value === null) {\n continue;\n }\n\n var keyPrefix = isArray(obj)\n ? typeof generateArrayPrefix === 'function' ? generateArrayPrefix(prefix, key) : prefix\n : prefix + (allowDots ? '.' + key : '[' + key + ']');\n\n pushToArray(values, stringify(\n value,\n keyPrefix,\n generateArrayPrefix,\n strictNullHandling,\n skipNulls,\n encoder,\n filter,\n sort,\n allowDots,\n serializeDate,\n format,\n formatter,\n encodeValuesOnly,\n charset\n ));\n }\n\n return values;\n};\n\nvar normalizeStringifyOptions = function normalizeStringifyOptions(opts) {\n if (!opts) {\n return defaults;\n }\n\n if (opts.encoder !== null && typeof opts.encoder !== 'undefined' && typeof opts.encoder !== 'function') {\n throw new TypeError('Encoder has to be a function.');\n }\n\n var charset = opts.charset || defaults.charset;\n if (typeof opts.charset !== 'undefined' && opts.charset !== 'utf-8' && opts.charset !== 'iso-8859-1') {\n throw new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined');\n }\n\n var format = formats['default'];\n if (typeof opts.format !== 'undefined') {\n if (!has.call(formats.formatters, opts.format)) {\n throw new TypeError('Unknown format option provided.');\n }\n format = opts.format;\n }\n var formatter = formats.formatters[format];\n\n var filter = defaults.filter;\n if (typeof opts.filter === 'function' || isArray(opts.filter)) {\n filter = opts.filter;\n }\n\n return {\n addQueryPrefix: typeof opts.addQueryPrefix === 'boolean' ? opts.addQueryPrefix : defaults.addQueryPrefix,\n allowDots: typeof opts.allowDots === 'undefined' ? defaults.allowDots : !!opts.allowDots,\n charset: charset,\n charsetSentinel: typeof opts.charsetSentinel === 'boolean' ? opts.charsetSentinel : defaults.charsetSentinel,\n delimiter: typeof opts.delimiter === 'undefined' ? defaults.delimiter : opts.delimiter,\n encode: typeof opts.encode === 'boolean' ? opts.encode : defaults.encode,\n encoder: typeof opts.encoder === 'function' ? opts.encoder : defaults.encoder,\n encodeValuesOnly: typeof opts.encodeValuesOnly === 'boolean' ? opts.encodeValuesOnly : defaults.encodeValuesOnly,\n filter: filter,\n format: format,\n formatter: formatter,\n serializeDate: typeof opts.serializeDate === 'function' ? opts.serializeDate : defaults.serializeDate,\n skipNulls: typeof opts.skipNulls === 'boolean' ? opts.skipNulls : defaults.skipNulls,\n sort: typeof opts.sort === 'function' ? opts.sort : null,\n strictNullHandling: typeof opts.strictNullHandling === 'boolean' ? opts.strictNullHandling : defaults.strictNullHandling\n };\n};\n\nmodule.exports = function (object, opts) {\n var obj = object;\n var options = normalizeStringifyOptions(opts);\n\n var objKeys;\n var filter;\n\n if (typeof options.filter === 'function') {\n filter = options.filter;\n obj = filter('', obj);\n } else if (isArray(options.filter)) {\n filter = options.filter;\n objKeys = filter;\n }\n\n var keys = [];\n\n if (typeof obj !== 'object' || obj === null) {\n return '';\n }\n\n var arrayFormat;\n if (opts && opts.arrayFormat in arrayPrefixGenerators) {\n arrayFormat = opts.arrayFormat;\n } else if (opts && 'indices' in opts) {\n arrayFormat = opts.indices ? 'indices' : 'repeat';\n } else {\n arrayFormat = 'indices';\n }\n\n var generateArrayPrefix = arrayPrefixGenerators[arrayFormat];\n\n if (!objKeys) {\n objKeys = Object.keys(obj);\n }\n\n if (options.sort) {\n objKeys.sort(options.sort);\n }\n\n for (var i = 0; i < objKeys.length; ++i) {\n var key = objKeys[i];\n\n if (options.skipNulls && obj[key] === null) {\n continue;\n }\n pushToArray(keys, stringify(\n obj[key],\n key,\n generateArrayPrefix,\n options.strictNullHandling,\n options.skipNulls,\n options.encode ? options.encoder : null,\n options.filter,\n options.sort,\n options.allowDots,\n options.serializeDate,\n options.format,\n options.formatter,\n options.encodeValuesOnly,\n options.charset\n ));\n }\n\n var joined = keys.join(options.delimiter);\n var prefix = options.addQueryPrefix === true ? '?' : '';\n\n if (options.charsetSentinel) {\n if (options.charset === 'iso-8859-1') {\n // encodeURIComponent('✓'), the \"numeric entity\" representation of a checkmark\n prefix += 'utf8=%26%2310003%3B&';\n } else {\n // encodeURIComponent('✓')\n prefix += 'utf8=%E2%9C%93&';\n }\n }\n\n return joined.length > 0 ? prefix + joined : '';\n};\n","'use strict';\n\nvar formats = require('./formats');\n\nvar has = Object.prototype.hasOwnProperty;\nvar isArray = Array.isArray;\n\nvar hexTable = (function () {\n var array = [];\n for (var i = 0; i < 256; ++i) {\n array.push('%' + ((i < 16 ? '0' : '') + i.toString(16)).toUpperCase());\n }\n\n return array;\n}());\n\nvar compactQueue = function compactQueue(queue) {\n while (queue.length > 1) {\n var item = queue.pop();\n var obj = item.obj[item.prop];\n\n if (isArray(obj)) {\n var compacted = [];\n\n for (var j = 0; j < obj.length; ++j) {\n if (typeof obj[j] !== 'undefined') {\n compacted.push(obj[j]);\n }\n }\n\n item.obj[item.prop] = compacted;\n }\n }\n};\n\nvar arrayToObject = function arrayToObject(source, options) {\n var obj = options && options.plainObjects ? Object.create(null) : {};\n for (var i = 0; i < source.length; ++i) {\n if (typeof source[i] !== 'undefined') {\n obj[i] = source[i];\n }\n }\n\n return obj;\n};\n\nvar merge = function merge(target, source, options) {\n /* eslint no-param-reassign: 0 */\n if (!source) {\n return target;\n }\n\n if (typeof source !== 'object') {\n if (isArray(target)) {\n target.push(source);\n } else if (target && typeof target === 'object') {\n if ((options && (options.plainObjects || options.allowPrototypes)) || !has.call(Object.prototype, source)) {\n target[source] = true;\n }\n } else {\n return [target, source];\n }\n\n return target;\n }\n\n if (!target || typeof target !== 'object') {\n return [target].concat(source);\n }\n\n var mergeTarget = target;\n if (isArray(target) && !isArray(source)) {\n mergeTarget = arrayToObject(target, options);\n }\n\n if (isArray(target) && isArray(source)) {\n source.forEach(function (item, i) {\n if (has.call(target, i)) {\n var targetItem = target[i];\n if (targetItem && typeof targetItem === 'object' && item && typeof item === 'object') {\n target[i] = merge(targetItem, item, options);\n } else {\n target.push(item);\n }\n } else {\n target[i] = item;\n }\n });\n return target;\n }\n\n return Object.keys(source).reduce(function (acc, key) {\n var value = source[key];\n\n if (has.call(acc, key)) {\n acc[key] = merge(acc[key], value, options);\n } else {\n acc[key] = value;\n }\n return acc;\n }, mergeTarget);\n};\n\nvar assign = function assignSingleSource(target, source) {\n return Object.keys(source).reduce(function (acc, key) {\n acc[key] = source[key];\n return acc;\n }, target);\n};\n\nvar decode = function (str, decoder, charset) {\n var strWithoutPlus = str.replace(/\\+/g, ' ');\n if (charset === 'iso-8859-1') {\n // unescape never throws, no try...catch needed:\n return strWithoutPlus.replace(/%[0-9a-f]{2}/gi, unescape);\n }\n // utf-8\n try {\n return decodeURIComponent(strWithoutPlus);\n } catch (e) {\n return strWithoutPlus;\n }\n};\n\nvar encode = function encode(str, defaultEncoder, charset, kind, format) {\n // This code was originally written by Brian White (mscdex) for the io.js core querystring library.\n // It has been adapted here for stricter adherence to RFC 3986\n if (str.length === 0) {\n return str;\n }\n\n var string = str;\n if (typeof str === 'symbol') {\n string = Symbol.prototype.toString.call(str);\n } else if (typeof str !== 'string') {\n string = String(str);\n }\n\n if (charset === 'iso-8859-1') {\n return escape(string).replace(/%u[0-9a-f]{4}/gi, function ($0) {\n return '%26%23' + parseInt($0.slice(2), 16) + '%3B';\n });\n }\n\n var out = '';\n for (var i = 0; i < string.length; ++i) {\n var c = string.charCodeAt(i);\n\n if (\n c === 0x2D // -\n || c === 0x2E // .\n || c === 0x5F // _\n || c === 0x7E // ~\n || (c >= 0x30 && c <= 0x39) // 0-9\n || (c >= 0x41 && c <= 0x5A) // a-z\n || (c >= 0x61 && c <= 0x7A) // A-Z\n || (format === formats.RFC1738 && (c === 0x28 || c === 0x29)) // ( )\n ) {\n out += string.charAt(i);\n continue;\n }\n\n if (c < 0x80) {\n out = out + hexTable[c];\n continue;\n }\n\n if (c < 0x800) {\n out = out + (hexTable[0xC0 | (c >> 6)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n if (c < 0xD800 || c >= 0xE000) {\n out = out + (hexTable[0xE0 | (c >> 12)] + hexTable[0x80 | ((c >> 6) & 0x3F)] + hexTable[0x80 | (c & 0x3F)]);\n continue;\n }\n\n i += 1;\n c = 0x10000 + (((c & 0x3FF) << 10) | (string.charCodeAt(i) & 0x3FF));\n /* eslint operator-linebreak: [2, \"before\"] */\n out += hexTable[0xF0 | (c >> 18)]\n + hexTable[0x80 | ((c >> 12) & 0x3F)]\n + hexTable[0x80 | ((c >> 6) & 0x3F)]\n + hexTable[0x80 | (c & 0x3F)];\n }\n\n return out;\n};\n\nvar compact = function compact(value) {\n var queue = [{ obj: { o: value }, prop: 'o' }];\n var refs = [];\n\n for (var i = 0; i < queue.length; ++i) {\n var item = queue[i];\n var obj = item.obj[item.prop];\n\n var keys = Object.keys(obj);\n for (var j = 0; j < keys.length; ++j) {\n var key = keys[j];\n var val = obj[key];\n if (typeof val === 'object' && val !== null && refs.indexOf(val) === -1) {\n queue.push({ obj: obj, prop: key });\n refs.push(val);\n }\n }\n }\n\n compactQueue(queue);\n\n return value;\n};\n\nvar isRegExp = function isRegExp(obj) {\n return Object.prototype.toString.call(obj) === '[object RegExp]';\n};\n\nvar isBuffer = function isBuffer(obj) {\n if (!obj || typeof obj !== 'object') {\n return false;\n }\n\n return !!(obj.constructor && obj.constructor.isBuffer && obj.constructor.isBuffer(obj));\n};\n\nvar combine = function combine(a, b) {\n return [].concat(a, b);\n};\n\nvar maybeMap = function maybeMap(val, fn) {\n if (isArray(val)) {\n var mapped = [];\n for (var i = 0; i < val.length; i += 1) {\n mapped.push(fn(val[i]));\n }\n return mapped;\n }\n return fn(val);\n};\n\nmodule.exports = {\n arrayToObject: arrayToObject,\n assign: assign,\n combine: combine,\n compact: compact,\n decode: decode,\n encode: encode,\n isBuffer: isBuffer,\n isRegExp: isRegExp,\n maybeMap: maybeMap,\n merge: merge\n};\n","// extracted by mini-css-extract-plugin\nexport {};","/**\n * @license React\n * use-sync-external-store-shim.development.js\n *\n * Copyright (c) Facebook, Inc. and its affiliates.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nif (process.env.NODE_ENV !== \"production\") {\n (function() {\n\n 'use strict';\n\n/* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\nif (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined' &&\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart ===\n 'function'\n) {\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStart(new Error());\n}\n var React = require('react');\n\nvar ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;\n\nfunction error(format) {\n {\n {\n for (var _len2 = arguments.length, args = new Array(_len2 > 1 ? _len2 - 1 : 0), _key2 = 1; _key2 < _len2; _key2++) {\n args[_key2 - 1] = arguments[_key2];\n }\n\n printWarning('error', format, args);\n }\n }\n}\n\nfunction printWarning(level, format, args) {\n // When changing this logic, you might want to also\n // update consoleWithStackDev.www.js as well.\n {\n var ReactDebugCurrentFrame = ReactSharedInternals.ReactDebugCurrentFrame;\n var stack = ReactDebugCurrentFrame.getStackAddendum();\n\n if (stack !== '') {\n format += '%s';\n args = args.concat([stack]);\n } // eslint-disable-next-line react-internal/safe-string-coercion\n\n\n var argsWithFormat = args.map(function (item) {\n return String(item);\n }); // Careful: RN currently depends on this prefix\n\n argsWithFormat.unshift('Warning: ' + format); // We intentionally don't use spread (or .apply) directly because it\n // breaks IE9: https://github.com/facebook/react/issues/13610\n // eslint-disable-next-line react-internal/no-production-logging\n\n Function.prototype.apply.call(console[level], console, argsWithFormat);\n }\n}\n\n/**\n * inlined Object.is polyfill to avoid requiring consumers ship their own\n * https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\n */\nfunction is(x, y) {\n return x === y && (x !== 0 || 1 / x === 1 / y) || x !== x && y !== y // eslint-disable-line no-self-compare\n ;\n}\n\nvar objectIs = typeof Object.is === 'function' ? Object.is : is;\n\n// dispatch for CommonJS interop named imports.\n\nvar useState = React.useState,\n useEffect = React.useEffect,\n useLayoutEffect = React.useLayoutEffect,\n useDebugValue = React.useDebugValue;\nvar didWarnOld18Alpha = false;\nvar didWarnUncachedGetSnapshot = false; // Disclaimer: This shim breaks many of the rules of React, and only works\n// because of a very particular set of implementation details and assumptions\n// -- change any one of them and it will break. The most important assumption\n// is that updates are always synchronous, because concurrent rendering is\n// only available in versions of React that also have a built-in\n// useSyncExternalStore API. And we only use this shim when the built-in API\n// does not exist.\n//\n// Do not assume that the clever hacks used by this hook also work in general.\n// The point of this shim is to replace the need for hacks by other libraries.\n\nfunction useSyncExternalStore(subscribe, getSnapshot, // Note: The shim does not use getServerSnapshot, because pre-18 versions of\n// React do not expose a way to check if we're hydrating. So users of the shim\n// will need to track that themselves and return the correct value\n// from `getSnapshot`.\ngetServerSnapshot) {\n {\n if (!didWarnOld18Alpha) {\n if (React.startTransition !== undefined) {\n didWarnOld18Alpha = true;\n\n error('You are using an outdated, pre-release alpha of React 18 that ' + 'does not support useSyncExternalStore. The ' + 'use-sync-external-store shim will not work correctly. Upgrade ' + 'to a newer pre-release.');\n }\n }\n } // Read the current snapshot from the store on every render. Again, this\n // breaks the rules of React, and only works here because of specific\n // implementation details, most importantly that updates are\n // always synchronous.\n\n\n var value = getSnapshot();\n\n {\n if (!didWarnUncachedGetSnapshot) {\n var cachedValue = getSnapshot();\n\n if (!objectIs(value, cachedValue)) {\n error('The result of getSnapshot should be cached to avoid an infinite loop');\n\n didWarnUncachedGetSnapshot = true;\n }\n }\n } // Because updates are synchronous, we don't queue them. Instead we force a\n // re-render whenever the subscribed state changes by updating an some\n // arbitrary useState hook. Then, during render, we call getSnapshot to read\n // the current value.\n //\n // Because we don't actually use the state returned by the useState hook, we\n // can save a bit of memory by storing other stuff in that slot.\n //\n // To implement the early bailout, we need to track some things on a mutable\n // object. Usually, we would put that in a useRef hook, but we can stash it in\n // our useState hook instead.\n //\n // To force a re-render, we call forceUpdate({inst}). That works because the\n // new object always fails an equality check.\n\n\n var _useState = useState({\n inst: {\n value: value,\n getSnapshot: getSnapshot\n }\n }),\n inst = _useState[0].inst,\n forceUpdate = _useState[1]; // Track the latest getSnapshot function with a ref. This needs to be updated\n // in the layout phase so we can access it during the tearing check that\n // happens on subscribe.\n\n\n useLayoutEffect(function () {\n inst.value = value;\n inst.getSnapshot = getSnapshot; // Whenever getSnapshot or subscribe changes, we need to check in the\n // commit phase if there was an interleaved mutation. In concurrent mode\n // this can happen all the time, but even in synchronous mode, an earlier\n // effect may have mutated the store.\n\n if (checkIfSnapshotChanged(inst)) {\n // Force a re-render.\n forceUpdate({\n inst: inst\n });\n }\n }, [subscribe, value, getSnapshot]);\n useEffect(function () {\n // Check for changes right before subscribing. Subsequent changes will be\n // detected in the subscription handler.\n if (checkIfSnapshotChanged(inst)) {\n // Force a re-render.\n forceUpdate({\n inst: inst\n });\n }\n\n var handleStoreChange = function () {\n // TODO: Because there is no cross-renderer API for batching updates, it's\n // up to the consumer of this library to wrap their subscription event\n // with unstable_batchedUpdates. Should we try to detect when this isn't\n // the case and print a warning in development?\n // The store changed. Check if the snapshot changed since the last time we\n // read from the store.\n if (checkIfSnapshotChanged(inst)) {\n // Force a re-render.\n forceUpdate({\n inst: inst\n });\n }\n }; // Subscribe to the store and return a clean-up function.\n\n\n return subscribe(handleStoreChange);\n }, [subscribe]);\n useDebugValue(value);\n return value;\n}\n\nfunction checkIfSnapshotChanged(inst) {\n var latestGetSnapshot = inst.getSnapshot;\n var prevValue = inst.value;\n\n try {\n var nextValue = latestGetSnapshot();\n return !objectIs(prevValue, nextValue);\n } catch (error) {\n return true;\n }\n}\n\nfunction useSyncExternalStore$1(subscribe, getSnapshot, getServerSnapshot) {\n // Note: The shim does not use getServerSnapshot, because pre-18 versions of\n // React do not expose a way to check if we're hydrating. So users of the shim\n // will need to track that themselves and return the correct value\n // from `getSnapshot`.\n return getSnapshot();\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && typeof window.document !== 'undefined' && typeof window.document.createElement !== 'undefined');\n\nvar isServerEnvironment = !canUseDOM;\n\nvar shim = isServerEnvironment ? useSyncExternalStore$1 : useSyncExternalStore;\nvar useSyncExternalStore$2 = React.useSyncExternalStore !== undefined ? React.useSyncExternalStore : shim;\n\nexports.useSyncExternalStore = useSyncExternalStore$2;\n /* global __REACT_DEVTOOLS_GLOBAL_HOOK__ */\nif (\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__ !== 'undefined' &&\n typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop ===\n 'function'\n) {\n __REACT_DEVTOOLS_GLOBAL_HOOK__.registerInternalModuleStop(new Error());\n}\n \n })();\n}\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('../cjs/use-sync-external-store-shim.production.min.js');\n} else {\n module.exports = require('../cjs/use-sync-external-store-shim.development.js');\n}\n","module.exports = window[\"React\"];","module.exports = window[\"lodash\"];","module.exports = window[\"wp\"][\"apiFetch\"];","module.exports = window[\"wp\"][\"data\"];","module.exports = window[\"wp\"][\"editPost\"];","module.exports = window[\"wp\"][\"element\"];","module.exports = window[\"wp\"][\"i18n\"];","module.exports = window[\"wp\"][\"plugins\"];","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport algoliasearchHelper from 'algoliasearch-helper';\nimport { createDocumentationMessageGenerator, isPlainObject, mergeSearchParameters, noop } from \"../../lib/utils/index.js\";\nvar withUsage = createDocumentationMessageGenerator({\n name: 'configure',\n connector: true\n});\nfunction getInitialSearchParameters(state, widgetParams) {\n // We leverage the helper internals to remove the `widgetParams` from\n // the state. The function `setQueryParameters` omits the values that\n // are `undefined` on the next state.\n return state.setQueryParameters(Object.keys(widgetParams.searchParameters).reduce(function (acc, key) {\n return _objectSpread(_objectSpread({}, acc), {}, _defineProperty({}, key, undefined));\n }, {}));\n}\nvar connectConfigure = function connectConfigure() {\n var renderFn = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : noop;\n var unmountFn = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;\n return function (widgetParams) {\n if (!widgetParams || !isPlainObject(widgetParams.searchParameters)) {\n throw new Error(withUsage('The `searchParameters` option expects an object.'));\n }\n var connectorState = {};\n function refine(helper) {\n return function (searchParameters) {\n // Merge new `searchParameters` with the ones set from other widgets\n var actualState = getInitialSearchParameters(helper.state, widgetParams);\n var nextSearchParameters = mergeSearchParameters(actualState, new algoliasearchHelper.SearchParameters(searchParameters));\n\n // Update original `widgetParams.searchParameters` to the new refined one\n widgetParams.searchParameters = searchParameters;\n\n // Trigger a search with the resolved search parameters\n helper.setState(nextSearchParameters).search();\n };\n }\n return {\n $$type: 'ais.configure',\n init: function init(initOptions) {\n var instantSearchInstance = initOptions.instantSearchInstance;\n renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(initOptions)), {}, {\n instantSearchInstance: instantSearchInstance\n }), true);\n },\n render: function render(renderOptions) {\n var instantSearchInstance = renderOptions.instantSearchInstance;\n renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(renderOptions)), {}, {\n instantSearchInstance: instantSearchInstance\n }), false);\n },\n dispose: function dispose(_ref) {\n var state = _ref.state;\n unmountFn();\n return getInitialSearchParameters(state, widgetParams);\n },\n getRenderState: function getRenderState(renderState, renderOptions) {\n var _renderState$configur;\n var widgetRenderState = this.getWidgetRenderState(renderOptions);\n return _objectSpread(_objectSpread({}, renderState), {}, {\n configure: _objectSpread(_objectSpread({}, widgetRenderState), {}, {\n widgetParams: _objectSpread(_objectSpread({}, widgetRenderState.widgetParams), {}, {\n searchParameters: mergeSearchParameters(new algoliasearchHelper.SearchParameters((_renderState$configur = renderState.configure) === null || _renderState$configur === void 0 ? void 0 : _renderState$configur.widgetParams.searchParameters), new algoliasearchHelper.SearchParameters(widgetRenderState.widgetParams.searchParameters)).getQueryParams()\n })\n })\n });\n },\n getWidgetRenderState: function getWidgetRenderState(_ref2) {\n var helper = _ref2.helper;\n if (!connectorState.refine) {\n connectorState.refine = refine(helper);\n }\n return {\n refine: connectorState.refine,\n widgetParams: widgetParams\n };\n },\n getWidgetSearchParameters: function getWidgetSearchParameters(state, _ref3) {\n var uiState = _ref3.uiState;\n return mergeSearchParameters(state, new algoliasearchHelper.SearchParameters(_objectSpread(_objectSpread({}, uiState.configure), widgetParams.searchParameters)));\n },\n getWidgetUiState: function getWidgetUiState(uiState) {\n return _objectSpread(_objectSpread({}, uiState), {}, {\n configure: _objectSpread(_objectSpread({}, uiState.configure), widgetParams.searchParameters)\n });\n }\n };\n };\n};\nexport default connectConfigure;","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { checkRendering, createDocumentationMessageGenerator, noop } from \"../../lib/utils/index.js\";\nvar withUsage = createDocumentationMessageGenerator({\n name: 'search-box',\n connector: true\n});\nvar defaultQueryHook = function defaultQueryHook(query, hook) {\n return hook(query);\n};\n\n/**\n * **SearchBox** connector provides the logic to build a widget that will let the user search for a query.\n *\n * The connector provides to the rendering: `refine()` to set the query. The behaviour of this function\n * may be impacted by the `queryHook` widget parameter.\n */\nvar connectSearchBox = function connectSearchBox(renderFn) {\n var unmountFn = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : noop;\n checkRendering(renderFn, withUsage());\n return function (widgetParams) {\n var _ref = widgetParams || {},\n _ref$queryHook = _ref.queryHook,\n queryHook = _ref$queryHook === void 0 ? defaultQueryHook : _ref$queryHook;\n var _refine;\n var _clear;\n return {\n $$type: 'ais.searchBox',\n init: function init(initOptions) {\n var instantSearchInstance = initOptions.instantSearchInstance;\n renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(initOptions)), {}, {\n instantSearchInstance: instantSearchInstance\n }), true);\n },\n render: function render(renderOptions) {\n var instantSearchInstance = renderOptions.instantSearchInstance;\n renderFn(_objectSpread(_objectSpread({}, this.getWidgetRenderState(renderOptions)), {}, {\n instantSearchInstance: instantSearchInstance\n }), false);\n },\n dispose: function dispose(_ref2) {\n var state = _ref2.state;\n unmountFn();\n return state.setQueryParameter('query', undefined);\n },\n getRenderState: function getRenderState(renderState, renderOptions) {\n return _objectSpread(_objectSpread({}, renderState), {}, {\n searchBox: this.getWidgetRenderState(renderOptions)\n });\n },\n getWidgetRenderState: function getWidgetRenderState(_ref3) {\n var helper = _ref3.helper,\n searchMetadata = _ref3.searchMetadata,\n state = _ref3.state;\n if (!_refine) {\n _refine = function _refine(query) {\n queryHook(query, function (q) {\n return helper.setQuery(q).search();\n });\n };\n _clear = function _clear() {\n helper.setQuery('').search();\n };\n }\n return {\n query: state.query || '',\n refine: _refine,\n clear: _clear,\n widgetParams: widgetParams,\n isSearchStalled: searchMetadata.isSearchStalled\n };\n },\n getWidgetUiState: function getWidgetUiState(uiState, _ref4) {\n var searchParameters = _ref4.searchParameters;\n var query = searchParameters.query || '';\n if (query === '' || uiState && uiState.query === query) {\n return uiState;\n }\n return _objectSpread(_objectSpread({}, uiState), {}, {\n query: query\n });\n },\n getWidgetSearchParameters: function getWidgetSearchParameters(searchParameters, _ref5) {\n var uiState = _ref5.uiState;\n return searchParameters.setQueryParameter('query', uiState.query || '');\n }\n };\n };\n};\nexport default connectSearchBox;","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nimport { warning } from \"../lib/utils/index.js\";\nexport var ANONYMOUS_TOKEN_COOKIE_KEY = '_ALGOLIA';\nfunction getCookie(name) {\n if ((typeof document === \"undefined\" ? \"undefined\" : _typeof(document)) !== 'object' || typeof document.cookie !== 'string') {\n return undefined;\n }\n var prefix = \"\".concat(name, \"=\");\n var cookies = document.cookie.split(';');\n for (var i = 0; i < cookies.length; i++) {\n var cookie = cookies[i];\n while (cookie.charAt(0) === ' ') {\n cookie = cookie.substring(1);\n }\n if (cookie.indexOf(prefix) === 0) {\n return cookie.substring(prefix.length, cookie.length);\n }\n }\n return undefined;\n}\nexport function getInsightsAnonymousUserTokenInternal() {\n return getCookie(ANONYMOUS_TOKEN_COOKIE_KEY);\n}\n\n/**\n * @deprecated This function will be still supported in 4.x releases, but not further. It is replaced by the `insights` middleware. For more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/\n */\nexport default function getInsightsAnonymousUserToken() {\n process.env.NODE_ENV === 'development' ? warning(false, \"`getInsightsAnonymousUserToken` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `insights` middleware.\\n\\nFor more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/\") : void 0;\n return getInsightsAnonymousUserTokenInternal();\n}","import { component } from \"../lib/suit.js\";\nimport { getPropertyByPath, TAG_REPLACEMENT, warning } from \"../lib/utils/index.js\";\nvar suit = component('Highlight');\n\n/**\n * @deprecated use html tagged templates and the Highlight component instead\n */\nexport default function highlight(_ref) {\n var attribute = _ref.attribute,\n _ref$highlightedTagNa = _ref.highlightedTagName,\n highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa,\n hit = _ref.hit,\n _ref$cssClasses = _ref.cssClasses,\n cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses;\n process.env.NODE_ENV === 'development' ? warning(false, \"`instantsearch.highlight` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `Highlight` component.\\n\\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates\") : void 0;\n var highlightAttributeResult = getPropertyByPath(hit._highlightResult, attribute);\n\n // @MAJOR fallback to attribute value if highlight is not found\n process.env.NODE_ENV === 'development' ? warning(highlightAttributeResult, \"Could not enable highlight for \\\"\".concat(attribute, \"\\\", will display an empty string.\\nPlease check whether this attribute exists and is either searchable or specified in `attributesToHighlight`.\\n\\nSee: https://alg.li/highlighting\\n\")) : void 0;\n var _ref2 = highlightAttributeResult || {},\n _ref2$value = _ref2.value,\n attributeValue = _ref2$value === void 0 ? '' : _ref2$value;\n\n // cx is not used, since it would be bundled as a dependency for Vue & Angular\n var className = suit({\n descendantName: 'highlighted'\n }) + (cssClasses.highlighted ? \" \".concat(cssClasses.highlighted) : '');\n return attributeValue.replace(new RegExp(TAG_REPLACEMENT.highlightPreTag, 'g'), \"<\".concat(highlightedTagName, \" class=\\\"\").concat(className, \"\\\">\")).replace(new RegExp(TAG_REPLACEMENT.highlightPostTag, 'g'), \"\"));\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nimport { warning, serializePayload, deserializePayload } from \"../lib/utils/index.js\";\n/** @deprecated use bindEvent instead */\nexport function readDataAttributes(domElement) {\n var method = domElement.getAttribute('data-insights-method');\n var serializedPayload = domElement.getAttribute('data-insights-payload');\n if (typeof serializedPayload !== 'string') {\n throw new Error('The insights helper expects `data-insights-payload` to be a base64-encoded JSON string.');\n }\n try {\n var payload = deserializePayload(serializedPayload);\n return {\n method: method,\n payload: payload\n };\n } catch (error) {\n throw new Error('The insights helper was unable to parse `data-insights-payload`.');\n }\n}\n\n/** @deprecated use bindEvent instead */\nexport function writeDataAttributes(_ref) {\n var method = _ref.method,\n payload = _ref.payload;\n if (_typeof(payload) !== 'object') {\n throw new Error(\"The insights helper expects the payload to be an object.\");\n }\n var serializedPayload;\n try {\n serializedPayload = serializePayload(payload);\n } catch (error) {\n throw new Error(\"Could not JSON serialize the payload object.\");\n }\n return \"data-insights-method=\\\"\".concat(method, \"\\\" data-insights-payload=\\\"\").concat(serializedPayload, \"\\\"\");\n}\n\n/**\n * @deprecated This function will be still supported in 4.x releases, but not further. It is replaced by the `insights` middleware. For more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/\n */\nexport default function insights(method, payload) {\n process.env.NODE_ENV === 'development' ? warning(false, \"`insights` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `insights` middleware.\\n\\nFor more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/\") : void 0;\n return writeDataAttributes({\n method: method,\n payload: payload\n });\n}","import { component } from \"../lib/suit.js\";\nimport { TAG_REPLACEMENT, getPropertyByPath, getHighlightedParts, reverseHighlightedParts, concatHighlightedParts, warning } from \"../lib/utils/index.js\";\nvar suit = component('ReverseHighlight');\n\n/**\n * @deprecated use html tagged templates and the ReverseHighlight component instead\n */\nexport default function reverseHighlight(_ref) {\n var attribute = _ref.attribute,\n _ref$highlightedTagNa = _ref.highlightedTagName,\n highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa,\n hit = _ref.hit,\n _ref$cssClasses = _ref.cssClasses,\n cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses;\n process.env.NODE_ENV === 'development' ? warning(false, \"`instantsearch.reverseHighlight` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `ReverseHighlight` component.\\n\\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates\") : void 0;\n var highlightAttributeResult = getPropertyByPath(hit._highlightResult, attribute);\n\n // @MAJOR fallback to attribute value if highlight is not found\n process.env.NODE_ENV === 'development' ? warning(highlightAttributeResult, \"Could not enable reverse highlight for \\\"\".concat(attribute, \"\\\", will display an empty string.\\nPlease check whether this attribute exists and is either searchable or specified in `attributesToHighlight`.\\n\\nSee: https://alg.li/highlighting\\n\")) : void 0;\n var _ref2 = highlightAttributeResult || {},\n _ref2$value = _ref2.value,\n attributeValue = _ref2$value === void 0 ? '' : _ref2$value;\n\n // cx is not used, since it would be bundled as a dependency for Vue & Angular\n var className = suit({\n descendantName: 'highlighted'\n }) + (cssClasses.highlighted ? \" \".concat(cssClasses.highlighted) : '');\n var reverseHighlightedValue = concatHighlightedParts(reverseHighlightedParts(getHighlightedParts(attributeValue)));\n return reverseHighlightedValue.replace(new RegExp(TAG_REPLACEMENT.highlightPreTag, 'g'), \"<\".concat(highlightedTagName, \" class=\\\"\").concat(className, \"\\\">\")).replace(new RegExp(TAG_REPLACEMENT.highlightPostTag, 'g'), \"\"));\n}","import { component } from \"../lib/suit.js\";\nimport { TAG_REPLACEMENT, getPropertyByPath, getHighlightedParts, reverseHighlightedParts, concatHighlightedParts, warning } from \"../lib/utils/index.js\";\nvar suit = component('ReverseSnippet');\n\n/**\n * @deprecated use html tagged templates and the ReverseSnippet component instead\n */\nexport default function reverseSnippet(_ref) {\n var attribute = _ref.attribute,\n _ref$highlightedTagNa = _ref.highlightedTagName,\n highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa,\n hit = _ref.hit,\n _ref$cssClasses = _ref.cssClasses,\n cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses;\n process.env.NODE_ENV === 'development' ? warning(false, \"`instantsearch.reverseSnippet` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `ReverseSnippet` component.\\n\\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates\") : void 0;\n var snippetAttributeResult = getPropertyByPath(hit._snippetResult, attribute);\n\n // @MAJOR fallback to attribute value if snippet is not found\n process.env.NODE_ENV === 'development' ? warning(snippetAttributeResult, \"Could not enable reverse snippet for \\\"\".concat(attribute, \"\\\", will display an empty string.\\nPlease check whether this attribute exists and is specified in `attributesToSnippet`.\\n\\nSee: https://alg.li/highlighting\\n\")) : void 0;\n var _ref2 = snippetAttributeResult || {},\n _ref2$value = _ref2.value,\n attributeValue = _ref2$value === void 0 ? '' : _ref2$value;\n\n // cx is not used, since it would be bundled as a dependency for Vue & Angular\n var className = suit({\n descendantName: 'highlighted'\n }) + (cssClasses.highlighted ? \" \".concat(cssClasses.highlighted) : '');\n var reverseHighlightedValue = concatHighlightedParts(reverseHighlightedParts(getHighlightedParts(attributeValue)));\n return reverseHighlightedValue.replace(new RegExp(TAG_REPLACEMENT.highlightPreTag, 'g'), \"<\".concat(highlightedTagName, \" class=\\\"\").concat(className, \"\\\">\")).replace(new RegExp(TAG_REPLACEMENT.highlightPostTag, 'g'), \"\"));\n}","import { component } from \"../lib/suit.js\";\nimport { TAG_REPLACEMENT, getPropertyByPath, warning } from \"../lib/utils/index.js\";\nvar suit = component('Snippet');\n\n/**\n * @deprecated use html tagged templates and the Snippet component instead\n */\nexport default function snippet(_ref) {\n var attribute = _ref.attribute,\n _ref$highlightedTagNa = _ref.highlightedTagName,\n highlightedTagName = _ref$highlightedTagNa === void 0 ? 'mark' : _ref$highlightedTagNa,\n hit = _ref.hit,\n _ref$cssClasses = _ref.cssClasses,\n cssClasses = _ref$cssClasses === void 0 ? {} : _ref$cssClasses;\n process.env.NODE_ENV === 'development' ? warning(false, \"`instantsearch.snippet` function has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `Snippet` component.\\n\\nFor more information, visit https://www.algolia.com/doc/guides/building-search-ui/upgrade-guides/js/?client=html+tagged+templates#upgrade-templates\") : void 0;\n var snippetAttributeResult = getPropertyByPath(hit._snippetResult, attribute);\n\n // @MAJOR fallback to attribute value if snippet is not found\n process.env.NODE_ENV === 'development' ? warning(snippetAttributeResult, \"Could not enable snippet for \\\"\".concat(attribute, \"\\\", will display an empty string.\\nPlease check whether this attribute exists and is specified in `attributesToSnippet`.\\n\\nSee: https://alg.li/highlighting\\n\")) : void 0;\n var _ref2 = snippetAttributeResult || {},\n _ref2$value = _ref2.value,\n attributeValue = _ref2$value === void 0 ? '' : _ref2$value;\n\n // cx is not used, since it would be bundled as a dependency for Vue & Angular\n var className = suit({\n descendantName: 'highlighted'\n }) + (cssClasses.highlighted ? \" \".concat(cssClasses.highlighted) : '');\n return attributeValue.replace(new RegExp(TAG_REPLACEMENT.highlightPreTag, 'g'), \"<\".concat(highlightedTagName, \" class=\\\"\").concat(className, \"\\\">\")).replace(new RegExp(TAG_REPLACEMENT.highlightPostTag, 'g'), \"\"));\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); Object.defineProperty(subClass, \"prototype\", { writable: false }); if (superClass) _setPrototypeOf(subClass, superClass); }\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\nfunction _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } else if (call !== void 0) { throw new TypeError(\"Derived constructors may only return object or undefined\"); } return _assertThisInitialized(self); }\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\nfunction _isNativeReflectConstruct() { if (typeof Reflect === \"undefined\" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === \"function\") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport EventEmitter from '@algolia/events';\nimport algoliasearchHelper from 'algoliasearch-helper';\nimport { createInsightsMiddleware } from \"../middlewares/createInsightsMiddleware.js\";\nimport { createMetadataMiddleware, isMetadataEnabled } from \"../middlewares/createMetadataMiddleware.js\";\nimport { createRouterMiddleware } from \"../middlewares/createRouterMiddleware.js\";\nimport index from \"../widgets/index/index.js\";\nimport createHelpers from \"./createHelpers.js\";\nimport { createDocumentationMessageGenerator, createDocumentationLink, defer, noop, warning, setIndexHelperState } from \"./utils/index.js\";\nimport version from \"./version.js\";\nvar withUsage = createDocumentationMessageGenerator({\n name: 'instantsearch'\n});\nfunction defaultCreateURL() {\n return '#';\n}\n\n// this purposely breaks typescript's type inference to ensure it's not used\n// as it's used for a default parameter for example\n// source: https://github.com/Microsoft/TypeScript/issues/14829#issuecomment-504042546\n/**\n * The actual implementation of the InstantSearch. This is\n * created using the `instantsearch` factory function.\n * It emits the 'render' event every time a search is done\n */\nvar InstantSearch = /*#__PURE__*/function (_EventEmitter) {\n _inherits(InstantSearch, _EventEmitter);\n var _super = _createSuper(InstantSearch);\n function InstantSearch(options) {\n var _this;\n _classCallCheck(this, InstantSearch);\n _this = _super.call(this);\n\n // prevent `render` event listening from causing a warning\n _defineProperty(_assertThisInitialized(_this), \"client\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"indexName\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"insightsClient\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"onStateChange\", null);\n _defineProperty(_assertThisInitialized(_this), \"helper\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"mainHelper\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"mainIndex\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"started\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"templatesConfig\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"renderState\", {});\n _defineProperty(_assertThisInitialized(_this), \"_stalledSearchDelay\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"_searchStalledTimer\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"_initialUiState\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"_initialResults\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"_createURL\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"_searchFunction\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"_mainHelperSearch\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"middleware\", []);\n _defineProperty(_assertThisInitialized(_this), \"sendEventToInsights\", void 0);\n _defineProperty(_assertThisInitialized(_this), \"status\", 'idle');\n _defineProperty(_assertThisInitialized(_this), \"error\", undefined);\n _defineProperty(_assertThisInitialized(_this), \"scheduleSearch\", defer(function () {\n if (_this.started) {\n _this.mainHelper.search();\n }\n }));\n _defineProperty(_assertThisInitialized(_this), \"scheduleRender\", defer(function () {\n var _this$mainHelper;\n var shouldResetStatus = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;\n if (!((_this$mainHelper = _this.mainHelper) !== null && _this$mainHelper !== void 0 && _this$mainHelper.hasPendingRequests())) {\n clearTimeout(_this._searchStalledTimer);\n _this._searchStalledTimer = null;\n if (shouldResetStatus) {\n _this.status = 'idle';\n _this.error = undefined;\n }\n }\n _this.mainIndex.render({\n instantSearchInstance: _assertThisInitialized(_this)\n });\n _this.emit('render');\n }));\n _defineProperty(_assertThisInitialized(_this), \"onInternalStateChange\", defer(function () {\n var nextUiState = _this.mainIndex.getWidgetUiState({});\n _this.middleware.forEach(function (_ref) {\n var instance = _ref.instance;\n instance.onStateChange({\n uiState: nextUiState\n });\n });\n }));\n _this.setMaxListeners(100);\n var _options$indexName = options.indexName,\n indexName = _options$indexName === void 0 ? null : _options$indexName,\n numberLocale = options.numberLocale,\n _options$initialUiSta = options.initialUiState,\n initialUiState = _options$initialUiSta === void 0 ? {} : _options$initialUiSta,\n _options$routing = options.routing,\n routing = _options$routing === void 0 ? null : _options$routing,\n _options$insights = options.insights,\n insights = _options$insights === void 0 ? false : _options$insights,\n searchFunction = options.searchFunction,\n _options$stalledSearc = options.stalledSearchDelay,\n stalledSearchDelay = _options$stalledSearc === void 0 ? 200 : _options$stalledSearc,\n _options$searchClient = options.searchClient,\n searchClient = _options$searchClient === void 0 ? null : _options$searchClient,\n _options$insightsClie = options.insightsClient,\n insightsClient = _options$insightsClie === void 0 ? null : _options$insightsClie,\n _options$onStateChang = options.onStateChange,\n onStateChange = _options$onStateChang === void 0 ? null : _options$onStateChang;\n if (indexName === null) {\n throw new Error(withUsage('The `indexName` option is required.'));\n }\n if (searchClient === null) {\n throw new Error(withUsage('The `searchClient` option is required.'));\n }\n if (typeof searchClient.search !== 'function') {\n throw new Error(\"The `searchClient` must implement a `search` method.\\n\\nSee: https://www.algolia.com/doc/guides/building-search-ui/going-further/backend-search/in-depth/backend-instantsearch/js/\");\n }\n if (typeof searchClient.addAlgoliaAgent === 'function') {\n searchClient.addAlgoliaAgent(\"instantsearch.js (\".concat(version, \")\"));\n }\n process.env.NODE_ENV === 'development' ? warning(insightsClient === null, \"`insightsClient` property has been deprecated. It is still supported in 4.x releases, but not further. It is replaced by the `insights` middleware.\\n\\nFor more information, visit https://www.algolia.com/doc/guides/getting-insights-and-analytics/search-analytics/click-through-and-conversions/how-to/send-click-and-conversion-events-with-instantsearch/js/\") : void 0;\n if (insightsClient && typeof insightsClient !== 'function') {\n throw new Error(withUsage('The `insightsClient` option should be a function.'));\n }\n process.env.NODE_ENV === 'development' ? warning(!options.searchParameters, \"The `searchParameters` option is deprecated and will not be supported in InstantSearch.js 4.x.\\n\\nYou can replace it with the `configure` widget:\\n\\n```\\nsearch.addWidgets([\\n configure(\".concat(JSON.stringify(options.searchParameters, null, 2), \")\\n]);\\n```\\n\\nSee \").concat(createDocumentationLink({\n name: 'configure'\n }))) : void 0;\n _this.client = searchClient;\n _this.insightsClient = insightsClient;\n _this.indexName = indexName;\n _this.helper = null;\n _this.mainHelper = null;\n _this.mainIndex = index({\n indexName: indexName\n });\n _this.onStateChange = onStateChange;\n _this.started = false;\n _this.templatesConfig = {\n helpers: createHelpers({\n numberLocale: numberLocale\n }),\n compileOptions: {}\n };\n _this._stalledSearchDelay = stalledSearchDelay;\n _this._searchStalledTimer = null;\n _this._createURL = defaultCreateURL;\n _this._initialUiState = initialUiState;\n _this._initialResults = null;\n if (searchFunction) {\n process.env.NODE_ENV === 'development' ? warning(false, \"The `searchFunction` option is deprecated. Use `onStateChange` instead.\") : void 0;\n _this._searchFunction = searchFunction;\n }\n _this.sendEventToInsights = noop;\n if (routing) {\n var routerOptions = typeof routing === 'boolean' ? {} : routing;\n routerOptions.$$internal = true;\n _this.use(createRouterMiddleware(routerOptions));\n }\n\n // This is the default middleware,\n // any user-provided middleware will be added later and override this one.\n if (insights) {\n var insightsOptions = typeof insights === 'boolean' ? {} : insights;\n insightsOptions.$$internal = true;\n _this.use(createInsightsMiddleware(insightsOptions));\n }\n if (isMetadataEnabled()) {\n _this.use(createMetadataMiddleware({\n $$internal: true\n }));\n }\n return _this;\n }\n\n /**\n * Hooks a middleware into the InstantSearch lifecycle.\n */\n _createClass(InstantSearch, [{\n key: \"_isSearchStalled\",\n get:\n /**\n * The status of the search. Can be \"idle\", \"loading\", \"stalled\", or \"error\".\n */\n\n /**\n * The last returned error from the Search API.\n * The error gets cleared when the next valid search response is rendered.\n */\n\n /**\n * @deprecated use `status === 'stalled'` instead\n */\n function get() {\n process.env.NODE_ENV === 'development' ? warning(false, \"`InstantSearch._isSearchStalled` is deprecated and will be removed in InstantSearch.js 5.0.\\n\\nUse `InstantSearch.status === \\\"stalled\\\"` instead.\") : void 0;\n return this.status === 'stalled';\n }\n }, {\n key: \"use\",\n value: function use() {\n var _this2 = this;\n for (var _len = arguments.length, middleware = new Array(_len), _key = 0; _key < _len; _key++) {\n middleware[_key] = arguments[_key];\n }\n var newMiddlewareList = middleware.map(function (fn) {\n var newMiddleware = _objectSpread({\n $$type: '__unknown__',\n $$internal: false,\n subscribe: noop,\n started: noop,\n unsubscribe: noop,\n onStateChange: noop\n }, fn({\n instantSearchInstance: _this2\n }));\n _this2.middleware.push({\n creator: fn,\n instance: newMiddleware\n });\n return newMiddleware;\n });\n\n // If the instance has already started, we directly subscribe the\n // middleware so they're notified of changes.\n if (this.started) {\n newMiddlewareList.forEach(function (m) {\n m.subscribe();\n m.started();\n });\n }\n return this;\n }\n\n /**\n * Removes a middleware from the InstantSearch lifecycle.\n */\n }, {\n key: \"unuse\",\n value: function unuse() {\n for (var _len2 = arguments.length, middlewareToUnuse = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n middlewareToUnuse[_key2] = arguments[_key2];\n }\n this.middleware.filter(function (m) {\n return middlewareToUnuse.includes(m.creator);\n }).forEach(function (m) {\n return m.instance.unsubscribe();\n });\n this.middleware = this.middleware.filter(function (m) {\n return !middlewareToUnuse.includes(m.creator);\n });\n return this;\n }\n\n // @major we shipped with EXPERIMENTAL_use, but have changed that to just `use` now\n }, {\n key: \"EXPERIMENTAL_use\",\n value: function EXPERIMENTAL_use() {\n process.env.NODE_ENV === 'development' ? warning(false, 'The middleware API is now considered stable, so we recommend replacing `EXPERIMENTAL_use` with `use` before upgrading to the next major version.') : void 0;\n return this.use.apply(this, arguments);\n }\n\n /**\n * Adds a widget to the search instance.\n * A widget can be added either before or after InstantSearch has started.\n * @param widget The widget to add to InstantSearch.\n *\n * @deprecated This method will still be supported in 4.x releases, but not further. It is replaced by `addWidgets([widget])`.\n */\n }, {\n key: \"addWidget\",\n value: function addWidget(widget) {\n process.env.NODE_ENV === 'development' ? warning(false, 'addWidget will still be supported in 4.x releases, but not further. It is replaced by `addWidgets([widget])`') : void 0;\n return this.addWidgets([widget]);\n }\n\n /**\n * Adds multiple widgets to the search instance.\n * Widgets can be added either before or after InstantSearch has started.\n * @param widgets The array of widgets to add to InstantSearch.\n */\n }, {\n key: \"addWidgets\",\n value: function addWidgets(widgets) {\n if (!Array.isArray(widgets)) {\n throw new Error(withUsage('The `addWidgets` method expects an array of widgets. Please use `addWidget`.'));\n }\n if (widgets.some(function (widget) {\n return typeof widget.init !== 'function' && typeof widget.render !== 'function';\n })) {\n throw new Error(withUsage('The widget definition expects a `render` and/or an `init` method.'));\n }\n this.mainIndex.addWidgets(widgets);\n return this;\n }\n\n /**\n * Removes a widget from the search instance.\n * @deprecated This method will still be supported in 4.x releases, but not further. It is replaced by `removeWidgets([widget])`\n * @param widget The widget instance to remove from InstantSearch.\n *\n * The widget must implement a `dispose()` method to clear its state.\n */\n }, {\n key: \"removeWidget\",\n value: function removeWidget(widget) {\n process.env.NODE_ENV === 'development' ? warning(false, 'removeWidget will still be supported in 4.x releases, but not further. It is replaced by `removeWidgets([widget])`') : void 0;\n return this.removeWidgets([widget]);\n }\n\n /**\n * Removes multiple widgets from the search instance.\n * @param widgets Array of widgets instances to remove from InstantSearch.\n *\n * The widgets must implement a `dispose()` method to clear their states.\n */\n }, {\n key: \"removeWidgets\",\n value: function removeWidgets(widgets) {\n if (!Array.isArray(widgets)) {\n throw new Error(withUsage('The `removeWidgets` method expects an array of widgets. Please use `removeWidget`.'));\n }\n if (widgets.some(function (widget) {\n return typeof widget.dispose !== 'function';\n })) {\n throw new Error(withUsage('The widget definition expects a `dispose` method.'));\n }\n this.mainIndex.removeWidgets(widgets);\n return this;\n }\n\n /**\n * Ends the initialization of InstantSearch.js and triggers the\n * first search. This method should be called after all widgets have been added\n * to the instance of InstantSearch.js. InstantSearch.js also supports adding and removing\n * widgets after the start as an **EXPERIMENTAL** feature.\n */\n }, {\n key: \"start\",\n value: function start() {\n var _this3 = this;\n if (this.started) {\n throw new Error(withUsage('The `start` method has already been called once.'));\n }\n\n // This Helper is used for the queries, we don't care about its state. The\n // states are managed at the `index` level. We use this Helper to create\n // DerivedHelper scoped into the `index` widgets.\n // In Vue InstantSearch' hydrate, a main helper gets set before start, so\n // we need to respect this helper as a way to keep all listeners correct.\n var mainHelper = this.mainHelper || algoliasearchHelper(this.client, this.indexName);\n mainHelper.search = function () {\n _this3.status = 'loading';\n _this3.scheduleRender(false);\n\n // This solution allows us to keep the exact same API for the users but\n // under the hood, we have a different implementation. It should be\n // completely transparent for the rest of the codebase. Only this module\n // is impacted.\n return mainHelper.searchOnlyWithDerivedHelpers();\n };\n if (this._searchFunction) {\n // this client isn't used to actually search, but required for the helper\n // to not throw errors\n var fakeClient = {\n search: function search() {\n return new Promise(noop);\n }\n };\n this._mainHelperSearch = mainHelper.search.bind(mainHelper);\n mainHelper.search = function () {\n var mainIndexHelper = _this3.mainIndex.getHelper();\n var searchFunctionHelper = algoliasearchHelper(fakeClient, mainIndexHelper.state.index, mainIndexHelper.state);\n searchFunctionHelper.once('search', function (_ref2) {\n var state = _ref2.state;\n mainIndexHelper.overrideStateWithoutTriggeringChangeEvent(state);\n _this3._mainHelperSearch();\n });\n // Forward state changes from `searchFunctionHelper` to `mainIndexHelper`\n searchFunctionHelper.on('change', function (_ref3) {\n var state = _ref3.state;\n mainIndexHelper.setState(state);\n });\n _this3._searchFunction(searchFunctionHelper);\n return mainHelper;\n };\n }\n\n // Only the \"main\" Helper emits the `error` event vs the one for `search`\n // and `results` that are also emitted on the derived one.\n mainHelper.on('error', function (_ref4) {\n var error = _ref4.error;\n if (!(error instanceof Error)) {\n // typescript lies here, error is in some cases { name: string, message: string }\n var err = error;\n error = Object.keys(err).reduce(function (acc, key) {\n acc[key] = err[key];\n return acc;\n }, new Error(err.message));\n }\n // If an error is emitted, it is re-thrown by events. In previous versions\n // we emitted {error}, which is thrown as:\n // \"Uncaught, unspecified \\\"error\\\" event. ([object Object])\"\n // To avoid breaking changes, we make the error available in both\n // `error` and `error.error`\n // @MAJOR emit only error\n error.error = error;\n _this3.error = error;\n _this3.status = 'error';\n _this3.scheduleRender(false);\n\n // This needs to execute last because it throws the error.\n _this3.emit('error', error);\n });\n this.mainHelper = mainHelper;\n this.middleware.forEach(function (_ref5) {\n var instance = _ref5.instance;\n instance.subscribe();\n });\n this.mainIndex.init({\n instantSearchInstance: this,\n parent: null,\n uiState: this._initialUiState\n });\n if (this._initialResults) {\n var originalScheduleSearch = this.scheduleSearch;\n // We don't schedule a first search when initial results are provided\n // because we already have the results to render. This skips the initial\n // network request on the browser on `start`.\n this.scheduleSearch = defer(noop);\n // We also skip the initial network request when widgets are dynamically\n // added in the first tick (that's the case in all the framework-based flavors).\n // When we add a widget to `index`, it calls `scheduleSearch`. We can rely\n // on our `defer` util to restore the original `scheduleSearch` value once\n // widgets are added to hook back to the regular lifecycle.\n defer(function () {\n _this3.scheduleSearch = originalScheduleSearch;\n })();\n }\n // We only schedule a search when widgets have been added before `start()`\n // because there are listeners that can use these results.\n // This is especially useful in framework-based flavors that wait for\n // dynamically-added widgets to trigger a network request. It avoids\n // having to batch this initial network request with the one coming from\n // `addWidgets()`.\n // Later, we could also skip `index()` widgets and widgets that don't read\n // the results, but this is an optimization that has a very low impact for now.\n else if (this.mainIndex.getWidgets().length > 0) {\n this.scheduleSearch();\n }\n\n // Keep the previous reference for legacy purpose, some pattern use\n // the direct Helper access `search.helper` (e.g multi-index).\n this.helper = this.mainIndex.getHelper();\n\n // track we started the search if we add more widgets,\n // to init them directly after add\n this.started = true;\n this.middleware.forEach(function (_ref6) {\n var instance = _ref6.instance;\n instance.started();\n });\n }\n\n /**\n * Removes all widgets without triggering a search afterwards. This is an **EXPERIMENTAL** feature,\n * if you find an issue with it, please\n * [open an issue](https://github.com/algolia/instantsearch.js/issues/new?title=Problem%20with%20dispose).\n * @return {undefined} This method does not return anything\n */\n }, {\n key: \"dispose\",\n value: function dispose() {\n var _this$mainHelper2;\n this.scheduleSearch.cancel();\n this.scheduleRender.cancel();\n clearTimeout(this._searchStalledTimer);\n this.removeWidgets(this.mainIndex.getWidgets());\n this.mainIndex.dispose();\n\n // You can not start an instance two times, therefore a disposed instance\n // needs to set started as false otherwise this can not be restarted at a\n // later point.\n this.started = false;\n\n // The helper needs to be reset to perform the next search from a fresh state.\n // If not reset, it would use the state stored before calling `dispose()`.\n this.removeAllListeners();\n (_this$mainHelper2 = this.mainHelper) === null || _this$mainHelper2 === void 0 ? void 0 : _this$mainHelper2.removeAllListeners();\n this.mainHelper = null;\n this.helper = null;\n this.middleware.forEach(function (_ref7) {\n var instance = _ref7.instance;\n instance.unsubscribe();\n });\n }\n }, {\n key: \"scheduleStalledRender\",\n value: function scheduleStalledRender() {\n var _this4 = this;\n if (!this._searchStalledTimer) {\n this._searchStalledTimer = setTimeout(function () {\n _this4.status = 'stalled';\n _this4.scheduleRender();\n }, this._stalledSearchDelay);\n }\n }\n\n /**\n * Set the UI state and trigger a search.\n * @param uiState The next UI state or a function computing it from the current state\n * @param callOnStateChange private parameter used to know if the method is called from a state change\n */\n }, {\n key: \"setUiState\",\n value: function setUiState(uiState) {\n var _this5 = this;\n var callOnStateChange = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;\n if (!this.mainHelper) {\n throw new Error(withUsage('The `start` method needs to be called before `setUiState`.'));\n }\n\n // We refresh the index UI state to update the local UI state that the\n // main index passes to the function form of `setUiState`.\n this.mainIndex.refreshUiState();\n var nextUiState = typeof uiState === 'function' ? uiState(this.mainIndex.getWidgetUiState({})) : uiState;\n if (this.onStateChange && callOnStateChange) {\n this.onStateChange({\n uiState: nextUiState,\n setUiState: function setUiState(finalUiState) {\n setIndexHelperState(typeof finalUiState === 'function' ? finalUiState(nextUiState) : finalUiState, _this5.mainIndex);\n _this5.scheduleSearch();\n _this5.onInternalStateChange();\n }\n });\n } else {\n setIndexHelperState(nextUiState, this.mainIndex);\n this.scheduleSearch();\n this.onInternalStateChange();\n }\n }\n }, {\n key: \"getUiState\",\n value: function getUiState() {\n if (this.started) {\n // We refresh the index UI state to make sure changes from `refine` are taken in account\n this.mainIndex.refreshUiState();\n }\n return this.mainIndex.getWidgetUiState({});\n }\n }, {\n key: \"createURL\",\n value: function createURL() {\n var nextState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n if (!this.started) {\n throw new Error(withUsage('The `start` method needs to be called before `createURL`.'));\n }\n return this._createURL(nextState);\n }\n }, {\n key: \"refresh\",\n value: function refresh() {\n if (!this.mainHelper) {\n throw new Error(withUsage('The `start` method needs to be called before `refresh`.'));\n }\n this.mainHelper.clearCache().search();\n }\n }]);\n return InstantSearch;\n}(EventEmitter);\nexport default InstantSearch;","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { highlight as _highlight, reverseHighlight as _reverseHighlight, snippet as _snippet, reverseSnippet as _reverseSnippet, insights as _insights } from \"../helpers/index.js\";\nimport { formatNumber as _formatNumber } from \"./formatNumber.js\";\nexport default function hoganHelpers(_ref) {\n var numberLocale = _ref.numberLocale;\n return {\n formatNumber: function formatNumber(value, render) {\n return _formatNumber(Number(render(value)), numberLocale);\n },\n highlight: function highlight(options, render) {\n try {\n var highlightOptions = JSON.parse(options);\n return render(_highlight(_objectSpread(_objectSpread({}, highlightOptions), {}, {\n hit: this\n })));\n } catch (error) {\n throw new Error(\"\\nThe highlight helper expects a JSON object of the format:\\n{ \\\"attribute\\\": \\\"name\\\", \\\"highlightedTagName\\\": \\\"mark\\\" }\");\n }\n },\n reverseHighlight: function reverseHighlight(options, render) {\n try {\n var reverseHighlightOptions = JSON.parse(options);\n return render(_reverseHighlight(_objectSpread(_objectSpread({}, reverseHighlightOptions), {}, {\n hit: this\n })));\n } catch (error) {\n throw new Error(\"\\n The reverseHighlight helper expects a JSON object of the format:\\n { \\\"attribute\\\": \\\"name\\\", \\\"highlightedTagName\\\": \\\"mark\\\" }\");\n }\n },\n snippet: function snippet(options, render) {\n try {\n var snippetOptions = JSON.parse(options);\n return render(_snippet(_objectSpread(_objectSpread({}, snippetOptions), {}, {\n hit: this\n })));\n } catch (error) {\n throw new Error(\"\\nThe snippet helper expects a JSON object of the format:\\n{ \\\"attribute\\\": \\\"name\\\", \\\"highlightedTagName\\\": \\\"mark\\\" }\");\n }\n },\n reverseSnippet: function reverseSnippet(options, render) {\n try {\n var reverseSnippetOptions = JSON.parse(options);\n return render(_reverseSnippet(_objectSpread(_objectSpread({}, reverseSnippetOptions), {}, {\n hit: this\n })));\n } catch (error) {\n throw new Error(\"\\n The reverseSnippet helper expects a JSON object of the format:\\n { \\\"attribute\\\": \\\"name\\\", \\\"highlightedTagName\\\": \\\"mark\\\" }\");\n }\n },\n insights: function insights(options, render) {\n try {\n var _JSON$parse = JSON.parse(options),\n method = _JSON$parse.method,\n payload = _JSON$parse.payload;\n return render(_insights(method, _objectSpread({\n objectIDs: [this.objectID]\n }, payload)));\n } catch (error) {\n throw new Error(\"\\nThe insights helper expects a JSON object of the format:\\n{ \\\"method\\\": \\\"method-name\\\", \\\"payload\\\": { \\\"eventName\\\": \\\"name of the event\\\" } }\");\n }\n }\n };\n}","export function formatNumber(value, numberLocale) {\n return value.toLocaleString(numberLocale);\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\nfunction _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if (\"value\" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, \"prototype\", { writable: false }); return Constructor; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport qs from 'qs';\nimport { safelyRunOnBrowser } from \"../utils/index.js\";\nvar setWindowTitle = function setWindowTitle(title) {\n if (title) {\n // This function is only executed on browsers so we can disable this check.\n // eslint-disable-next-line no-restricted-globals\n window.document.title = title;\n }\n};\nvar BrowserHistory = /*#__PURE__*/function () {\n /**\n * Initializes a new storage provider that syncs the search state to the URL\n * using web APIs (`window.location.pushState` and `onpopstate` event).\n */\n function BrowserHistory(_ref) {\n var _this = this;\n var windowTitle = _ref.windowTitle,\n _ref$writeDelay = _ref.writeDelay,\n writeDelay = _ref$writeDelay === void 0 ? 400 : _ref$writeDelay,\n createURL = _ref.createURL,\n parseURL = _ref.parseURL,\n getLocation = _ref.getLocation,\n start = _ref.start,\n dispose = _ref.dispose,\n push = _ref.push;\n _classCallCheck(this, BrowserHistory);\n _defineProperty(this, \"$$type\", 'ais.browser');\n _defineProperty(this, \"windowTitle\", void 0);\n _defineProperty(this, \"writeDelay\", void 0);\n _defineProperty(this, \"_createURL\", void 0);\n _defineProperty(this, \"parseURL\", void 0);\n _defineProperty(this, \"getLocation\", void 0);\n _defineProperty(this, \"writeTimer\", void 0);\n _defineProperty(this, \"inPopState\", false);\n _defineProperty(this, \"isDisposed\", false);\n _defineProperty(this, \"latestAcknowledgedHistory\", 0);\n _defineProperty(this, \"_start\", void 0);\n _defineProperty(this, \"_dispose\", void 0);\n _defineProperty(this, \"_push\", void 0);\n this.windowTitle = windowTitle;\n this.writeTimer = undefined;\n this.writeDelay = writeDelay;\n this._createURL = createURL;\n this.parseURL = parseURL;\n this.getLocation = getLocation;\n this._start = start;\n this._dispose = dispose;\n this._push = push;\n safelyRunOnBrowser(function (_ref2) {\n var window = _ref2.window;\n var title = _this.windowTitle && _this.windowTitle(_this.read());\n setWindowTitle(title);\n _this.latestAcknowledgedHistory = window.history.length;\n });\n }\n\n /**\n * Reads the URL and returns a syncable UI search state.\n */\n _createClass(BrowserHistory, [{\n key: \"read\",\n value: function read() {\n return this.parseURL({\n qsModule: qs,\n location: this.getLocation()\n });\n }\n\n /**\n * Pushes a search state into the URL.\n */\n }, {\n key: \"write\",\n value: function write(routeState) {\n var _this2 = this;\n safelyRunOnBrowser(function (_ref3) {\n var window = _ref3.window;\n var url = _this2.createURL(routeState);\n var title = _this2.windowTitle && _this2.windowTitle(routeState);\n if (_this2.writeTimer) {\n clearTimeout(_this2.writeTimer);\n }\n _this2.writeTimer = setTimeout(function () {\n setWindowTitle(title);\n if (_this2.shouldWrite(url)) {\n if (_this2._push) {\n _this2._push(url);\n } else {\n window.history.pushState(routeState, title || '', url);\n }\n _this2.latestAcknowledgedHistory = window.history.length;\n }\n _this2.inPopState = false;\n _this2.writeTimer = undefined;\n }, _this2.writeDelay);\n });\n }\n\n /**\n * Sets a callback on the `onpopstate` event of the history API of the current page.\n * It enables the URL sync to keep track of the changes.\n */\n }, {\n key: \"onUpdate\",\n value: function onUpdate(callback) {\n var _this3 = this;\n if (this._start) {\n this._start(function () {\n callback(_this3.read());\n });\n }\n this._onPopState = function () {\n if (_this3.writeTimer) {\n clearTimeout(_this3.writeTimer);\n _this3.writeTimer = undefined;\n }\n _this3.inPopState = true;\n\n // We always read the state from the URL because the state of the history\n // can be incorect in some cases (e.g. using React Router).\n callback(_this3.read());\n };\n safelyRunOnBrowser(function (_ref4) {\n var window = _ref4.window;\n window.addEventListener('popstate', _this3._onPopState);\n });\n }\n\n /**\n * Creates a complete URL from a given syncable UI state.\n *\n * It always generates the full URL, not a relative one.\n * This allows to handle cases like using a .\n * See: https://github.com/algolia/instantsearch.js/issues/790\n */\n }, {\n key: \"createURL\",\n value: function createURL(routeState) {\n return this._createURL({\n qsModule: qs,\n routeState: routeState,\n location: this.getLocation()\n });\n }\n\n /**\n * Removes the event listener and cleans up the URL.\n */\n }, {\n key: \"dispose\",\n value: function dispose() {\n var _this4 = this;\n if (this._dispose) {\n this._dispose();\n }\n this.isDisposed = true;\n safelyRunOnBrowser(function (_ref5) {\n var window = _ref5.window;\n if (_this4._onPopState) {\n window.removeEventListener('popstate', _this4._onPopState);\n }\n });\n if (this.writeTimer) {\n clearTimeout(this.writeTimer);\n }\n this.write({});\n }\n }, {\n key: \"start\",\n value: function start() {\n this.isDisposed = false;\n }\n }, {\n key: \"shouldWrite\",\n value: function shouldWrite(url) {\n var _this5 = this;\n return safelyRunOnBrowser(function (_ref6) {\n var window = _ref6.window;\n // We do want to `pushState` if:\n // - the router is not disposed, IS.js needs to update the URL\n // OR\n // - the last write was from InstantSearch.js\n // (unlike a SPA, where it would have last written)\n var lastPushWasByISAfterDispose = !(_this5.isDisposed && _this5.latestAcknowledgedHistory !== window.history.length);\n return (\n // When the last state change was through popstate, the IS.js state changes,\n // but that should not write the URL.\n !_this5.inPopState &&\n // When the previous pushState after dispose was by IS.js, we want to write the URL.\n lastPushWasByISAfterDispose &&\n // When the URL is the same as the current one, we do not want to write it.\n url !== window.location.href\n );\n });\n }\n }]);\n return BrowserHistory;\n}();\nexport default function historyRouter() {\n var _ref7 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n _ref7$createURL = _ref7.createURL,\n createURL = _ref7$createURL === void 0 ? function (_ref8) {\n var qsModule = _ref8.qsModule,\n routeState = _ref8.routeState,\n location = _ref8.location;\n var protocol = location.protocol,\n hostname = location.hostname,\n _location$port = location.port,\n port = _location$port === void 0 ? '' : _location$port,\n pathname = location.pathname,\n hash = location.hash;\n var queryString = qsModule.stringify(routeState);\n var portWithPrefix = port === '' ? '' : \":\".concat(port);\n\n // IE <= 11 has no proper `location.origin` so we cannot rely on it.\n if (!queryString) {\n return \"\".concat(protocol, \"//\").concat(hostname).concat(portWithPrefix).concat(pathname).concat(hash);\n }\n return \"\".concat(protocol, \"//\").concat(hostname).concat(portWithPrefix).concat(pathname, \"?\").concat(queryString).concat(hash);\n } : _ref7$createURL,\n _ref7$parseURL = _ref7.parseURL,\n parseURL = _ref7$parseURL === void 0 ? function (_ref9) {\n var qsModule = _ref9.qsModule,\n location = _ref9.location;\n // `qs` by default converts arrays with more than 20 items to an object.\n // We want to avoid this because the data structure manipulated can therefore vary.\n // Setting the limit to `100` seems a good number because the engine's default is 100\n // (it can go up to 1000 but it is very unlikely to select more than 100 items in the UI).\n //\n // Using an `arrayLimit` of `n` allows `n + 1` items.\n //\n // See:\n // - https://github.com/ljharb/qs#parsing-arrays\n // - https://www.algolia.com/doc/api-reference/api-parameters/maxValuesPerFacet/\n return qsModule.parse(location.search.slice(1), {\n arrayLimit: 99\n });\n } : _ref7$parseURL,\n _ref7$writeDelay = _ref7.writeDelay,\n writeDelay = _ref7$writeDelay === void 0 ? 400 : _ref7$writeDelay,\n windowTitle = _ref7.windowTitle,\n _ref7$getLocation = _ref7.getLocation,\n getLocation = _ref7$getLocation === void 0 ? function () {\n return safelyRunOnBrowser(function (_ref10) {\n var window = _ref10.window;\n return window.location;\n }, {\n fallback: function fallback() {\n throw new Error('You need to provide `getLocation` to the `history` router in environments where `window` does not exist.');\n }\n });\n } : _ref7$getLocation,\n start = _ref7.start,\n dispose = _ref7.dispose,\n push = _ref7.push;\n return new BrowserHistory({\n createURL: createURL,\n parseURL: parseURL,\n writeDelay: writeDelay,\n windowTitle: windowTitle,\n getLocation: getLocation,\n start: start,\n dispose: dispose,\n push: push\n });\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar _excluded = [\"configure\"];\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nfunction getIndexStateWithoutConfigure(uiState) {\n var configure = uiState.configure,\n trackedUiState = _objectWithoutProperties(uiState, _excluded);\n return trackedUiState;\n}\n\n// technically a URL could contain any key, since users provide it,\n// which is why the input to this function is UiState, not something\n// which excludes \"configure\" as this function does.\nexport default function simpleStateMapping() {\n return {\n $$type: 'ais.simple',\n stateToRoute: function stateToRoute(uiState) {\n return Object.keys(uiState).reduce(function (state, indexId) {\n return _objectSpread(_objectSpread({}, state), {}, _defineProperty({}, indexId, getIndexStateWithoutConfigure(uiState[indexId])));\n }, {});\n },\n routeToState: function routeToState() {\n var routeState = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n return Object.keys(routeState).reduce(function (state, indexId) {\n return _objectSpread(_objectSpread({}, state), {}, _defineProperty({}, indexId, getIndexStateWithoutConfigure(routeState[indexId])));\n }, {});\n }\n };\n}","var NAMESPACE = 'ais';\nexport var component = function component(componentName) {\n return function () {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n descendantName = _ref.descendantName,\n modifierName = _ref.modifierName;\n var descendent = descendantName ? \"-\".concat(descendantName) : '';\n var modifier = modifierName ? \"--\".concat(modifierName) : '';\n return \"\".concat(NAMESPACE, \"-\").concat(componentName).concat(descendent).concat(modifier);\n };\n};","export function capitalize(text) {\n return text.toString().charAt(0).toUpperCase() + text.toString().slice(1);\n}","function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { capitalize } from \"./capitalize.js\";\nimport { warning } from \"./logger.js\";\nimport { keys } from \"./typedObject.js\";\n// Some connectors are responsible for multiple widgets so we need\n// to map them.\nfunction getWidgetNames(connectorName) {\n switch (connectorName) {\n case 'range':\n return [];\n case 'menu':\n return ['menu', 'menuSelect'];\n default:\n return [connectorName];\n }\n}\nvar stateToWidgetsMap = {\n query: {\n connectors: ['connectSearchBox'],\n widgets: ['ais.searchBox', 'ais.autocomplete', 'ais.voiceSearch']\n },\n refinementList: {\n connectors: ['connectRefinementList'],\n widgets: ['ais.refinementList']\n },\n menu: {\n connectors: ['connectMenu'],\n widgets: ['ais.menu']\n },\n hierarchicalMenu: {\n connectors: ['connectHierarchicalMenu'],\n widgets: ['ais.hierarchicalMenu']\n },\n numericMenu: {\n connectors: ['connectNumericMenu'],\n widgets: ['ais.numericMenu']\n },\n ratingMenu: {\n connectors: ['connectRatingMenu'],\n widgets: ['ais.ratingMenu']\n },\n range: {\n connectors: ['connectRange'],\n widgets: ['ais.rangeInput', 'ais.rangeSlider', 'ais.range']\n },\n toggle: {\n connectors: ['connectToggleRefinement'],\n widgets: ['ais.toggleRefinement']\n },\n geoSearch: {\n connectors: ['connectGeoSearch'],\n widgets: ['ais.geoSearch']\n },\n sortBy: {\n connectors: ['connectSortBy'],\n widgets: ['ais.sortBy']\n },\n page: {\n connectors: ['connectPagination'],\n widgets: ['ais.pagination', 'ais.infiniteHits']\n },\n hitsPerPage: {\n connectors: ['connectHitsPerPage'],\n widgets: ['ais.hitsPerPage']\n },\n configure: {\n connectors: ['connectConfigure'],\n widgets: ['ais.configure']\n },\n places: {\n connectors: [],\n widgets: ['ais.places']\n }\n};\nexport function checkIndexUiState(_ref) {\n var index = _ref.index,\n indexUiState = _ref.indexUiState;\n var mountedWidgets = index.getWidgets().map(function (widget) {\n return widget.$$type;\n }).filter(Boolean);\n var missingWidgets = keys(indexUiState).reduce(function (acc, parameter) {\n var widgetUiState = stateToWidgetsMap[parameter];\n if (!widgetUiState) {\n return acc;\n }\n var requiredWidgets = widgetUiState.widgets;\n if (requiredWidgets && !requiredWidgets.some(function (requiredWidget) {\n return mountedWidgets.includes(requiredWidget);\n })) {\n acc.push([parameter, {\n connectors: widgetUiState.connectors,\n widgets: widgetUiState.widgets.map(function (widgetIdentifier) {\n return widgetIdentifier.split('ais.')[1];\n })\n }]);\n }\n return acc;\n }, []);\n process.env.NODE_ENV === 'development' ? warning(missingWidgets.length === 0, \"The UI state for the index \\\"\".concat(index.getIndexId(), \"\\\" is not consistent with the widgets mounted.\\n\\nThis can happen when the UI state is specified via `initialUiState`, `routing` or `setUiState` but that the widgets responsible for this state were not added. This results in those query parameters not being sent to the API.\\n\\nTo fully reflect the state, some widgets need to be added to the index \\\"\").concat(index.getIndexId(), \"\\\":\\n\\n\").concat(missingWidgets.map(function (_ref2) {\n var _ref4;\n var _ref3 = _slicedToArray(_ref2, 2),\n stateParameter = _ref3[0],\n widgets = _ref3[1].widgets;\n return \"- `\".concat(stateParameter, \"` needs one of these widgets: \").concat((_ref4 = []).concat.apply(_ref4, _toConsumableArray(widgets.map(function (name) {\n return getWidgetNames(name);\n }))).map(function (name) {\n return \"\\\"\".concat(name, \"\\\"\");\n }).join(', '));\n }).join('\\n'), \"\\n\\nIf you do not wish to display widgets but still want to support their search parameters, you can mount \\\"virtual widgets\\\" that don't render anything:\\n\\n```\\n\").concat(missingWidgets.filter(function (_ref5) {\n var _ref6 = _slicedToArray(_ref5, 2),\n _stateParameter = _ref6[0],\n connectors = _ref6[1].connectors;\n return connectors.length > 0;\n }).map(function (_ref7) {\n var _ref8 = _slicedToArray(_ref7, 2),\n _stateParameter = _ref8[0],\n _ref8$ = _ref8[1],\n connectors = _ref8$.connectors,\n widgets = _ref8$.widgets;\n var capitalizedWidget = capitalize(widgets[0]);\n var connectorName = connectors[0];\n return \"const virtual\".concat(capitalizedWidget, \" = \").concat(connectorName, \"(() => null);\");\n }).join('\\n'), \"\\n\\nsearch.addWidgets([\\n \").concat(missingWidgets.filter(function (_ref9) {\n var _ref10 = _slicedToArray(_ref9, 2),\n _stateParameter = _ref10[0],\n connectors = _ref10[1].connectors;\n return connectors.length > 0;\n }).map(function (_ref11) {\n var _ref12 = _slicedToArray(_ref11, 2),\n _stateParameter = _ref12[0],\n widgets = _ref12[1].widgets;\n var capitalizedWidget = capitalize(widgets[0]);\n return \"virtual\".concat(capitalizedWidget, \"({ /* ... */ })\");\n }).join(',\\n '), \"\\n]);\\n```\\n\\nIf you're using custom widgets that do set these query parameters, we recommend using connectors instead.\\n\\nSee https://www.algolia.com/doc/guides/building-search-ui/widgets/customize-an-existing-widget/js/#customize-the-complete-ui-of-the-widgets\")) : void 0;\n}","import { getObjectType } from \"./getObjectType.js\";\nexport function checkRendering(rendering, usage) {\n if (rendering === undefined || typeof rendering !== 'function') {\n throw new Error(\"The render function is not valid (received type \".concat(getObjectType(rendering), \").\\n\\n\").concat(usage));\n }\n}","import { TAG_REPLACEMENT } from \"./escape-highlight.js\";\nexport function concatHighlightedParts(parts) {\n var highlightPreTag = TAG_REPLACEMENT.highlightPreTag,\n highlightPostTag = TAG_REPLACEMENT.highlightPostTag;\n return parts.map(function (part) {\n return part.isHighlighted ? highlightPreTag + part.value + highlightPostTag : part.value;\n }).join('');\n}","var nextMicroTask = Promise.resolve();\nexport function defer(callback) {\n var progress = null;\n var cancelled = false;\n var fn = function fn() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n if (progress !== null) {\n return;\n }\n progress = nextMicroTask.then(function () {\n progress = null;\n if (cancelled) {\n cancelled = false;\n return;\n }\n callback.apply(void 0, args);\n });\n };\n fn.wait = function () {\n if (progress === null) {\n throw new Error('The deferred function should be called before calling `wait()`');\n }\n return progress;\n };\n fn.cancel = function () {\n if (progress === null) {\n return;\n }\n cancelled = true;\n };\n return fn;\n}","export function createDocumentationLink(_ref) {\n var name = _ref.name,\n _ref$connector = _ref.connector,\n connector = _ref$connector === void 0 ? false : _ref$connector;\n return ['https://www.algolia.com/doc/api-reference/widgets/', name, '/js/', connector ? '#connector' : ''].join('');\n}\nexport function createDocumentationMessageGenerator() {\n for (var _len = arguments.length, widgets = new Array(_len), _key = 0; _key < _len; _key++) {\n widgets[_key] = arguments[_key];\n }\n var links = widgets.map(function (widget) {\n return createDocumentationLink(widget);\n }).join(', ');\n return function (message) {\n return [message, \"See documentation: \".concat(links)].filter(Boolean).join('\\n\\n');\n };\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction _objectDestructuringEmpty(obj) { if (obj == null) throw new TypeError(\"Cannot destructure \" + obj); }\nfunction _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { escape } from \"./escape-html.js\";\nimport { isPlainObject } from \"./isPlainObject.js\";\nexport var TAG_PLACEHOLDER = {\n highlightPreTag: '__ais-highlight__',\n highlightPostTag: '__/ais-highlight__'\n};\nexport var TAG_REPLACEMENT = {\n highlightPreTag: '',\n highlightPostTag: ''\n};\nfunction replaceTagsAndEscape(value) {\n return escape(value).replace(new RegExp(TAG_PLACEHOLDER.highlightPreTag, 'g'), TAG_REPLACEMENT.highlightPreTag).replace(new RegExp(TAG_PLACEHOLDER.highlightPostTag, 'g'), TAG_REPLACEMENT.highlightPostTag);\n}\nfunction recursiveEscape(input) {\n if (isPlainObject(input) && typeof input.value !== 'string') {\n return Object.keys(input).reduce(function (acc, key) {\n return _objectSpread(_objectSpread({}, acc), {}, _defineProperty({}, key, recursiveEscape(input[key])));\n }, {});\n }\n if (Array.isArray(input)) {\n return input.map(recursiveEscape);\n }\n return _objectSpread(_objectSpread({}, input), {}, {\n value: replaceTagsAndEscape(input.value)\n });\n}\nexport function escapeHits(hits) {\n if (hits.__escaped === undefined) {\n // We don't override the value on hit because it will mutate the raw results\n // instead we make a shallow copy and we assign the escaped values on it.\n hits = hits.map(function (_ref) {\n var hit = _extends({}, (_objectDestructuringEmpty(_ref), _ref));\n if (hit._highlightResult) {\n hit._highlightResult = recursiveEscape(hit._highlightResult);\n }\n if (hit._snippetResult) {\n hit._snippetResult = recursiveEscape(hit._snippetResult);\n }\n return hit;\n });\n hits.__escaped = true;\n }\n return hits;\n}\nexport function escapeFacets(facetHits) {\n return facetHits.map(function (h) {\n return _objectSpread(_objectSpread({}, h), {}, {\n highlighted: replaceTagsAndEscape(h.highlighted)\n });\n });\n}","/**\n * This implementation is taken from Lodash implementation.\n * See: https://github.com/lodash/lodash/blob/4.17.11-npm/escape.js\n */\n\n// Used to map characters to HTML entities.\nvar htmlEntities = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": '''\n};\n\n// Used to match HTML entities and HTML characters.\nvar regexUnescapedHtml = /[&<>\"']/g;\nvar regexHasUnescapedHtml = RegExp(regexUnescapedHtml.source);\n\n/**\n * Converts the characters \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\n * corresponding HTML entities.\n */\nexport function escape(value) {\n return value && regexHasUnescapedHtml.test(value) ? value.replace(regexUnescapedHtml, function (character) {\n return htmlEntities[character];\n }) : value;\n}\n\n/**\n * This implementation is taken from Lodash implementation.\n * See: https://github.com/lodash/lodash/blob/4.17.11-npm/unescape.js\n */\n\n// Used to map HTML entities to characters.\nvar htmlCharacters = {\n '&': '&',\n '<': '<',\n '>': '>',\n '"': '\"',\n ''': \"'\"\n};\n\n// Used to match HTML entities and HTML characters.\nvar regexEscapedHtml = /&(amp|quot|lt|gt|#39);/g;\nvar regexHasEscapedHtml = RegExp(regexEscapedHtml.source);\n\n/**\n * Converts the HTML entities \"&\", \"<\", \">\", '\"', and \"'\" in `string` to their\n * characters.\n */\nexport function unescape(value) {\n return value && regexHasEscapedHtml.test(value) ? value.replace(regexEscapedHtml, function (character) {\n return htmlCharacters[character];\n }) : value;\n}","// We aren't using the native `Array.prototype.find` because the refactor away from Lodash is not\n// published as a major version.\n// Relying on the `find` polyfill on user-land, which before was only required for niche use-cases,\n// was decided as too risky.\n// @MAJOR Replace with the native `Array.prototype.find` method\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find\nexport function find(items, predicate) {\n var value;\n for (var i = 0; i < items.length; i++) {\n value = items[i];\n // inlined for performance: if (Call(predicate, thisArg, [value, i, list])) {\n if (predicate(value, i, items)) {\n return value;\n }\n }\n return undefined;\n}","// We aren't using the native `Array.prototype.findIndex` because the refactor away from Lodash is not\n// published as a major version.\n// Relying on the `findIndex` polyfill on user-land, which before was only required for niche use-cases,\n// was decided as too risky.\n// @MAJOR Replace with the native `Array.prototype.findIndex` method\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/findIndex\nexport function findIndex(array, comparator) {\n if (!Array.isArray(array)) {\n return -1;\n }\n for (var i = 0; i < array.length; i++) {\n if (comparator(array[i])) {\n return i;\n }\n }\n return -1;\n}","// typed as any, since it accepts the _real_ js clients, not the interface we otherwise expect\nexport function getAppIdAndApiKey(searchClient) {\n if (searchClient.transporter) {\n // searchClient v4\n var _searchClient$transpo = searchClient.transporter,\n headers = _searchClient$transpo.headers,\n queryParameters = _searchClient$transpo.queryParameters;\n var APP_ID = 'x-algolia-application-id';\n var API_KEY = 'x-algolia-api-key';\n var appId = headers[APP_ID] || queryParameters[APP_ID];\n var apiKey = headers[API_KEY] || queryParameters[API_KEY];\n return [appId, apiKey];\n } else {\n // searchClient v3\n return [searchClient.applicationID, searchClient.apiKey];\n }\n}","import { unescape } from \"./escape-html.js\";\nvar hasAlphanumeric = new RegExp(/\\w/i);\nexport function getHighlightFromSiblings(parts, i) {\n var _parts, _parts2;\n var current = parts[i];\n var isNextHighlighted = ((_parts = parts[i + 1]) === null || _parts === void 0 ? void 0 : _parts.isHighlighted) || true;\n var isPreviousHighlighted = ((_parts2 = parts[i - 1]) === null || _parts2 === void 0 ? void 0 : _parts2.isHighlighted) || true;\n if (!hasAlphanumeric.test(unescape(current.value)) && isPreviousHighlighted === isNextHighlighted) {\n return isPreviousHighlighted;\n }\n return current.isHighlighted;\n}","import { TAG_REPLACEMENT } from \"./escape-highlight.js\";\nexport function getHighlightedParts(highlightedValue) {\n var highlightPostTag = TAG_REPLACEMENT.highlightPostTag,\n highlightPreTag = TAG_REPLACEMENT.highlightPreTag;\n var splitByPreTag = highlightedValue.split(highlightPreTag);\n var firstValue = splitByPreTag.shift();\n var elements = !firstValue ? [] : [{\n value: firstValue,\n isHighlighted: false\n }];\n splitByPreTag.forEach(function (split) {\n var splitByPostTag = split.split(highlightPostTag);\n elements.push({\n value: splitByPostTag[0],\n isHighlighted: true\n });\n if (splitByPostTag[1] !== '') {\n elements.push({\n value: splitByPostTag[1],\n isHighlighted: false\n });\n }\n });\n return elements;\n}","export function getObjectType(object) {\n return Object.prototype.toString.call(object).slice(8, -1);\n}","export function getPropertyByPath(object, path) {\n var parts = Array.isArray(path) ? path : path.split('.');\n return parts.reduce(function (current, key) {\n return current && current[key];\n }, object);\n}","function isPrimitive(obj) {\n return obj !== Object(obj);\n}\nexport function isEqual(first, second) {\n if (first === second) {\n return true;\n }\n if (isPrimitive(first) || isPrimitive(second) || typeof first === 'function' || typeof second === 'function') {\n return first === second;\n }\n if (Object.keys(first).length !== Object.keys(second).length) {\n return false;\n }\n\n // @TODO avoid for..of because of the large polyfill\n // eslint-disable-next-line no-restricted-syntax\n for (var _i = 0, _Object$keys = Object.keys(first); _i < _Object$keys.length; _i++) {\n var key = _Object$keys[_i];\n if (!(key in second)) {\n return false;\n }\n if (!isEqual(first[key], second[key])) {\n return false;\n }\n }\n return true;\n}","export function isIndexWidget(widget) {\n return widget.$$type === 'ais.index';\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\n/**\n * This implementation is taken from Lodash implementation.\n * See: https://github.com/lodash/lodash/blob/master/isPlainObject.js\n */\n\nfunction getTag(value) {\n if (value === null) {\n return value === undefined ? '[object Undefined]' : '[object Null]';\n }\n return Object.prototype.toString.call(value);\n}\nfunction isObjectLike(value) {\n return _typeof(value) === 'object' && value !== null;\n}\n\n/**\n * Checks if `value` is a plain object.\n *\n * A plain object is an object created by the `Object`\n * constructor or with a `[[Prototype]]` of `null`.\n */\nexport function isPlainObject(value) {\n if (!isObjectLike(value) || getTag(value) !== '[object Object]') {\n return false;\n }\n if (Object.getPrototypeOf(value) === null) {\n return true;\n }\n var proto = value;\n while (Object.getPrototypeOf(proto) !== null) {\n proto = Object.getPrototypeOf(proto);\n }\n return Object.getPrototypeOf(value) === proto;\n}","import { noop } from \"./noop.js\";\n/**\n * Logs a warning when this function is called, in development environment only.\n */\nvar deprecate = function deprecate(fn, message) {\n return fn;\n};\n\n/**\n * Logs a warning\n * This is used to log issues in development environment only.\n */\nvar warn = noop;\n\n/**\n * Logs a warning if the condition is not met.\n * This is used to log issues in development environment only.\n */\nvar _warning = noop;\nif (process.env.NODE_ENV === 'development') {\n warn = function warn(message) {\n // eslint-disable-next-line no-console\n console.warn(\"[InstantSearch.js]: \".concat(message.trim()));\n };\n deprecate = function deprecate(fn, message) {\n var hasAlreadyPrinted = false;\n return function () {\n if (!hasAlreadyPrinted) {\n hasAlreadyPrinted = true;\n process.env.NODE_ENV === 'development' ? warn(message) : void 0;\n }\n return fn.apply(void 0, arguments);\n };\n };\n _warning = function warning(condition, message) {\n if (condition) {\n return;\n }\n var hasAlreadyPrinted = _warning.cache[message];\n if (!hasAlreadyPrinted) {\n _warning.cache[message] = true;\n process.env.NODE_ENV === 'development' ? warn(message) : void 0;\n }\n };\n _warning.cache = {};\n}\nexport { warn, deprecate, _warning as warning };","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar _excluded = [\"facets\", \"disjunctiveFacets\", \"facetsRefinements\", \"facetsExcludes\", \"disjunctiveFacetsRefinements\", \"numericRefinements\", \"tagRefinements\", \"hierarchicalFacets\", \"hierarchicalFacetsRefinements\", \"ruleContexts\"];\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport { findIndex } from \"./findIndex.js\";\nimport { uniq } from \"./uniq.js\";\nvar mergeWithRest = function mergeWithRest(left, right) {\n var facets = right.facets,\n disjunctiveFacets = right.disjunctiveFacets,\n facetsRefinements = right.facetsRefinements,\n facetsExcludes = right.facetsExcludes,\n disjunctiveFacetsRefinements = right.disjunctiveFacetsRefinements,\n numericRefinements = right.numericRefinements,\n tagRefinements = right.tagRefinements,\n hierarchicalFacets = right.hierarchicalFacets,\n hierarchicalFacetsRefinements = right.hierarchicalFacetsRefinements,\n ruleContexts = right.ruleContexts,\n rest = _objectWithoutProperties(right, _excluded);\n return left.setQueryParameters(rest);\n};\n\n// Merge facets\nvar mergeFacets = function mergeFacets(left, right) {\n return right.facets.reduce(function (_, name) {\n return _.addFacet(name);\n }, left);\n};\nvar mergeDisjunctiveFacets = function mergeDisjunctiveFacets(left, right) {\n return right.disjunctiveFacets.reduce(function (_, name) {\n return _.addDisjunctiveFacet(name);\n }, left);\n};\nvar mergeHierarchicalFacets = function mergeHierarchicalFacets(left, right) {\n return left.setQueryParameters({\n hierarchicalFacets: right.hierarchicalFacets.reduce(function (facets, facet) {\n var index = findIndex(facets, function (_) {\n return _.name === facet.name;\n });\n if (index === -1) {\n return facets.concat(facet);\n }\n var nextFacets = facets.slice();\n nextFacets.splice(index, 1, facet);\n return nextFacets;\n }, left.hierarchicalFacets)\n });\n};\n\n// Merge facet refinements\nvar mergeTagRefinements = function mergeTagRefinements(left, right) {\n return right.tagRefinements.reduce(function (_, value) {\n return _.addTagRefinement(value);\n }, left);\n};\nvar mergeFacetRefinements = function mergeFacetRefinements(left, right) {\n return left.setQueryParameters({\n facetsRefinements: _objectSpread(_objectSpread({}, left.facetsRefinements), right.facetsRefinements)\n });\n};\nvar mergeFacetsExcludes = function mergeFacetsExcludes(left, right) {\n return left.setQueryParameters({\n facetsExcludes: _objectSpread(_objectSpread({}, left.facetsExcludes), right.facetsExcludes)\n });\n};\nvar mergeDisjunctiveFacetsRefinements = function mergeDisjunctiveFacetsRefinements(left, right) {\n return left.setQueryParameters({\n disjunctiveFacetsRefinements: _objectSpread(_objectSpread({}, left.disjunctiveFacetsRefinements), right.disjunctiveFacetsRefinements)\n });\n};\nvar mergeNumericRefinements = function mergeNumericRefinements(left, right) {\n return left.setQueryParameters({\n numericRefinements: _objectSpread(_objectSpread({}, left.numericRefinements), right.numericRefinements)\n });\n};\nvar mergeHierarchicalFacetsRefinements = function mergeHierarchicalFacetsRefinements(left, right) {\n return left.setQueryParameters({\n hierarchicalFacetsRefinements: _objectSpread(_objectSpread({}, left.hierarchicalFacetsRefinements), right.hierarchicalFacetsRefinements)\n });\n};\nvar mergeRuleContexts = function mergeRuleContexts(left, right) {\n var ruleContexts = uniq([].concat(left.ruleContexts).concat(right.ruleContexts).filter(Boolean));\n if (ruleContexts.length > 0) {\n return left.setQueryParameters({\n ruleContexts: ruleContexts\n });\n }\n return left;\n};\nexport var mergeSearchParameters = function mergeSearchParameters() {\n for (var _len = arguments.length, parameters = new Array(_len), _key = 0; _key < _len; _key++) {\n parameters[_key] = arguments[_key];\n }\n return parameters.reduce(function (left, right) {\n var hierarchicalFacetsRefinementsMerged = mergeHierarchicalFacetsRefinements(left, right);\n var hierarchicalFacetsMerged = mergeHierarchicalFacets(hierarchicalFacetsRefinementsMerged, right);\n var tagRefinementsMerged = mergeTagRefinements(hierarchicalFacetsMerged, right);\n var numericRefinementsMerged = mergeNumericRefinements(tagRefinementsMerged, right);\n var disjunctiveFacetsRefinementsMerged = mergeDisjunctiveFacetsRefinements(numericRefinementsMerged, right);\n var facetsExcludesMerged = mergeFacetsExcludes(disjunctiveFacetsRefinementsMerged, right);\n var facetRefinementsMerged = mergeFacetRefinements(facetsExcludesMerged, right);\n var disjunctiveFacetsMerged = mergeDisjunctiveFacets(facetRefinementsMerged, right);\n var ruleContextsMerged = mergeRuleContexts(disjunctiveFacetsMerged, right);\n var facetsMerged = mergeFacets(ruleContextsMerged, right);\n return mergeWithRest(facetsMerged, right);\n });\n};","export function noop() {}","export function createInitArgs(instantSearchInstance, parent, uiState) {\n var helper = parent.getHelper();\n return {\n uiState: uiState,\n helper: helper,\n parent: parent,\n instantSearchInstance: instantSearchInstance,\n state: helper.state,\n renderState: instantSearchInstance.renderState,\n templatesConfig: instantSearchInstance.templatesConfig,\n createURL: parent.createURL,\n scopedResults: [],\n searchMetadata: {\n isSearchStalled: instantSearchInstance.status === 'stalled'\n },\n status: instantSearchInstance.status,\n error: instantSearchInstance.error\n };\n}\nexport function createRenderArgs(instantSearchInstance, parent) {\n var results = parent.getResults();\n return {\n helper: parent.getHelper(),\n parent: parent,\n instantSearchInstance: instantSearchInstance,\n results: results,\n scopedResults: parent.getScopedResults(),\n state: results._state,\n renderState: instantSearchInstance.renderState,\n templatesConfig: instantSearchInstance.templatesConfig,\n createURL: parent.createURL,\n searchMetadata: {\n isSearchStalled: instantSearchInstance.status === 'stalled'\n },\n status: instantSearchInstance.status,\n error: instantSearchInstance.error\n };\n}","export function resolveSearchParameters(current) {\n var parent = current.getParent();\n var states = [current.getHelper().state];\n while (parent !== null) {\n states = [parent.getHelper().state].concat(states);\n parent = parent.getParent();\n }\n return states;\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { getHighlightFromSiblings } from \"./getHighlightFromSiblings.js\";\nexport function reverseHighlightedParts(parts) {\n if (!parts.some(function (part) {\n return part.isHighlighted;\n })) {\n return parts.map(function (part) {\n return _objectSpread(_objectSpread({}, part), {}, {\n isHighlighted: false\n });\n });\n }\n return parts.map(function (part, i) {\n return _objectSpread(_objectSpread({}, part), {}, {\n isHighlighted: !getHighlightFromSiblings(parts, i)\n });\n });\n}","// eslint-disable-next-line no-restricted-globals\n\n/**\n * Runs code on browser environments safely.\n */\nexport function safelyRunOnBrowser(callback) {\n var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {\n fallback: function fallback() {\n return undefined;\n }\n },\n fallback = _ref.fallback;\n // eslint-disable-next-line no-restricted-globals\n if (typeof window === 'undefined') {\n return fallback();\n }\n\n // eslint-disable-next-line no-restricted-globals\n return callback({\n window: window\n });\n}","export function serializePayload(payload) {\n return btoa(encodeURIComponent(JSON.stringify(payload)));\n}\nexport function deserializePayload(serialized) {\n return JSON.parse(decodeURIComponent(atob(serialized)));\n}","import { checkIndexUiState } from \"./checkIndexUiState.js\";\nimport { isIndexWidget } from \"./isIndexWidget.js\";\nexport function setIndexHelperState(finalUiState, indexWidget) {\n var nextIndexUiState = finalUiState[indexWidget.getIndexId()] || {};\n if (process.env.NODE_ENV === 'development') {\n checkIndexUiState({\n index: indexWidget,\n indexUiState: nextIndexUiState\n });\n }\n indexWidget.getHelper().setState(indexWidget.getWidgetSearchParameters(indexWidget.getHelper().state, {\n uiState: nextIndexUiState\n }));\n indexWidget.getWidgets().filter(isIndexWidget).forEach(function (widget) {\n return setIndexHelperState(finalUiState, widget);\n });\n}","/**\n * A typed version of Object.keys, to use when looping over a static object\n * inspired from https://stackoverflow.com/a/65117465/3185307\n */\nexport var keys = Object.keys;","export function uniq(array) {\n return array.filter(function (value, index, self) {\n return self.indexOf(value) === index;\n });\n}","export default '4.55.0';","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nimport { getInsightsAnonymousUserTokenInternal } from \"../helpers/index.js\";\nimport { warning, noop, getAppIdAndApiKey, find, safelyRunOnBrowser } from \"../lib/utils/index.js\";\nvar ALGOLIA_INSIGHTS_VERSION = '2.6.0';\nvar ALGOLIA_INSIGHTS_SRC = \"https://cdn.jsdelivr.net/npm/search-insights@\".concat(ALGOLIA_INSIGHTS_VERSION, \"/dist/search-insights.min.js\");\nexport function createInsightsMiddleware() {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var _insightsClient = props.insightsClient,\n insightsInitParams = props.insightsInitParams,\n onEvent = props.onEvent,\n _props$$$internal = props.$$internal,\n $$internal = _props$$$internal === void 0 ? false : _props$$$internal;\n var potentialInsightsClient = _insightsClient;\n if (!_insightsClient && _insightsClient !== null) {\n safelyRunOnBrowser(function (_ref) {\n var window = _ref.window;\n var pointer = window.AlgoliaAnalyticsObject || 'aa';\n if (typeof pointer === 'string') {\n potentialInsightsClient = window[pointer];\n }\n if (!potentialInsightsClient) {\n window.AlgoliaAnalyticsObject = pointer;\n if (!window[pointer]) {\n window[pointer] = function () {\n if (!window[pointer].queue) {\n window[pointer].queue = [];\n }\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n window[pointer].queue.push(args);\n };\n window[pointer].version = ALGOLIA_INSIGHTS_VERSION;\n window[pointer].shouldAddScript = true;\n }\n potentialInsightsClient = window[pointer];\n }\n });\n }\n // if still no insightsClient was found, we use a noop\n var insightsClient = potentialInsightsClient || noop;\n return function (_ref2) {\n var instantSearchInstance = _ref2.instantSearchInstance;\n // remove existing default insights middleware\n // user-provided insights middleware takes precedence\n var existingInsightsMiddlewares = instantSearchInstance.middleware.filter(function (m) {\n return m.instance.$$type === 'ais.insights' && m.instance.$$internal;\n }).map(function (m) {\n return m.creator;\n });\n instantSearchInstance.unuse.apply(instantSearchInstance, _toConsumableArray(existingInsightsMiddlewares));\n var _getAppIdAndApiKey = getAppIdAndApiKey(instantSearchInstance.client),\n _getAppIdAndApiKey2 = _slicedToArray(_getAppIdAndApiKey, 2),\n appId = _getAppIdAndApiKey2[0],\n apiKey = _getAppIdAndApiKey2[1];\n\n // search-insights.js also throws an error so dev-only clarification is sufficient\n process.env.NODE_ENV === 'development' ? warning(Boolean(appId && apiKey), 'could not extract Algolia credentials from searchClient in insights middleware.') : void 0;\n var queuedUserToken = undefined;\n var userTokenBeforeInit = undefined;\n if (Array.isArray(insightsClient.queue)) {\n // Context: The umd build of search-insights is asynchronously loaded by the snippet.\n //\n // When user calls `aa('setUserToken', 'my-user-token')` before `search-insights` is loaded,\n // ['setUserToken', 'my-user-token'] gets stored in `aa.queue`.\n // Whenever `search-insights` is finally loaded, it will process the queue.\n //\n // But here's the reason why we handle it here:\n // At this point, even though `search-insights` is not loaded yet,\n // we still want to read the token from the queue.\n // Otherwise, the first search call will be fired without the token.\n var _ref3 = find(insightsClient.queue.slice().reverse(), function (_ref5) {\n var _ref6 = _slicedToArray(_ref5, 1),\n method = _ref6[0];\n return method === 'setUserToken';\n }) || [];\n var _ref4 = _slicedToArray(_ref3, 2);\n queuedUserToken = _ref4[1];\n }\n insightsClient('getUserToken', null, function (_error, userToken) {\n // If user has called `aa('setUserToken', 'my-user-token')` before creating\n // the `insights` middleware, we store them temporarily and\n // set it later on.\n //\n // Otherwise, the `init` call might override it with anonymous user token.\n userTokenBeforeInit = userToken;\n });\n\n // Only `init` if the `insightsInitParams` option is passed or\n // if the `insightsClient` version doesn't supports optional `init` calling.\n if (insightsInitParams || !isModernInsightsClient(insightsClient)) {\n insightsClient('init', _objectSpread({\n appId: appId,\n apiKey: apiKey,\n partial: true\n }, insightsInitParams));\n }\n var initialParameters;\n var helper;\n return {\n $$type: 'ais.insights',\n $$internal: $$internal,\n onStateChange: function onStateChange() {},\n subscribe: function subscribe() {\n if (!insightsClient.shouldAddScript) return;\n var errorMessage = '[insights middleware]: could not load search-insights.js. Please load it manually following https://alg.li/insights-init';\n try {\n var script = document.createElement('script');\n script.async = true;\n script.src = ALGOLIA_INSIGHTS_SRC;\n script.onerror = function () {\n instantSearchInstance.emit('error', new Error(errorMessage));\n };\n document.body.appendChild(script);\n insightsClient.shouldAddScript = false;\n } catch (cause) {\n insightsClient.shouldAddScript = false;\n instantSearchInstance.emit('error', new Error(errorMessage));\n }\n },\n started: function started() {\n insightsClient('addAlgoliaAgent', 'insights-middleware');\n helper = instantSearchInstance.helper;\n initialParameters = {\n userToken: helper.state.userToken,\n clickAnalytics: helper.state.clickAnalytics\n };\n helper.overrideStateWithoutTriggeringChangeEvent(_objectSpread(_objectSpread({}, helper.state), {}, {\n clickAnalytics: true\n }));\n if (!$$internal) {\n instantSearchInstance.scheduleSearch();\n }\n var setUserTokenToSearch = function setUserTokenToSearch(userToken) {\n if (!userToken) {\n return;\n }\n var existingToken = helper.state.userToken;\n helper.overrideStateWithoutTriggeringChangeEvent(_objectSpread(_objectSpread({}, helper.state), {}, {\n userToken: userToken\n }));\n if (existingToken && existingToken !== userToken) {\n instantSearchInstance.scheduleSearch();\n }\n };\n var anonymousUserToken = getInsightsAnonymousUserTokenInternal();\n if (anonymousUserToken) {\n // When `aa('init', { ... })` is called, it creates an anonymous user token in cookie.\n // We can set it as userToken.\n setUserTokenToSearch(anonymousUserToken);\n }\n\n // We consider the `userToken` coming from a `init` call to have a higher\n // importance than the one coming from the queue.\n if (userTokenBeforeInit) {\n setUserTokenToSearch(userTokenBeforeInit);\n insightsClient('setUserToken', userTokenBeforeInit);\n } else if (queuedUserToken) {\n setUserTokenToSearch(queuedUserToken);\n insightsClient('setUserToken', queuedUserToken);\n }\n\n // This updates userToken which is set explicitly by `aa('setUserToken', userToken)`\n insightsClient('onUserTokenChange', setUserTokenToSearch, {\n immediate: true\n });\n var insightsClientWithLocalCredentials = insightsClient;\n if (isModernInsightsClient(insightsClient)) {\n insightsClientWithLocalCredentials = function insightsClientWithLocalCredentials(method, payload) {\n var extraParams = {\n headers: {\n 'X-Algolia-Application-Id': appId,\n 'X-Algolia-API-Key': apiKey\n }\n };\n\n // @ts-ignore we are calling this only when we know that the client actually is correct\n return insightsClient(method, payload, extraParams);\n };\n }\n instantSearchInstance.sendEventToInsights = function (event) {\n if (onEvent) {\n onEvent(event, insightsClientWithLocalCredentials);\n } else if (event.insightsMethod) {\n // Source is used to differentiate events sent by instantsearch from those sent manually.\n event.payload.algoliaSource = ['instantsearch'];\n if (event.eventModifier === 'internal') {\n event.payload.algoliaSource.push('instantsearch-internal');\n }\n insightsClientWithLocalCredentials(event.insightsMethod, event.payload);\n process.env.NODE_ENV === 'development' ? warning(Boolean(helper.state.userToken), \"\\nCannot send event to Algolia Insights because `userToken` is not set.\\n\\nSee documentation: https://www.algolia.com/doc/guides/building-search-ui/going-further/send-insights-events/js/#setting-the-usertoken\\n\") : void 0;\n } else {\n process.env.NODE_ENV === 'development' ? warning(false, 'Cannot send event to Algolia Insights because `insightsMethod` option is missing.') : void 0;\n }\n };\n },\n unsubscribe: function unsubscribe() {\n insightsClient('onUserTokenChange', undefined);\n instantSearchInstance.sendEventToInsights = noop;\n if (helper && initialParameters) {\n helper.overrideStateWithoutTriggeringChangeEvent(_objectSpread(_objectSpread({}, helper.state), initialParameters));\n instantSearchInstance.scheduleSearch();\n }\n }\n };\n };\n}\n\n/**\n * Determines if a given insights `client` supports the optional call to `init`\n * and the ability to set credentials via extra parameters when sending events.\n */\nfunction isModernInsightsClient(client) {\n var _split$map = (client.version || '').split('.').map(Number),\n _split$map2 = _slicedToArray(_split$map, 2),\n major = _split$map2[0],\n minor = _split$map2[1];\n\n /* eslint-disable @typescript-eslint/naming-convention */\n var v3 = major >= 3;\n var v2_6 = major === 2 && minor >= 6;\n var v1_10 = major === 1 && minor >= 10;\n /* eslint-enable @typescript-eslint/naming-convention */\n\n return v3 || v2_6 || v1_10;\n}","import { createInitArgs, safelyRunOnBrowser } from \"../lib/utils/index.js\";\nfunction extractWidgetPayload(widgets, instantSearchInstance, payload) {\n var initOptions = createInitArgs(instantSearchInstance, instantSearchInstance.mainIndex, instantSearchInstance._initialUiState);\n widgets.forEach(function (widget) {\n var widgetParams = {};\n if (widget.getWidgetRenderState) {\n var renderState = widget.getWidgetRenderState(initOptions);\n if (renderState && renderState.widgetParams) {\n // casting, as we just earlier checked widgetParams exists, and thus an object\n widgetParams = renderState.widgetParams;\n }\n }\n\n // since we destructure in all widgets, the parameters with defaults are set to \"undefined\"\n var params = Object.keys(widgetParams).filter(function (key) {\n return widgetParams[key] !== undefined;\n });\n payload.widgets.push({\n type: widget.$$type,\n widgetType: widget.$$widgetType,\n params: params\n });\n if (widget.$$type === 'ais.index') {\n extractWidgetPayload(widget.getWidgets(), instantSearchInstance, payload);\n }\n });\n}\nexport function isMetadataEnabled() {\n return safelyRunOnBrowser(function (_ref) {\n var _window$navigator, _window$navigator$use;\n var window = _ref.window;\n return ((_window$navigator = window.navigator) === null || _window$navigator === void 0 ? void 0 : (_window$navigator$use = _window$navigator.userAgent) === null || _window$navigator$use === void 0 ? void 0 : _window$navigator$use.indexOf('Algolia Crawler')) > -1;\n }, {\n fallback: function fallback() {\n return false;\n }\n });\n}\n\n/**\n * Exposes the metadata of mounted widgets in a custom\n * `` tag. The metadata per widget is:\n * - applied parameters\n * - widget name\n * - connector name\n */\nexport function createMetadataMiddleware() {\n var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n _ref2$$$internal = _ref2.$$internal,\n $$internal = _ref2$$$internal === void 0 ? false : _ref2$$$internal;\n return function (_ref3) {\n var instantSearchInstance = _ref3.instantSearchInstance;\n var payload = {\n widgets: []\n };\n var payloadContainer = document.createElement('meta');\n var refNode = document.querySelector('head');\n payloadContainer.name = 'instantsearch:widgets';\n return {\n $$type: 'ais.metadata',\n $$internal: $$internal,\n onStateChange: function onStateChange() {},\n subscribe: function subscribe() {\n // using setTimeout here to delay extraction until widgets have been added in a tick (e.g. Vue)\n setTimeout(function () {\n var client = instantSearchInstance.client;\n payload.ua = client.transporter && client.transporter.userAgent ? client.transporter.userAgent.value : client._ua;\n extractWidgetPayload(instantSearchInstance.mainIndex.getWidgets(), instantSearchInstance, payload);\n instantSearchInstance.middleware.forEach(function (middleware) {\n return payload.widgets.push({\n middleware: true,\n type: middleware.instance.$$type,\n internal: middleware.instance.$$internal\n });\n });\n payloadContainer.content = JSON.stringify(payload);\n refNode.appendChild(payloadContainer);\n }, 0);\n },\n started: function started() {},\n unsubscribe: function unsubscribe() {\n payloadContainer.remove();\n }\n };\n };\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport historyRouter from \"../lib/routers/history.js\";\nimport simpleStateMapping from \"../lib/stateMappings/simple.js\";\nimport { isEqual } from \"../lib/utils/index.js\";\nexport var createRouterMiddleware = function createRouterMiddleware() {\n var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};\n var _props$router = props.router,\n router = _props$router === void 0 ? historyRouter() : _props$router,\n _props$stateMapping = props.stateMapping,\n stateMapping = _props$stateMapping === void 0 ? simpleStateMapping() : _props$stateMapping,\n _props$$$internal = props.$$internal,\n $$internal = _props$$$internal === void 0 ? false : _props$$$internal;\n return function (_ref) {\n var instantSearchInstance = _ref.instantSearchInstance;\n function topLevelCreateURL(nextState) {\n var uiState = Object.keys(nextState).reduce(function (acc, indexId) {\n return _objectSpread(_objectSpread({}, acc), {}, _defineProperty({}, indexId, nextState[indexId]));\n }, instantSearchInstance.mainIndex.getWidgetUiState({}));\n var route = stateMapping.stateToRoute(uiState);\n return router.createURL(route);\n }\n\n // casting to UiState here to keep createURL unaware of custom UiState\n // (as long as it's an object, it's ok)\n instantSearchInstance._createURL = topLevelCreateURL;\n var lastRouteState = undefined;\n var initialUiState = instantSearchInstance._initialUiState;\n return {\n $$type: \"ais.router({router:\".concat(router.$$type || '__unknown__', \", stateMapping:\").concat(stateMapping.$$type || '__unknown__', \"})\"),\n $$internal: $$internal,\n onStateChange: function onStateChange(_ref2) {\n var uiState = _ref2.uiState;\n var routeState = stateMapping.stateToRoute(uiState);\n if (lastRouteState === undefined || !isEqual(lastRouteState, routeState)) {\n router.write(routeState);\n lastRouteState = routeState;\n }\n },\n subscribe: function subscribe() {\n instantSearchInstance._initialUiState = _objectSpread(_objectSpread({}, initialUiState), stateMapping.routeToState(router.read()));\n router.onUpdate(function (route) {\n instantSearchInstance.setUiState(stateMapping.routeToState(route));\n });\n },\n started: function started() {\n var _router$start;\n (_router$start = router.start) === null || _router$start === void 0 ? void 0 : _router$start.call(router);\n },\n unsubscribe: function unsubscribe() {\n router.dispose();\n }\n };\n };\n};","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar _excluded = [\"initialSearchParameters\"];\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }\nfunction _nonIterableSpread() { throw new TypeError(\"Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _iterableToArray(iter) { if (typeof Symbol !== \"undefined\" && iter[Symbol.iterator] != null || iter[\"@@iterator\"] != null) return Array.from(iter); }\nfunction _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport algoliasearchHelper from 'algoliasearch-helper';\nimport { checkIndexUiState, createDocumentationMessageGenerator, resolveSearchParameters, mergeSearchParameters, warning, isIndexWidget, createInitArgs, createRenderArgs } from \"../../lib/utils/index.js\";\nvar withUsage = createDocumentationMessageGenerator({\n name: 'index-widget'\n});\n/**\n * This is the same content as helper._change / setState, but allowing for extra\n * UiState to be synchronized.\n * see: https://github.com/algolia/algoliasearch-helper-js/blob/6b835ffd07742f2d6b314022cce6848f5cfecd4a/src/algoliasearch.helper.js#L1311-L1324\n */\nfunction privateHelperSetState(helper, _ref) {\n var state = _ref.state,\n isPageReset = _ref.isPageReset,\n _uiState = _ref._uiState;\n if (state !== helper.state) {\n helper.state = state;\n helper.emit('change', {\n state: helper.state,\n results: helper.lastResults,\n isPageReset: isPageReset,\n _uiState: _uiState\n });\n }\n}\nfunction getLocalWidgetsUiState(widgets, widgetStateOptions) {\n var initialUiState = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n return widgets.reduce(function (uiState, widget) {\n if (isIndexWidget(widget)) {\n return uiState;\n }\n if (!widget.getWidgetUiState && !widget.getWidgetState) {\n return uiState;\n }\n if (widget.getWidgetUiState) {\n return widget.getWidgetUiState(uiState, widgetStateOptions);\n }\n return widget.getWidgetState(uiState, widgetStateOptions);\n }, initialUiState);\n}\nfunction getLocalWidgetsSearchParameters(widgets, widgetSearchParametersOptions) {\n var initialSearchParameters = widgetSearchParametersOptions.initialSearchParameters,\n rest = _objectWithoutProperties(widgetSearchParametersOptions, _excluded);\n return widgets.filter(function (widget) {\n return !isIndexWidget(widget);\n }).reduce(function (state, widget) {\n if (!widget.getWidgetSearchParameters) {\n return state;\n }\n return widget.getWidgetSearchParameters(state, rest);\n }, initialSearchParameters);\n}\nfunction resetPageFromWidgets(widgets) {\n var indexWidgets = widgets.filter(isIndexWidget);\n if (indexWidgets.length === 0) {\n return;\n }\n indexWidgets.forEach(function (widget) {\n var widgetHelper = widget.getHelper();\n privateHelperSetState(widgetHelper, {\n state: widgetHelper.state.resetPage(),\n isPageReset: true\n });\n resetPageFromWidgets(widget.getWidgets());\n });\n}\nfunction resolveScopedResultsFromWidgets(widgets) {\n var indexWidgets = widgets.filter(isIndexWidget);\n return indexWidgets.reduce(function (scopedResults, current) {\n return scopedResults.concat.apply(scopedResults, [{\n indexId: current.getIndexId(),\n results: current.getResults(),\n helper: current.getHelper()\n }].concat(_toConsumableArray(resolveScopedResultsFromWidgets(current.getWidgets()))));\n }, []);\n}\nvar index = function index(widgetParams) {\n if (widgetParams === undefined || widgetParams.indexName === undefined) {\n throw new Error(withUsage('The `indexName` option is required.'));\n }\n var indexName = widgetParams.indexName,\n _widgetParams$indexId = widgetParams.indexId,\n indexId = _widgetParams$indexId === void 0 ? indexName : _widgetParams$indexId;\n var localWidgets = [];\n var localUiState = {};\n var localInstantSearchInstance = null;\n var localParent = null;\n var helper = null;\n var derivedHelper = null;\n var lastValidSearchParameters = null;\n return {\n $$type: 'ais.index',\n $$widgetType: 'ais.index',\n getIndexName: function getIndexName() {\n return indexName;\n },\n getIndexId: function getIndexId() {\n return indexId;\n },\n getHelper: function getHelper() {\n return helper;\n },\n getResults: function getResults() {\n var _derivedHelper;\n if (!((_derivedHelper = derivedHelper) !== null && _derivedHelper !== void 0 && _derivedHelper.lastResults)) return null;\n\n // To make the UI optimistic, we patch the state to display to the current\n // one instead of the one associated with the latest results.\n // This means user-driven UI changes (e.g., checked checkbox) are reflected\n // immediately instead of waiting for Algolia to respond, regardless of\n // the status of the network request.\n derivedHelper.lastResults._state = helper.state;\n return derivedHelper.lastResults;\n },\n getPreviousState: function getPreviousState() {\n return lastValidSearchParameters;\n },\n getScopedResults: function getScopedResults() {\n var widgetParent = this.getParent();\n\n // If the widget is the root, we consider itself as the only sibling.\n var widgetSiblings = widgetParent ? widgetParent.getWidgets() : [this];\n return resolveScopedResultsFromWidgets(widgetSiblings);\n },\n getParent: function getParent() {\n return localParent;\n },\n createURL: function createURL(nextState) {\n return localInstantSearchInstance._createURL(_defineProperty({}, indexId, getLocalWidgetsUiState(localWidgets, {\n searchParameters: nextState,\n helper: helper\n })));\n },\n getWidgets: function getWidgets() {\n return localWidgets;\n },\n addWidgets: function addWidgets(widgets) {\n var _this = this;\n if (!Array.isArray(widgets)) {\n throw new Error(withUsage('The `addWidgets` method expects an array of widgets.'));\n }\n if (widgets.some(function (widget) {\n return typeof widget.init !== 'function' && typeof widget.render !== 'function';\n })) {\n throw new Error(withUsage('The widget definition expects a `render` and/or an `init` method.'));\n }\n localWidgets = localWidgets.concat(widgets);\n if (localInstantSearchInstance && Boolean(widgets.length)) {\n privateHelperSetState(helper, {\n state: getLocalWidgetsSearchParameters(localWidgets, {\n uiState: localUiState,\n initialSearchParameters: helper.state\n }),\n _uiState: localUiState\n });\n\n // We compute the render state before calling `init` in a separate loop\n // to construct the whole render state object that is then passed to\n // `init`.\n widgets.forEach(function (widget) {\n if (widget.getRenderState) {\n var renderState = widget.getRenderState(localInstantSearchInstance.renderState[_this.getIndexId()] || {}, createInitArgs(localInstantSearchInstance, _this, localInstantSearchInstance._initialUiState));\n storeRenderState({\n renderState: renderState,\n instantSearchInstance: localInstantSearchInstance,\n parent: _this\n });\n }\n });\n widgets.forEach(function (widget) {\n if (widget.init) {\n widget.init(createInitArgs(localInstantSearchInstance, _this, localInstantSearchInstance._initialUiState));\n }\n });\n localInstantSearchInstance.scheduleSearch();\n }\n return this;\n },\n removeWidgets: function removeWidgets(widgets) {\n var _this2 = this;\n if (!Array.isArray(widgets)) {\n throw new Error(withUsage('The `removeWidgets` method expects an array of widgets.'));\n }\n if (widgets.some(function (widget) {\n return typeof widget.dispose !== 'function';\n })) {\n throw new Error(withUsage('The widget definition expects a `dispose` method.'));\n }\n localWidgets = localWidgets.filter(function (widget) {\n return widgets.indexOf(widget) === -1;\n });\n if (localInstantSearchInstance && Boolean(widgets.length)) {\n var nextState = widgets.reduce(function (state, widget) {\n // the `dispose` method exists at this point we already assert it\n var next = widget.dispose({\n helper: helper,\n state: state,\n parent: _this2\n });\n return next || state;\n }, helper.state);\n localUiState = getLocalWidgetsUiState(localWidgets, {\n searchParameters: nextState,\n helper: helper\n });\n helper.setState(getLocalWidgetsSearchParameters(localWidgets, {\n uiState: localUiState,\n initialSearchParameters: nextState\n }));\n if (localWidgets.length) {\n localInstantSearchInstance.scheduleSearch();\n }\n }\n return this;\n },\n init: function init(_ref2) {\n var _this3 = this,\n _instantSearchInstanc;\n var instantSearchInstance = _ref2.instantSearchInstance,\n parent = _ref2.parent,\n uiState = _ref2.uiState;\n if (helper !== null) {\n // helper is already initialized, therefore we do not need to set up\n // any listeners\n return;\n }\n localInstantSearchInstance = instantSearchInstance;\n localParent = parent;\n localUiState = uiState[indexId] || {};\n\n // The `mainHelper` is already defined at this point. The instance is created\n // inside InstantSearch at the `start` method, which occurs before the `init`\n // step.\n var mainHelper = instantSearchInstance.mainHelper;\n var parameters = getLocalWidgetsSearchParameters(localWidgets, {\n uiState: localUiState,\n initialSearchParameters: new algoliasearchHelper.SearchParameters({\n index: indexName\n })\n });\n\n // This Helper is only used for state management we do not care about the\n // `searchClient`. Only the \"main\" Helper created at the `InstantSearch`\n // level is aware of the client.\n helper = algoliasearchHelper({}, parameters.index, parameters);\n\n // We forward the call to `search` to the \"main\" instance of the Helper\n // which is responsible for managing the queries (it's the only one that is\n // aware of the `searchClient`).\n helper.search = function () {\n if (instantSearchInstance.onStateChange) {\n instantSearchInstance.onStateChange({\n uiState: instantSearchInstance.mainIndex.getWidgetUiState({}),\n setUiState: function setUiState(nextState) {\n return instantSearchInstance.setUiState(nextState, false);\n }\n });\n\n // We don't trigger a search when controlled because it becomes the\n // responsibility of `setUiState`.\n return mainHelper;\n }\n return mainHelper.search();\n };\n helper.searchWithoutTriggeringOnStateChange = function () {\n return mainHelper.search();\n };\n\n // We use the same pattern for the `searchForFacetValues`.\n helper.searchForFacetValues = function (facetName, facetValue, maxFacetHits, userState) {\n var state = helper.state.setQueryParameters(userState);\n return mainHelper.searchForFacetValues(facetName, facetValue, maxFacetHits, state);\n };\n derivedHelper = mainHelper.derive(function () {\n return mergeSearchParameters.apply(void 0, _toConsumableArray(resolveSearchParameters(_this3)));\n });\n var indexInitialResults = (_instantSearchInstanc = instantSearchInstance._initialResults) === null || _instantSearchInstanc === void 0 ? void 0 : _instantSearchInstanc[this.getIndexId()];\n if (indexInitialResults) {\n // We restore the shape of the results provided to the instance to respect\n // the helper's structure.\n var results = new algoliasearchHelper.SearchResults(new algoliasearchHelper.SearchParameters(indexInitialResults.state), indexInitialResults.results);\n derivedHelper.lastResults = results;\n helper.lastResults = results;\n }\n\n // Subscribe to the Helper state changes for the page before widgets\n // are initialized. This behavior mimics the original one of the Helper.\n // It makes sense to replicate it at the `init` step. We have another\n // listener on `change` below, once `init` is done.\n helper.on('change', function (_ref3) {\n var isPageReset = _ref3.isPageReset;\n if (isPageReset) {\n resetPageFromWidgets(localWidgets);\n }\n });\n derivedHelper.on('search', function () {\n // The index does not manage the \"staleness\" of the search. This is the\n // responsibility of the main instance. It does not make sense to manage\n // it at the index level because it's either: all of them or none of them\n // that are stalled. The queries are performed into a single network request.\n instantSearchInstance.scheduleStalledRender();\n if (process.env.NODE_ENV === 'development') {\n checkIndexUiState({\n index: _this3,\n indexUiState: localUiState\n });\n }\n });\n derivedHelper.on('result', function (_ref4) {\n var results = _ref4.results;\n // The index does not render the results it schedules a new render\n // to let all the other indices emit their own results. It allows us to\n // run the render process in one pass.\n instantSearchInstance.scheduleRender();\n\n // the derived helper is the one which actually searches, but the helper\n // which is exposed e.g. via instance.helper, doesn't search, and thus\n // does not have access to lastResults, which it used to in pre-federated\n // search behavior.\n helper.lastResults = results;\n lastValidSearchParameters = results._state;\n });\n\n // We compute the render state before calling `init` in a separate loop\n // to construct the whole render state object that is then passed to\n // `init`.\n localWidgets.forEach(function (widget) {\n if (widget.getRenderState) {\n var renderState = widget.getRenderState(instantSearchInstance.renderState[_this3.getIndexId()] || {}, createInitArgs(instantSearchInstance, _this3, uiState));\n storeRenderState({\n renderState: renderState,\n instantSearchInstance: instantSearchInstance,\n parent: _this3\n });\n }\n });\n localWidgets.forEach(function (widget) {\n process.env.NODE_ENV === 'development' ? warning(\n // if it has NO getWidgetState or if it has getWidgetUiState, we don't warn\n // aka we warn if there's _only_ getWidgetState\n !widget.getWidgetState || Boolean(widget.getWidgetUiState), 'The `getWidgetState` method is renamed `getWidgetUiState` and will no longer exist under that name in InstantSearch.js 5.x. Please use `getWidgetUiState` instead.') : void 0;\n if (widget.init) {\n widget.init(createInitArgs(instantSearchInstance, _this3, uiState));\n }\n });\n\n // Subscribe to the Helper state changes for the `uiState` once widgets\n // are initialized. Until the first render, state changes are part of the\n // configuration step. This is mainly for backward compatibility with custom\n // widgets. When the subscription happens before the `init` step, the (static)\n // configuration of the widget is pushed in the URL. That's what we want to avoid.\n // https://github.com/algolia/instantsearch.js/pull/994/commits/4a672ae3fd78809e213de0368549ef12e9dc9454\n helper.on('change', function (event) {\n var state = event.state;\n var _uiState = event._uiState;\n localUiState = getLocalWidgetsUiState(localWidgets, {\n searchParameters: state,\n helper: helper\n }, _uiState || {});\n\n // We don't trigger an internal change when controlled because it\n // becomes the responsibility of `setUiState`.\n if (!instantSearchInstance.onStateChange) {\n instantSearchInstance.onInternalStateChange();\n }\n });\n if (indexInitialResults) {\n // If there are initial results, we're not notified of the next results\n // because we don't trigger an initial search. We therefore need to directly\n // schedule a render that will render the results injected on the helper.\n instantSearchInstance.scheduleRender();\n }\n },\n render: function render(_ref5) {\n var _this4 = this;\n var instantSearchInstance = _ref5.instantSearchInstance;\n if (!this.getResults()) {\n return;\n }\n\n // we can't attach a listener to the error event of search, as the error\n // then would no longer be thrown for global handlers.\n if (instantSearchInstance.status === 'error' && !instantSearchInstance.mainHelper.hasPendingRequests()) {\n helper.setState(lastValidSearchParameters);\n }\n localWidgets.forEach(function (widget) {\n if (widget.getRenderState) {\n var renderState = widget.getRenderState(instantSearchInstance.renderState[_this4.getIndexId()] || {}, createRenderArgs(instantSearchInstance, _this4));\n storeRenderState({\n renderState: renderState,\n instantSearchInstance: instantSearchInstance,\n parent: _this4\n });\n }\n });\n localWidgets.forEach(function (widget) {\n // At this point, all the variables used below are set. Both `helper`\n // and `derivedHelper` have been created at the `init` step. The attribute\n // `lastResults` might be `null` though. It's possible that a stalled render\n // happens before the result e.g with a dynamically added index the request might\n // be delayed. The render is triggered for the complete tree but some parts do\n // not have results yet.\n\n if (widget.render) {\n widget.render(createRenderArgs(instantSearchInstance, _this4));\n }\n });\n },\n dispose: function dispose() {\n var _this5 = this,\n _helper,\n _derivedHelper2;\n localWidgets.forEach(function (widget) {\n if (widget.dispose) {\n // The dispose function is always called once the instance is started\n // (it's an effect of `removeWidgets`). The index is initialized and\n // the Helper is available. We don't care about the return value of\n // `dispose` because the index is removed. We can't call `removeWidgets`\n // because we want to keep the widgets on the instance, to allow idempotent\n // operations on `add` & `remove`.\n widget.dispose({\n helper: helper,\n state: helper.state,\n parent: _this5\n });\n }\n });\n localInstantSearchInstance = null;\n localParent = null;\n (_helper = helper) === null || _helper === void 0 ? void 0 : _helper.removeAllListeners();\n helper = null;\n (_derivedHelper2 = derivedHelper) === null || _derivedHelper2 === void 0 ? void 0 : _derivedHelper2.detach();\n derivedHelper = null;\n },\n getWidgetUiState: function getWidgetUiState(uiState) {\n return localWidgets.filter(isIndexWidget).reduce(function (previousUiState, innerIndex) {\n return innerIndex.getWidgetUiState(previousUiState);\n }, _objectSpread(_objectSpread({}, uiState), {}, _defineProperty({}, indexId, _objectSpread(_objectSpread({}, uiState[indexId]), localUiState))));\n },\n getWidgetState: function getWidgetState(uiState) {\n process.env.NODE_ENV === 'development' ? warning(false, 'The `getWidgetState` method is renamed `getWidgetUiState` and will no longer exist under that name in InstantSearch.js 5.x. Please use `getWidgetUiState` instead.') : void 0;\n return this.getWidgetUiState(uiState);\n },\n getWidgetSearchParameters: function getWidgetSearchParameters(searchParameters, _ref6) {\n var uiState = _ref6.uiState;\n return getLocalWidgetsSearchParameters(localWidgets, {\n uiState: uiState,\n initialSearchParameters: searchParameters\n });\n },\n refreshUiState: function refreshUiState() {\n localUiState = getLocalWidgetsUiState(localWidgets, {\n searchParameters: this.getHelper().state,\n helper: this.getHelper()\n }, localUiState);\n },\n setIndexUiState: function setIndexUiState(indexUiState) {\n var nextIndexUiState = typeof indexUiState === 'function' ? indexUiState(localUiState) : indexUiState;\n localInstantSearchInstance.setUiState(function (state) {\n return _objectSpread(_objectSpread({}, state), {}, _defineProperty({}, indexId, nextIndexUiState));\n });\n }\n };\n};\nexport default index;\nfunction storeRenderState(_ref7) {\n var renderState = _ref7.renderState,\n instantSearchInstance = _ref7.instantSearchInstance,\n parent = _ref7.parent;\n var parentIndexName = parent ? parent.getIndexId() : instantSearchInstance.mainIndex.getIndexId();\n instantSearchInstance.renderState = _objectSpread(_objectSpread({}, instantSearchInstance.renderState), {}, _defineProperty({}, parentIndexName, _objectSpread(_objectSpread({}, instantSearchInstance.renderState[parentIndexName]), renderState)));\n}","import { useConfigure } from \"../connectors/useConfigure.js\";\nexport function Configure(props) {\n useConfigure(props, {\n $$widgetType: 'ais.configure'\n });\n return null;\n}","var _excluded = [\"children\"];\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport React from 'react';\nimport { IndexContext } from \"../lib/IndexContext.js\";\nimport { useIndex } from \"../lib/useIndex.js\";\nexport function Index(_ref) {\n var children = _ref.children,\n props = _objectWithoutProperties(_ref, _excluded);\n var index = useIndex(props);\n if (index.getHelper() === null) {\n return null;\n }\n return /*#__PURE__*/React.createElement(IndexContext.Provider, {\n value: index\n }, children);\n}","var _excluded = [\"children\"];\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport React from 'react';\nimport { IndexContext } from \"../lib/IndexContext.js\";\nimport { InstantSearchContext } from \"../lib/InstantSearchContext.js\";\nimport { useInstantSearchApi } from \"../lib/useInstantSearchApi.js\";\nexport function InstantSearch(_ref) {\n var children = _ref.children,\n props = _objectWithoutProperties(_ref, _excluded);\n var search = useInstantSearchApi(props);\n if (!search.started) {\n return null;\n }\n return /*#__PURE__*/React.createElement(InstantSearchContext.Provider, {\n value: search\n }, /*#__PURE__*/React.createElement(IndexContext.Provider, {\n value: search.mainIndex\n }, children));\n}","import { createContext } from 'react';\nexport var InstantSearchServerContext = /*#__PURE__*/createContext(null);\nif (process.env.NODE_ENV === 'development') {\n InstantSearchServerContext.displayName = 'InstantSearchServer';\n}","import connectConfigure from \"instantsearch.js/es/connectors/configure/connectConfigure.js\";\nimport { useConnector } from \"../hooks/useConnector.js\";\nexport function useConfigure(props, additionalWidgetProperties) {\n return useConnector(connectConfigure, {\n searchParameters: props\n }, additionalWidgetProperties);\n}","import connectSearchBox from \"instantsearch.js/es/connectors/search-box/connectSearchBox.js\";\nimport { useConnector } from \"../hooks/useConnector.js\";\nexport function useSearchBox(props, additionalWidgetProperties) {\n return useConnector(connectSearchBox, props, additionalWidgetProperties);\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nvar _excluded = [\"instantSearchInstance\", \"widgetParams\"],\n _excluded2 = [\"widgetParams\"];\nfunction _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nfunction _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\nimport { useMemo, useRef, useState } from 'react';\nimport { dequal } from \"../lib/dequal.js\";\nimport { getIndexSearchResults } from \"../lib/getIndexSearchResults.js\";\nimport { useIndexContext } from \"../lib/useIndexContext.js\";\nimport { useInstantSearchContext } from \"../lib/useInstantSearchContext.js\";\nimport { useInstantSearchServerContext } from \"../lib/useInstantSearchServerContext.js\";\nimport { useStableValue } from \"../lib/useStableValue.js\";\nimport { useWidget } from \"../lib/useWidget.js\";\nexport function useConnector(connector) {\n var props = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n var additionalWidgetProperties = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};\n var serverContext = useInstantSearchServerContext();\n var search = useInstantSearchContext();\n var parentIndex = useIndexContext();\n var stableProps = useStableValue(props);\n var stableAdditionalWidgetProperties = useStableValue(additionalWidgetProperties);\n var shouldSetStateRef = useRef(true);\n var previousRenderStateRef = useRef(null);\n var widget = useMemo(function () {\n var createWidget = connector(function (connectorState, isFirstRender) {\n // We skip the `init` widget render because:\n // - We rely on `getWidgetRenderState` to compute the initial state before\n // the InstantSearch.js lifecycle starts.\n // - It prevents UI flashes when updating the widget props.\n if (isFirstRender) {\n shouldSetStateRef.current = true;\n return;\n }\n\n // There are situations where InstantSearch.js may render widgets slightly\n // after they're removed by React, and thus try to update the React state\n // on unmounted components. React 16 and 17 consider them as memory leaks\n // and display a warning.\n // This happens in when `attributesToRender` contains a\n // value without an attribute previously mounted. React will unmount the\n // component controlled by that attribute, but InstantSearch.js will stay\n // unaware of this change until the render pass finishes, and therefore\n // notifies of a state change.\n // This ref lets us track this situation and ignore these state updates.\n if (shouldSetStateRef.current) {\n var instantSearchInstance = connectorState.instantSearchInstance,\n widgetParams = connectorState.widgetParams,\n renderState = _objectWithoutProperties(connectorState, _excluded);\n\n // We only update the state when a widget render state param changes,\n // except for functions. We ignore function reference changes to avoid\n // infinite loops. It's safe to omit them because they get updated\n // every time another render param changes.\n if (!dequal(renderState, previousRenderStateRef.current, function (a, b) {\n return (a === null || a === void 0 ? void 0 : a.constructor) === Function && (b === null || b === void 0 ? void 0 : b.constructor) === Function;\n })) {\n // eslint-disable-next-line @typescript-eslint/no-use-before-define\n setState(renderState);\n previousRenderStateRef.current = renderState;\n }\n }\n }, function () {\n // We'll ignore the next state update until we know for sure that\n // InstantSearch.js re-inits the component.\n shouldSetStateRef.current = false;\n });\n return _objectSpread(_objectSpread({}, createWidget(stableProps)), stableAdditionalWidgetProperties);\n }, [connector, stableProps, stableAdditionalWidgetProperties]);\n var _useState = useState(function () {\n if (widget.getWidgetRenderState) {\n var _widget$getWidgetSear;\n // The helper exists because we've started InstantSearch.\n var helper = parentIndex.getHelper();\n var uiState = parentIndex.getWidgetUiState({})[parentIndex.getIndexId()];\n helper.state = ((_widget$getWidgetSear = widget.getWidgetSearchParameters) === null || _widget$getWidgetSear === void 0 ? void 0 : _widget$getWidgetSear.call(widget, helper.state, {\n uiState: uiState\n })) || helper.state;\n var _getIndexSearchResult = getIndexSearchResults(parentIndex),\n results = _getIndexSearchResult.results,\n scopedResults = _getIndexSearchResult.scopedResults;\n\n // We get the widget render state by providing the same parameters as\n // InstantSearch provides to the widget's `render` method.\n // See https://github.com/algolia/instantsearch.js/blob/019cd18d0de6dd320284aa4890541b7fe2198c65/src/widgets/index/index.ts#L604-L617\n var _widget$getWidgetRend = widget.getWidgetRenderState({\n helper: helper,\n parent: parentIndex,\n instantSearchInstance: search,\n results: results,\n scopedResults: scopedResults,\n state: helper.state,\n renderState: search.renderState,\n templatesConfig: search.templatesConfig,\n createURL: parentIndex.createURL,\n searchMetadata: {\n isSearchStalled: search.status === 'stalled'\n },\n status: search.status,\n error: search.error\n }),\n widgetParams = _widget$getWidgetRend.widgetParams,\n renderState = _objectWithoutProperties(_widget$getWidgetRend, _excluded2);\n return renderState;\n }\n return {};\n }),\n _useState2 = _slicedToArray(_useState, 2),\n state = _useState2[0],\n setState = _useState2[1];\n useWidget({\n widget: widget,\n parentIndex: parentIndex,\n props: stableProps,\n shouldSsr: Boolean(serverContext)\n });\n return state;\n}","import { useCallback } from 'react';\nimport { useInstantSearchContext } from \"../lib/useInstantSearchContext.js\";\nimport { useIsomorphicLayoutEffect } from \"../lib/useIsomorphicLayoutEffect.js\";\nimport { useSearchResults } from \"../lib/useSearchResults.js\";\nimport { useSearchState } from \"../lib/useSearchState.js\";\nexport function useInstantSearch() {\n var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n catchError = _ref.catchError;\n var search = useInstantSearchContext();\n var _useSearchState = useSearchState(),\n uiState = _useSearchState.uiState,\n setUiState = _useSearchState.setUiState,\n indexUiState = _useSearchState.indexUiState,\n setIndexUiState = _useSearchState.setIndexUiState;\n var _useSearchResults = useSearchResults(),\n results = _useSearchResults.results,\n scopedResults = _useSearchResults.scopedResults;\n var use = useCallback(function () {\n for (var _len = arguments.length, middlewares = new Array(_len), _key = 0; _key < _len; _key++) {\n middlewares[_key] = arguments[_key];\n }\n search.use.apply(search, middlewares);\n return function () {\n search.unuse.apply(search, middlewares);\n };\n }, [search]);\n var refresh = useCallback(function () {\n search.refresh();\n }, [search]);\n useIsomorphicLayoutEffect(function () {\n if (catchError) {\n var onError = function onError() {};\n search.addListener('error', onError);\n return function () {\n return search.removeListener('error', onError);\n };\n }\n return function () {};\n }, [search, catchError]);\n return {\n results: results,\n scopedResults: scopedResults,\n uiState: uiState,\n setUiState: setUiState,\n indexUiState: indexUiState,\n setIndexUiState: setIndexUiState,\n use: use,\n refresh: refresh,\n status: search.status,\n error: search.error\n };\n}","import { createContext } from 'react';\nexport var IndexContext = /*#__PURE__*/createContext(null);\nif (process.env.NODE_ENV === 'development') {\n IndexContext.displayName = 'Index';\n}","import { createContext } from 'react';\nexport var InstantSearchContext = /*#__PURE__*/createContext(null);\nif (process.env.NODE_ENV === 'development') {\n InstantSearchContext.displayName = 'InstantSearch';\n}","import { createContext } from 'react';\nexport var InstantSearchSSRContext = /*#__PURE__*/createContext(null);\nif (process.env.NODE_ENV === 'development') {\n InstantSearchSSRContext.displayName = 'InstantSearchSSR';\n}","import algoliasearchHelper from 'algoliasearch-helper';\nexport function createSearchResults(state) {\n var _state$query, _state$page, _state$hitsPerPage;\n return new algoliasearchHelper.SearchResults(state, [{\n query: (_state$query = state.query) !== null && _state$query !== void 0 ? _state$query : '',\n page: (_state$page = state.page) !== null && _state$page !== void 0 ? _state$page : 0,\n hitsPerPage: (_state$hitsPerPage = state.hitsPerPage) !== null && _state$hitsPerPage !== void 0 ? _state$hitsPerPage : 20,\n hits: [],\n nbHits: 0,\n nbPages: 0,\n params: '',\n exhaustiveNbHits: true,\n exhaustiveFacetsCount: true,\n processingTimeMS: 0,\n index: state.index\n }], {\n /** used by connectors to prevent persisting these results */\n __isArtificial: true\n });\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\n/* eslint-disable complexity */\n\n/*\n * Code taken from dequal/lite v2.0.0\n * https://github.com/lukeed/dequal/blob/9aa73181ac7e081cd330cac67d313632ac04bb02/src/lite.js\n *\n * It adds a 3rd argument `compare(a, b)` that lets execute custom logic to\n * compare values.\n * We use it to skip comparing function references.\n */\n\nvar has = Object.prototype.hasOwnProperty;\nexport function dequal(foo, bar, compare) {\n // start of custom implementation\n if (compare !== null && compare !== void 0 && compare(foo, bar)) {\n return true;\n }\n // end of custom implementation\n\n var ctor;\n var len;\n if (foo === bar) return true;\n if (foo && bar && (ctor = foo.constructor) === bar.constructor) {\n if (ctor === Date) return foo.getTime() === bar.getTime();\n if (ctor === RegExp) return foo.toString() === bar.toString();\n if (ctor === Array) {\n if ((len = foo.length) === bar.length) {\n while (len-- && dequal(foo[len], bar[len], compare));\n }\n return len === -1;\n }\n if (!ctor || _typeof(foo) === 'object') {\n len = 0;\n // eslint-disable-next-line guard-for-in, no-restricted-syntax\n for (ctor in foo) {\n if (has.call(foo, ctor) && ++len && !has.call(bar, ctor)) return false;\n if (!(ctor in bar) || !dequal(foo[ctor], bar[ctor], compare)) return false;\n }\n return Object.keys(bar).length === len;\n }\n }\n\n // eslint-disable-next-line no-self-compare\n return foo !== foo && bar !== bar;\n}","function _typeof(obj) { \"@babel/helpers - typeof\"; return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && \"function\" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }, _typeof(obj); }\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }\nfunction _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return _typeof(key) === \"symbol\" ? key : String(key); }\nfunction _toPrimitive(input, hint) { if (_typeof(input) !== \"object\" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || \"default\"); if (_typeof(res) !== \"object\") return res; throw new TypeError(\"@@toPrimitive must return a primitive value.\"); } return (hint === \"string\" ? String : Number)(input); }\nimport { createSearchResults } from \"./createSearchResults.js\";\nexport function getIndexSearchResults(indexWidget) {\n var helper = indexWidget.getHelper();\n var results =\n // On SSR, we get the results injected on the Index.\n indexWidget.getResults() ||\n // On the browser, we create fallback results based on the helper state.\n createSearchResults(helper.state);\n var scopedResults = indexWidget.getScopedResults().map(function (scopedResult) {\n var fallbackResults = scopedResult.indexId === indexWidget.getIndexId() ? results : createSearchResults(scopedResult.helper.state);\n return _objectSpread(_objectSpread({}, scopedResult), {}, {\n // We keep `results` from being `null`.\n results: scopedResult.results || fallbackResults\n });\n });\n return {\n results: results,\n scopedResults: scopedResults\n };\n}","/**\n * Throws an error if the condition is not met.\n *\n * The error is exhaustive in development, and becomes generic in production.\n *\n * This is used to make development a better experience to provide guidance as\n * to where the error comes from.\n */\nexport function invariant(condition, message) {\n if (condition) {\n return;\n }\n if (!(process.env.NODE_ENV === 'development')) {\n throw new Error('Invariant failed');\n }\n if (process.env.NODE_ENV === 'development') {\n throw new Error(\"[InstantSearch] \".concat(typeof message === 'function' ? message() : message));\n }\n}","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useReducer } from 'react';\n\n/**\n * Forces a React update that triggers a rerender.\n * @link https://reactjs.org/docs/hooks-faq.html#is-there-something-like-forceupdate\n */\nexport function useForceUpdate() {\n var _useReducer = useReducer(function (x) {\n return x + 1;\n }, 0),\n _useReducer2 = _slicedToArray(_useReducer, 2),\n forceUpdate = _useReducer2[1];\n return forceUpdate;\n}","import index from \"instantsearch.js/es/widgets/index/index.js\";\nimport { useMemo } from 'react';\nimport { useIndexContext } from \"./useIndexContext.js\";\nimport { useForceUpdate } from \"./useForceUpdate.js\";\nimport { useInstantSearchServerContext } from \"./useInstantSearchServerContext.js\";\nimport { useInstantSearchSSRContext } from \"./useInstantSearchSSRContext.js\";\nimport { useIsomorphicLayoutEffect } from \"./useIsomorphicLayoutEffect.js\";\nimport { useStableValue } from \"./useStableValue.js\";\nimport { useWidget } from \"./useWidget.js\";\nexport function useIndex(props) {\n var serverContext = useInstantSearchServerContext();\n var ssrContext = useInstantSearchSSRContext();\n var initialResults = ssrContext === null || ssrContext === void 0 ? void 0 : ssrContext.initialResults;\n var parentIndex = useIndexContext();\n var stableProps = useStableValue(props);\n var indexWidget = useMemo(function () {\n return index(stableProps);\n }, [stableProps]);\n var helper = indexWidget.getHelper();\n var forceUpdate = useForceUpdate();\n useIsomorphicLayoutEffect(function () {\n forceUpdate();\n }, [helper, forceUpdate]);\n useWidget({\n widget: indexWidget,\n parentIndex: parentIndex,\n props: stableProps,\n shouldSsr: Boolean(serverContext || initialResults)\n });\n return indexWidget;\n}","import { useContext } from 'react';\nimport { invariant } from \"./invariant.js\";\nimport { IndexContext } from \"./IndexContext.js\";\nexport function useIndexContext() {\n var context = useContext(IndexContext);\n invariant(context !== null, 'The component must be used within .');\n return context;\n}","import InstantSearch from \"instantsearch.js/es/lib/InstantSearch.js\";\nimport { useCallback, useRef, version as ReactVersion } from 'react';\nimport { useSyncExternalStore } from \"use-sync-external-store/shim/index.js\";\nimport { useInstantSearchServerContext } from \"./useInstantSearchServerContext.js\";\nimport { useInstantSearchSSRContext } from \"./useInstantSearchSSRContext.js\";\nimport version from \"../version.js\";\nimport { useForceUpdate } from \"./useForceUpdate.js\";\nimport { warn } from \"./warn.js\";\nvar defaultUserAgents = [\"react (\".concat(ReactVersion, \")\"), \"react-instantsearch (\".concat(version, \")\"), \"react-instantsearch-hooks (\".concat(version, \")\")];\nvar serverUserAgent = \"react-instantsearch-server (\".concat(version, \")\");\nexport function useInstantSearchApi(props) {\n var forceUpdate = useForceUpdate();\n var serverContext = useInstantSearchServerContext();\n var serverState = useInstantSearchSSRContext();\n var initialResults = serverState === null || serverState === void 0 ? void 0 : serverState.initialResults;\n var prevPropsRef = useRef(props);\n var searchRef = useRef(null);\n // As we need to render on mount with SSR, using the local ref above in `StrictMode` will\n // create and start two instances of InstantSearch. To avoid this, we instead discard it and use\n // an upward ref from `InstantSearchSSRContext` as it has already been mounted a second time at this point.\n if (serverState) {\n searchRef = serverState.ssrSearchRef;\n }\n if (searchRef.current === null) {\n // We don't use the `instantsearch()` function because it comes with other\n // top-level APIs that we don't need.\n // See https://github.com/algolia/instantsearch.js/blob/5b529f43d8acc680f85837eaaa41f7fd03a3f833/src/index.es.ts#L63-L86\n var search = new InstantSearch(props);\n search._schedule = function _schedule(cb) {\n search._schedule.queue.push(cb);\n clearTimeout(search._schedule.timer);\n search._schedule.timer = setTimeout(function () {\n search._schedule.queue.forEach(function (callback) {\n callback();\n });\n search._schedule.queue = [];\n }, 0);\n };\n search._schedule.queue = [];\n if (serverContext || initialResults) {\n // InstantSearch.js has a private Initial Results API that lets us inject\n // results on the search instance.\n // On the server, we default the initial results to an empty object so that\n // InstantSearch.js doesn't schedule a search that isn't used, leading to\n // an additional network request. (This is equivalent to monkey-patching\n // `scheduleSearch` to a noop.)\n search._initialResults = initialResults || {};\n }\n addAlgoliaAgents(props.searchClient, [].concat(defaultUserAgents, [serverContext && serverUserAgent]));\n\n // On the server, we start the search early to compute the search parameters.\n // On SSR, we start the search early to directly catch up with the lifecycle\n // and render.\n if (serverContext || initialResults) {\n search.start();\n }\n if (serverContext) {\n // We notify `getServerState()` of the InstantSearch internals to retrieve\n // the server state and pass it to the render on SSR.\n serverContext.notifyServer({\n search: search\n });\n }\n warnNextRouter(props.routing);\n searchRef.current = search;\n }\n {\n var _search = searchRef.current;\n var prevProps = prevPropsRef.current;\n if (prevProps.indexName !== props.indexName) {\n _search.helper.setIndex(props.indexName).search();\n prevPropsRef.current = props;\n }\n if (prevProps.searchClient !== props.searchClient) {\n process.env.NODE_ENV === 'development' ? warn(false, 'The `searchClient` prop of `` changed between renders, which may cause more search requests than necessary. If this is an unwanted behavior, please provide a stable reference: https://www.algolia.com/doc/api-reference/widgets/instantsearch/react-hooks/#widget-param-searchclient') : void 0;\n addAlgoliaAgents(props.searchClient, [].concat(defaultUserAgents, [serverContext && serverUserAgent]));\n _search.mainHelper.setClient(props.searchClient).search();\n prevPropsRef.current = props;\n }\n if (prevProps.onStateChange !== props.onStateChange) {\n _search.onStateChange = props.onStateChange;\n prevPropsRef.current = props;\n }\n if (prevProps.searchFunction !== props.searchFunction) {\n // Updating the `searchFunction` to `undefined` is not supported by\n // InstantSearch.js, so it will throw an error.\n // This is a fair behavior until we add an update API in InstantSearch.js.\n _search._searchFunction = props.searchFunction;\n prevPropsRef.current = props;\n }\n if (prevProps.stalledSearchDelay !== props.stalledSearchDelay) {\n var _props$stalledSearchD;\n // The default `stalledSearchDelay` in InstantSearch.js is 200ms.\n // We need to reset it when it's undefined to get back to the original value.\n _search._stalledSearchDelay = (_props$stalledSearchD = props.stalledSearchDelay) !== null && _props$stalledSearchD !== void 0 ? _props$stalledSearchD : 200;\n prevPropsRef.current = props;\n }\n\n // Updating the `routing` prop is not supported because InstantSearch.js\n // doesn't let us change it. This might not be a problem though, because `routing`\n // shouldn't need to be dynamic.\n // If we find scenarios where `routing` needs to change, we can always expose\n // it privately on the InstantSearch instance. Another way would be to\n // manually inject the routing middleware in this library, and not rely\n // on the provided `routing` prop.\n }\n\n var cleanupTimerRef = useRef(null);\n var store = useSyncExternalStore(useCallback(function () {\n var search = searchRef.current;\n\n // Scenario 1: the component mounts.\n if (cleanupTimerRef.current === null) {\n // On SSR, the instance is already started so we don't start it again.\n if (!search.started) {\n search.start();\n forceUpdate();\n }\n }\n // Scenario 2: the component updates.\n else {\n // We cancel the previous cleanup function because we don't want to\n // dispose the search during an update.\n clearTimeout(cleanupTimerRef.current);\n search._preventWidgetCleanup = false;\n }\n return function () {\n function cleanup() {\n search.dispose();\n }\n clearTimeout(search._schedule.timer);\n // We clean up only when the component that uses this subscription unmounts,\n // but not when it updates, because it would dispose the instance, which\n // would remove all the widgets and break routing.\n // Executing the cleanup function in a `setTimeout()` lets us cancel it\n // in the next effect.\n // (There might be better ways to do this.)\n cleanupTimerRef.current = setTimeout(cleanup);\n\n // We need to prevent the `useWidget` cleanup function so that widgets\n // are not removed before the instance is disposed, triggering\n // an unwanted search request.\n search._preventWidgetCleanup = true;\n };\n }, [forceUpdate]), function () {\n return searchRef.current;\n }, function () {\n return searchRef.current;\n });\n return store;\n}\nfunction addAlgoliaAgents(searchClient, userAgents) {\n if (typeof searchClient.addAlgoliaAgent !== 'function') {\n return;\n }\n userAgents.filter(Boolean).forEach(function (userAgent) {\n searchClient.addAlgoliaAgent(userAgent);\n });\n}\nfunction warnNextRouter(routing) {\n if (process.env.NODE_ENV === 'development') {\n var _routing$router;\n if (!routing || typeof window === 'undefined' || !('__NEXT_DATA__' in window)) {\n return;\n }\n var isUsingNextRouter =\n // @ts-expect-error: _isNextRouter is only set on the Next.js router\n routing !== true && (routing === null || routing === void 0 ? void 0 : (_routing$router = routing.router) === null || _routing$router === void 0 ? void 0 : _routing$router._isNextRouter);\n process.env.NODE_ENV === 'development' ? warn(isUsingNextRouter, \"\\nYou are using Next.js with InstantSearch without the \\\"react-instantsearch-hooks-router-nextjs\\\" package.\\nThis package is recommended to make the routing work correctly with Next.js.\\nPlease check its usage instructions: https://github.com/algolia/instantsearch/tree/master/packages/react-instantsearch-hooks-router-nextjs\\n\\nYou can ignore this warning if you are using a custom router that suits your needs, it won't be outputted in production builds.\") : void 0;\n }\n}","import { useContext } from 'react';\nimport { invariant } from \"./invariant.js\";\nimport { InstantSearchContext } from \"./InstantSearchContext.js\";\nexport function useInstantSearchContext() {\n var search = useContext(InstantSearchContext);\n invariant(search !== null, 'Hooks must be used inside the component.\\n\\n' + 'They are not compatible with the `react-instantsearch-core` and `react-instantsearch-dom` packages, so make sure to use the component from `react-instantsearch-hooks`.');\n return search;\n}","import { useContext } from 'react';\nimport { InstantSearchSSRContext } from \"./InstantSearchSSRContext.js\";\nexport function useInstantSearchSSRContext() {\n return useContext(InstantSearchSSRContext);\n}","import { useContext } from 'react';\nimport { InstantSearchServerContext } from \"../components/InstantSearchServerContext.js\";\nexport function useInstantSearchServerContext() {\n return useContext(InstantSearchServerContext);\n}","import { useEffect, useLayoutEffect } from 'react';\n\n/**\n * `useLayoutEffect` that doesn't show a warning when server-side rendering.\n *\n * It uses `useEffect` on the server (no-op), and `useLayoutEffect` on the browser.\n */\nexport var useIsomorphicLayoutEffect = typeof window !== 'undefined' ? useLayoutEffect : useEffect;","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useEffect, useState } from 'react';\nimport { getIndexSearchResults } from \"./getIndexSearchResults.js\";\nimport { useIndexContext } from \"./useIndexContext.js\";\nimport { useInstantSearchContext } from \"./useInstantSearchContext.js\";\nexport function useSearchResults() {\n var search = useInstantSearchContext();\n var searchIndex = useIndexContext();\n var _useState = useState(function () {\n return getIndexSearchResults(searchIndex);\n }),\n _useState2 = _slicedToArray(_useState, 2),\n searchResults = _useState2[0],\n setSearchResults = _useState2[1];\n useEffect(function () {\n function handleRender() {\n var results = searchIndex.getResults();\n\n // Results can be `null` when the first search is stalled.\n // In this case, we skip the update.\n // See: https://github.com/algolia/instantsearch.js/blob/20996c7a159988c58e00ff24d2d2dc98af8b980f/src/widgets/index/index.ts#L652-L657\n if (results !== null) {\n setSearchResults({\n results: results,\n scopedResults: searchIndex.getScopedResults()\n });\n }\n }\n search.addListener('render', handleRender);\n return function () {\n search.removeListener('render', handleRender);\n };\n }, [search, searchIndex]);\n return searchResults;\n}","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useCallback, useEffect, useState } from 'react';\nimport { useIndexContext } from \"./useIndexContext.js\";\nimport { useInstantSearchContext } from \"./useInstantSearchContext.js\";\nexport function useSearchState() {\n var search = useInstantSearchContext();\n var searchIndex = useIndexContext();\n var indexId = searchIndex.getIndexId();\n var _useState = useState(function () {\n return search.getUiState();\n }),\n _useState2 = _slicedToArray(_useState, 2),\n uiState = _useState2[0],\n setLocalUiState = _useState2[1];\n var indexUiState = uiState[indexId];\n var setUiState = useCallback(function (nextUiState) {\n search.setUiState(nextUiState);\n }, [search]);\n var setIndexUiState = useCallback(function (nextIndexUiState) {\n searchIndex.setIndexUiState(nextIndexUiState);\n }, [searchIndex]);\n useEffect(function () {\n function handleRender() {\n setLocalUiState(search.getUiState());\n }\n search.addListener('render', handleRender);\n return function () {\n search.removeListener('render', handleRender);\n };\n }, [search]);\n return {\n uiState: uiState,\n setUiState: setUiState,\n indexUiState: indexUiState,\n setIndexUiState: setIndexUiState\n };\n}","function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }\nfunction _nonIterableRest() { throw new TypeError(\"Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.\"); }\nfunction _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === \"string\") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === \"Object\" && o.constructor) n = o.constructor.name; if (n === \"Map\" || n === \"Set\") return Array.from(o); if (n === \"Arguments\" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }\nfunction _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }\nfunction _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : \"undefined\" != typeof Symbol && arr[Symbol.iterator] || arr[\"@@iterator\"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }\nfunction _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }\nimport { useState } from 'react';\nimport { dequal } from \"./dequal.js\";\nexport function useStableValue(value) {\n var _useState = useState(function () {\n return value;\n }),\n _useState2 = _slicedToArray(_useState, 2),\n stableValue = _useState2[0],\n setStableValue = _useState2[1];\n if (!dequal(stableValue, value)) {\n setStableValue(value);\n }\n return stableValue;\n}","import { useEffect, useRef } from 'react';\nimport { dequal } from \"./dequal.js\";\nimport { useInstantSearchContext } from \"./useInstantSearchContext.js\";\nimport { useIsomorphicLayoutEffect } from \"./useIsomorphicLayoutEffect.js\";\nexport function useWidget(_ref) {\n var widget = _ref.widget,\n parentIndex = _ref.parentIndex,\n props = _ref.props,\n shouldSsr = _ref.shouldSsr;\n var prevPropsRef = useRef(props);\n useEffect(function () {\n prevPropsRef.current = props;\n }, [props]);\n var prevWidgetRef = useRef(widget);\n useEffect(function () {\n prevWidgetRef.current = widget;\n }, [widget]);\n var cleanupTimerRef = useRef(null);\n var shouldAddWidgetEarly = shouldSsr && !parentIndex.getWidgets().includes(widget);\n var search = useInstantSearchContext();\n\n // This effect is responsible for adding, removing, and updating the widget.\n // We need to support scenarios where the widget is remounted quickly, like in\n // Strict Mode, so that we don't lose its state, and therefore that we don't\n // break routing.\n useIsomorphicLayoutEffect(function () {\n var previousWidget = prevWidgetRef.current;\n\n // Scenario 1: the widget is added for the first time.\n if (!cleanupTimerRef.current) {\n if (!shouldAddWidgetEarly) {\n parentIndex.addWidgets([widget]);\n }\n }\n // Scenario 2: the widget is rerendered or updated.\n else {\n // We cancel the original effect cleanup because it may not be necessary if\n // props haven't changed. (We manually call it if it is below.)\n clearTimeout(cleanupTimerRef.current);\n\n // Warning: if an unstable function prop is provided, `dequal` is not able\n // to keep its reference and therefore will consider that props did change.\n // This could unsollicitely remove/add the widget, therefore forget its state,\n // and could be a source of confusion.\n // If users face this issue, we should advise them to provide stable function\n // references.\n var arePropsEqual = dequal(props, prevPropsRef.current);\n\n // If props did change, then we execute the cleanup function instantly\n // and then add the widget back. This lets us add the widget without\n // waiting for the scheduled cleanup function to finish (that we canceled\n // above).\n if (!arePropsEqual) {\n parentIndex.removeWidgets([previousWidget]);\n parentIndex.addWidgets([widget]);\n }\n }\n return function () {\n // We don't remove the widget right away, but rather schedule it so that\n // we're able to cancel it in the next effect.\n cleanupTimerRef.current = setTimeout(function () {\n search._schedule(function () {\n if (search._preventWidgetCleanup) return;\n parentIndex.removeWidgets([previousWidget]);\n });\n });\n };\n }, [parentIndex, widget, shouldAddWidgetEarly, search, props]);\n if (shouldAddWidgetEarly) {\n parentIndex.addWidgets([widget]);\n }\n}","/* eslint-disable no-console, no-empty */\n\nexport var warnCache = {\n current: {}\n};\n\n/**\n * Logs a warning if the condition is not met.\n * This is used to log issues in development environment only.\n */\nexport function warn(condition, message) {\n if (!(process.env.NODE_ENV === 'development')) {\n return;\n }\n if (condition) {\n return;\n }\n var sanitizedMessage = message.trim();\n var hasAlreadyPrinted = warnCache.current[sanitizedMessage];\n if (!hasAlreadyPrinted) {\n warnCache.current[sanitizedMessage] = true;\n var warning = \"[InstantSearch] \".concat(sanitizedMessage);\n console.warn(warning);\n try {\n // Welcome to debugging InstantSearch.\n //\n // This error was thrown as a convenience so that you can find the source\n // of the warning that appears in the console by enabling \"Pause on exceptions\"\n // in your debugger.\n throw new Error(warning);\n } catch (error) {}\n }\n}","export default '6.38.1';","// The module cache\nvar __webpack_module_cache__ = {};\n\n// The require function\nfunction __webpack_require__(moduleId) {\n\t// Check if module is in cache\n\tvar cachedModule = __webpack_module_cache__[moduleId];\n\tif (cachedModule !== undefined) {\n\t\treturn cachedModule.exports;\n\t}\n\t// Create a new module (and put it into the cache)\n\tvar module = __webpack_module_cache__[moduleId] = {\n\t\t// no module.id needed\n\t\t// no module.loaded needed\n\t\texports: {}\n\t};\n\n\t// Execute the module function\n\t__webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n","// getDefaultExport function for compatibility with non-harmony modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};","// define getter functions for harmony exports\n__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n\t\tif(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n\t\t\tObject.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n\t\t}\n\t}\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","","// startup\n// Load entry module and return exports\n// This entry module is referenced by other modules so it can't be inlined\nvar __webpack_exports__ = __webpack_require__(\"./src/index.js\");\n",""],"names":["ReactComponent","Go","AlgoliaResult","searchTitle","onGo","useEffect","useState","useRef","__","Analytics","InteractionAPIs","Feedback","postId","status","setStatus","yesButtonRef","noButtonRef","postFeedback","sendEvent","current","className","SearchResults","algoliasearch","Configure","Index","InstantSearch","HelpCenter","props","searchClient","LoaderIcon","Loader","CloseIcon","Help","toggleHelp","LocalStorageUtils","Modal","onClose","helpVisible","getHelpVisible","NoResultIllustration","NoResults","ResultContent","content","noResult","length","__html","debounce","useMemo","useInstantSearch","useSearchBox","moduleAI","SearchIcon","isLoading","setIsLoading","setNoResult","searchInput","setSearchInput","resultContent","setResultContent","setPostId","query","refine","clear","results","populateSearchResult","resultContentFormatted","replace","persistResult","persistSearchInput","currentResultContent","currentResultPostId","getResultInfo","input","getSearchInput","getResultMatches","proximity","words","getAIResult","hits","resultMatches","_rankingInfo","proximityDistance","post_id","result","search","getSearchResult","exception","console","log","debouncedResults","cancel","document","getElementById","focus","flexGrow","e","target","value","undefined","key","map","post_title","PluginSidebar","React","render","registerPlugin","HiiveAnalytics","HiiveEvent","initialize","urls","single","window","nfdHelpCenter","restUrl","wpContentContainer","visible","classList","toggle","nfdHelpContainer","updateHelpVisible","newfoldEmbeddedHelp","toggleNFDLaunchedEmbeddedHelp","Object","is","toggleNFDUnlaunchedEmbeddedHelp","helpContainer","removeChild","renderEmbeddedHelp","HelpCenterPluginSidebar","createElement","id","style","display","appendChild","DOM_TARGET","apiFetch","base","path","method","data","localStorage","setItem","getItem","event","hiiveEvent","time","Date","send"],"sourceRoot":""} \ No newline at end of file diff --git a/includes/HelpCenter.php b/includes/HelpCenter.php index f1186cb..7e0109f 100644 --- a/includes/HelpCenter.php +++ b/includes/HelpCenter.php @@ -59,11 +59,11 @@ public function newfold_help_center( \WP_Admin_Bar $admin_bar ) { ), ); $help_enabled = $this->container->get('capabilities')->get( 'canAccessHelpCenter' ); - if ( $help_enabled ) { + // if ( $help_enabled ) { $admin_bar->add_menu( $help_center_menu ); $menu_name = $this->container->plugin()->id . '-help-center'; $admin_bar->remove_menu( $menu_name ); - } + // } } } @@ -86,6 +86,12 @@ public function register_assets() { NFD_HELPCENTER_PLUGIN_URL . 'vendor/newfold-labs/wp-module-help-center/build/index.css', null, '1', 'screen' ); + + \wp_add_inline_script( + 'nfd-helpcenter-dependency', + 'var nfdHelpCenter =' . wp_json_encode( array( 'restUrl' => \get_home_url() . '/index.php?rest_route=', ) ) . ';', + 'before' + ); } } } diff --git a/package-lock.json b/package-lock.json index 779617b..37f9ca5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,21389 +1,7 @@ { "name": "@newfold-labs/wp-module-help-center", - "lockfileVersion": 2, "requires": true, - "packages": { - "": { - "name": "@newfold-labs/wp-module-help-center", - "license": "MIT", - "dependencies": { - "@newfold-labs/wp-module-ai": "github:newfold-labs/js-utility-ai#1.0.0", - "@wordpress/api-fetch": "6.20.0", - "@wordpress/components": "23.0.0", - "@wordpress/data": "8.3.0", - "@wordpress/edit-post": "7.2.0", - "@wordpress/element": "5.0.0", - "@wordpress/i18n": "4.23.0", - "@wordpress/plugins": "5.2.0", - "algoliasearch": "4.17.0", - "lodash.debounce": "4.0.8", - "react-instantsearch-hooks-web": "6.43.0", - "react-router-dom": "6.6.2" - }, - "devDependencies": { - "@wordpress/scripts": "25.0.0" - } - }, - "../wp-module-ai": { - "extraneous": true, - "dependencies": { - "@wordpress/api-fetch": "^6.28.0" - } - }, - "node_modules/@algolia/cache-browser-local-storage": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/cache-browser-local-storage/-/cache-browser-local-storage-4.17.0.tgz", - "integrity": "sha512-myRSRZDIMYB8uCkO+lb40YKiYHi0fjpWRtJpR/dgkaiBlSD0plRyB6lLOh1XIfmMcSeBOqDE7y9m8xZMrXYfyQ==", - "dependencies": { - "@algolia/cache-common": "4.17.0" - } - }, - "node_modules/@algolia/cache-common": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/cache-common/-/cache-common-4.17.0.tgz", - "integrity": "sha512-g8mXzkrcUBIPZaulAuqE7xyHhLAYAcF2xSch7d9dABheybaU3U91LjBX6eJTEB7XVhEsgK4Smi27vWtAJRhIKQ==" - }, - "node_modules/@algolia/cache-in-memory": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/cache-in-memory/-/cache-in-memory-4.17.0.tgz", - "integrity": "sha512-PT32ciC/xI8z919d0oknWVu3kMfTlhQn3MKxDln3pkn+yA7F7xrxSALysxquv+MhFfNAcrtQ/oVvQVBAQSHtdw==", - "dependencies": { - "@algolia/cache-common": "4.17.0" - } - }, - "node_modules/@algolia/client-account": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/client-account/-/client-account-4.17.0.tgz", - "integrity": "sha512-sSEHx9GA6m7wrlsSMNBGfyzlIfDT2fkz2u7jqfCCd6JEEwmxt8emGmxAU/0qBfbhRSuGvzojoLJlr83BSZAKjA==", - "dependencies": { - "@algolia/client-common": "4.17.0", - "@algolia/client-search": "4.17.0", - "@algolia/transporter": "4.17.0" - } - }, - "node_modules/@algolia/client-analytics": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/client-analytics/-/client-analytics-4.17.0.tgz", - "integrity": "sha512-84ooP8QA3mQ958hQ9wozk7hFUbAO+81CX1CjAuerxBqjKIInh1fOhXKTaku05O/GHBvcfExpPLIQuSuLYziBXQ==", - "dependencies": { - "@algolia/client-common": "4.17.0", - "@algolia/client-search": "4.17.0", - "@algolia/requester-common": "4.17.0", - "@algolia/transporter": "4.17.0" - } - }, - "node_modules/@algolia/client-common": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/client-common/-/client-common-4.17.0.tgz", - "integrity": "sha512-jHMks0ZFicf8nRDn6ma8DNNsdwGgP/NKiAAL9z6rS7CymJ7L0+QqTJl3rYxRW7TmBhsUH40wqzmrG6aMIN/DrQ==", - "dependencies": { - "@algolia/requester-common": "4.17.0", - "@algolia/transporter": "4.17.0" - } - }, - "node_modules/@algolia/client-personalization": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/client-personalization/-/client-personalization-4.17.0.tgz", - "integrity": "sha512-RMzN4dZLIta1YuwT7QC9o+OeGz2cU6eTOlGNE/6RcUBLOU3l9tkCOdln5dPE2jp8GZXPl2yk54b2nSs1+pAjqw==", - "dependencies": { - "@algolia/client-common": "4.17.0", - "@algolia/requester-common": "4.17.0", - "@algolia/transporter": "4.17.0" - } - }, - "node_modules/@algolia/client-search": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/client-search/-/client-search-4.17.0.tgz", - "integrity": "sha512-x4P2wKrrRIXszT8gb7eWsMHNNHAJs0wE7/uqbufm4tZenAp+hwU/hq5KVsY50v+PfwM0LcDwwn/1DroujsTFoA==", - "dependencies": { - "@algolia/client-common": "4.17.0", - "@algolia/requester-common": "4.17.0", - "@algolia/transporter": "4.17.0" - } - }, - "node_modules/@algolia/events": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/@algolia/events/-/events-4.0.1.tgz", - "integrity": "sha512-FQzvOCgoFXAbf5Y6mYozw2aj5KCJoA3m4heImceldzPSMbdyS4atVjJzXKMsfX3wnZTFYwkkt8/z8UesLHlSBQ==" - }, - "node_modules/@algolia/logger-common": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/logger-common/-/logger-common-4.17.0.tgz", - "integrity": "sha512-DGuoZqpTmIKJFDeyAJ7M8E/LOenIjWiOsg1XJ1OqAU/eofp49JfqXxbfgctlVZVmDABIyOz8LqEoJ6ZP4DTyvw==" - }, - "node_modules/@algolia/logger-console": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/logger-console/-/logger-console-4.17.0.tgz", - "integrity": "sha512-zMPvugQV/gbXUvWBCzihw6m7oxIKp48w37QBIUu/XqQQfxhjoOE9xyfJr1KldUt5FrYOKZJVsJaEjTsu+bIgQg==", - "dependencies": { - "@algolia/logger-common": "4.17.0" - } - }, - "node_modules/@algolia/requester-browser-xhr": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/requester-browser-xhr/-/requester-browser-xhr-4.17.0.tgz", - "integrity": "sha512-aSOX/smauyTkP21Pf52pJ1O2LmNFJ5iHRIzEeTh0mwBeADO4GdG94cAWDILFA9rNblq/nK3EDh3+UyHHjplZ1A==", - "dependencies": { - "@algolia/requester-common": "4.17.0" - } - }, - "node_modules/@algolia/requester-common": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/requester-common/-/requester-common-4.17.0.tgz", - "integrity": "sha512-XJjmWFEUlHu0ijvcHBoixuXfEoiRUdyzQM6YwTuB8usJNIgShua8ouFlRWF8iCeag0vZZiUm4S2WCVBPkdxFgg==" - }, - "node_modules/@algolia/requester-node-http": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/requester-node-http/-/requester-node-http-4.17.0.tgz", - "integrity": "sha512-bpb/wDA1aC6WxxM8v7TsFspB7yBN3nqCGs2H1OADolQR/hiAIjAxusbuMxVbRFOdaUvAIqioIIkWvZdpYNIn8w==", - "dependencies": { - "@algolia/requester-common": "4.17.0" - } - }, - "node_modules/@algolia/transporter": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/@algolia/transporter/-/transporter-4.17.0.tgz", - "integrity": "sha512-6xL6H6fe+Fi0AEP3ziSgC+G04RK37iRb4uUUqVAH9WPYFI8g+LYFq6iv5HS8Cbuc5TTut+Bwj6G+dh/asdb9uA==", - "dependencies": { - "@algolia/cache-common": "4.17.0", - "@algolia/logger-common": "4.17.0", - "@algolia/requester-common": "4.17.0" - } - }, - "node_modules/@algolia/ui-components-highlight-vdom": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@algolia/ui-components-highlight-vdom/-/ui-components-highlight-vdom-1.2.1.tgz", - "integrity": "sha512-IlYgIaCUEkz9ezNbwugwKv991oOHhveyq6nzL0F1jDzg1p3q5Yj/vO4KpNG910r2dwGCG3nEm5GtChcLnarhFA==", - "dependencies": { - "@algolia/ui-components-shared": "1.2.1", - "@babel/runtime": "^7.0.0" - } - }, - "node_modules/@algolia/ui-components-shared": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@algolia/ui-components-shared/-/ui-components-shared-1.2.1.tgz", - "integrity": "sha512-a7mYHf/GVQfhAx/HRiMveKkFvHspQv/REdG+C/FIOosiSmNZxX7QebDwJkrGSmDWdXO12D0Qv1xn3AytFcEDlQ==" - }, - "node_modules/@ampproject/remapping": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz", - "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==", - "dependencies": { - "@jridgewell/gen-mapping": "^0.1.0", - "@jridgewell/trace-mapping": "^0.3.9" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@babel/code-frame": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.18.6.tgz", - "integrity": "sha512-TDCmlK5eOvH+eH7cdAFlNXeVJqWIQ7gW9tY1GJIpUtFb6CmjVyq2VM3u71bOyR8CRihcCgMUYoDNyLXao3+70Q==", - "dependencies": { - "@babel/highlight": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/compat-data": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.20.5.tgz", - "integrity": "sha512-KZXo2t10+/jxmkhNXc7pZTqRvSOIvVv/+lJwHS+B2rErwOyjuVRh60yVpb7liQ1U5t7lLJ1bz+t8tSypUZdm0g==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/core": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.20.5.tgz", - "integrity": "sha512-UdOWmk4pNWTm/4DlPUl/Pt4Gz4rcEMb7CY0Y3eJl5Yz1vI8ZJGmHWaVE55LoxRjdpx0z259GE9U5STA9atUinQ==", - "dependencies": { - "@ampproject/remapping": "^2.1.0", - "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.20.5", - "@babel/helper-compilation-targets": "^7.20.0", - "@babel/helper-module-transforms": "^7.20.2", - "@babel/helpers": "^7.20.5", - "@babel/parser": "^7.20.5", - "@babel/template": "^7.18.10", - "@babel/traverse": "^7.20.5", - "@babel/types": "^7.20.5", - "convert-source-map": "^1.7.0", - "debug": "^4.1.0", - "gensync": "^1.0.0-beta.2", - "json5": "^2.2.1", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/babel" - } - }, - "node_modules/@babel/eslint-parser": { - "version": "7.19.1", - "resolved": "https://registry.npmjs.org/@babel/eslint-parser/-/eslint-parser-7.19.1.tgz", - "integrity": "sha512-AqNf2QWt1rtu2/1rLswy6CDP7H9Oh3mMhk177Y67Rg8d7RD9WfOLLv8CGn6tisFvS2htm86yIe1yLF6I1UDaGQ==", - "dev": true, - "dependencies": { - "@nicolo-ribaudo/eslint-scope-5-internals": "5.1.1-v1", - "eslint-visitor-keys": "^2.1.0", - "semver": "^6.3.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || >=14.0.0" - }, - "peerDependencies": { - "@babel/core": ">=7.11.0", - "eslint": "^7.5.0 || ^8.0.0" - } - }, - "node_modules/@babel/generator": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.20.5.tgz", - "integrity": "sha512-jl7JY2Ykn9S0yj4DQP82sYvPU+T3g0HFcWTqDLqiuA9tGRNIj9VfbtXGAYTTkyNEnQk1jkMGOdYka8aG/lulCA==", - "dependencies": { - "@babel/types": "^7.20.5", - "@jridgewell/gen-mapping": "^0.3.2", - "jsesc": "^2.5.1" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/generator/node_modules/@jridgewell/gen-mapping": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", - "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", - "dependencies": { - "@jridgewell/set-array": "^1.0.1", - "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@babel/helper-annotate-as-pure": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.18.6.tgz", - "integrity": "sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==", - "dev": true, - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.18.9.tgz", - "integrity": "sha512-yFQ0YCHoIqarl8BCRwBL8ulYUaZpz3bNsA7oFepAzee+8/+ImtADXNOmO5vJvsPff3qi+hvpkY/NYBTrBQgdNw==", - "dev": true, - "dependencies": { - "@babel/helper-explode-assignable-expression": "^7.18.6", - "@babel/types": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-compilation-targets": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.0.tgz", - "integrity": "sha512-0jp//vDGp9e8hZzBc6N/KwA5ZK3Wsm/pfm4CrY7vzegkVxc65SgSn6wYOnwHe9Js9HRQ1YTCKLGPzDtaS3RoLQ==", - "dependencies": { - "@babel/compat-data": "^7.20.0", - "@babel/helper-validator-option": "^7.18.6", - "browserslist": "^4.21.3", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-create-class-features-plugin": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.20.5.tgz", - "integrity": "sha512-3RCdA/EmEaikrhayahwToF0fpweU/8o2p8vhc1c/1kftHOdTKuC65kik/TLc+qfbS8JKw4qqJbne4ovICDhmww==", - "dev": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.19.0", - "@babel/helper-member-expression-to-functions": "^7.18.9", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/helper-replace-supers": "^7.19.1", - "@babel/helper-split-export-declaration": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-create-regexp-features-plugin": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.20.5.tgz", - "integrity": "sha512-m68B1lkg3XDGX5yCvGO0kPx3v9WIYLnzjKfPcQiwntEQa5ZeRkPmo2X/ISJc8qxWGfwUr+kvZAeEzAwLec2r2w==", - "dev": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "regexpu-core": "^5.2.1" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-define-polyfill-provider": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@babel/helper-define-polyfill-provider/-/helper-define-polyfill-provider-0.3.3.tgz", - "integrity": "sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww==", - "dev": true, - "dependencies": { - "@babel/helper-compilation-targets": "^7.17.7", - "@babel/helper-plugin-utils": "^7.16.7", - "debug": "^4.1.1", - "lodash.debounce": "^4.0.8", - "resolve": "^1.14.2", - "semver": "^6.1.2" - }, - "peerDependencies": { - "@babel/core": "^7.4.0-0" - } - }, - "node_modules/@babel/helper-environment-visitor": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz", - "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-explode-assignable-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.18.6.tgz", - "integrity": "sha512-eyAYAsQmB80jNfg4baAtLeWAQHfHFiR483rzFK+BhETlGZaQC9bsfrugfXDCbRHLQbIA7U5NxhhOxN7p/dWIcg==", - "dev": true, - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-function-name": { - "version": "7.19.0", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz", - "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==", - "dependencies": { - "@babel/template": "^7.18.10", - "@babel/types": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-hoist-variables": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", - "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-member-expression-to-functions": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.18.9.tgz", - "integrity": "sha512-RxifAh2ZoVU67PyKIO4AMi1wTenGfMR/O/ae0CCRqwgBAt5v7xjdtRw7UoSbsreKrQn5t7r89eruK/9JjYHuDg==", - "dev": true, - "dependencies": { - "@babel/types": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-module-imports": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.18.6.tgz", - "integrity": "sha512-0NFvs3VkuSYbFi1x2Vd6tKrywq+z/cLeYC/RJNFrIX/30Bf5aiGYbtvGXolEktzJH8o5E5KJ3tT+nkxuuZFVlA==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-module-transforms": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.20.2.tgz", - "integrity": "sha512-zvBKyJXRbmK07XhMuujYoJ48B5yvvmM6+wcpv6Ivj4Yg6qO7NOZOSnvZN9CRl1zz1Z4cKf8YejmCMh8clOoOeA==", - "dependencies": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-simple-access": "^7.20.2", - "@babel/helper-split-export-declaration": "^7.18.6", - "@babel/helper-validator-identifier": "^7.19.1", - "@babel/template": "^7.18.10", - "@babel/traverse": "^7.20.1", - "@babel/types": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-optimise-call-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.18.6.tgz", - "integrity": "sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==", - "dev": true, - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-plugin-utils": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.20.2.tgz", - "integrity": "sha512-8RvlJG2mj4huQ4pZ+rU9lqKi9ZKiRmuvGuM2HlWmkmgOhbs6zEAw6IEiJ5cQqGbDzGZOhwuOQNtZMi/ENLjZoQ==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-remap-async-to-generator": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.18.9.tgz", - "integrity": "sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==", - "dev": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-wrap-function": "^7.18.9", - "@babel/types": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/helper-replace-supers": { - "version": "7.19.1", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.19.1.tgz", - "integrity": "sha512-T7ahH7wV0Hfs46SFh5Jz3s0B6+o8g3c+7TMxu7xKfmHikg7EAZ3I2Qk9LFhjxXq8sL7UkP5JflezNwoZa8WvWw==", - "dev": true, - "dependencies": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-member-expression-to-functions": "^7.18.9", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/traverse": "^7.19.1", - "@babel/types": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-simple-access": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz", - "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==", - "dependencies": { - "@babel/types": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-skip-transparent-expression-wrappers": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.20.0.tgz", - "integrity": "sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==", - "dev": true, - "dependencies": { - "@babel/types": "^7.20.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-split-export-declaration": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", - "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", - "dependencies": { - "@babel/types": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-string-parser": { - "version": "7.19.4", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.19.4.tgz", - "integrity": "sha512-nHtDoQcuqFmwYNYPz3Rah5ph2p8PFeFCsZk9A/48dPc/rGocJ5J3hAAZ7pb76VWX3fZKu+uEr/FhH5jLx7umrw==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-validator-identifier": { - "version": "7.19.1", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.19.1.tgz", - "integrity": "sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-validator-option": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz", - "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helper-wrap-function": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.20.5.tgz", - "integrity": "sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q==", - "dev": true, - "dependencies": { - "@babel/helper-function-name": "^7.19.0", - "@babel/template": "^7.18.10", - "@babel/traverse": "^7.20.5", - "@babel/types": "^7.20.5" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/helpers": { - "version": "7.20.6", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.20.6.tgz", - "integrity": "sha512-Pf/OjgfgFRW5bApskEz5pvidpim7tEDPlFtKcNRXWmfHGn9IEI2W2flqRQXTFb7gIPTyK++N6rVHuwKut4XK6w==", - "dependencies": { - "@babel/template": "^7.18.10", - "@babel/traverse": "^7.20.5", - "@babel/types": "^7.20.5" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/highlight": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.18.6.tgz", - "integrity": "sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==", - "dependencies": { - "@babel/helper-validator-identifier": "^7.18.6", - "chalk": "^2.0.0", - "js-tokens": "^4.0.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/parser": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.20.5.tgz", - "integrity": "sha512-r27t/cy/m9uKLXQNWWebeCUHgnAZq0CpG1OwKRxzJMP1vpSU4bSIK2hq+/cp0bQxetkXx38n09rNu8jVkcK/zA==", - "bin": { - "parser": "bin/babel-parser.js" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.18.6.tgz", - "integrity": "sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.18.9.tgz", - "integrity": "sha512-AHrP9jadvH7qlOj6PINbgSuphjQUAK7AOT7DPjBo9EHoLhQTnnK5u45e1Hd4DbSQEO9nqPWtQ89r+XEOWFScKg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9", - "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9", - "@babel/plugin-proposal-optional-chaining": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.13.0" - } - }, - "node_modules/@babel/plugin-proposal-async-generator-functions": { - "version": "7.20.1", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.20.1.tgz", - "integrity": "sha512-Gh5rchzSwE4kC+o/6T8waD0WHEQIsDmjltY8WnWRXHUdH8axZhuH86Ov9M72YhJfDrZseQwuuWaaIT/TmePp3g==", - "dev": true, - "dependencies": { - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-plugin-utils": "^7.19.0", - "@babel/helper-remap-async-to-generator": "^7.18.9", - "@babel/plugin-syntax-async-generators": "^7.8.4" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-class-properties": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.18.6.tgz", - "integrity": "sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==", - "dev": true, - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-class-static-block": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-static-block/-/plugin-proposal-class-static-block-7.18.6.tgz", - "integrity": "sha512-+I3oIiNxrCpup3Gi8n5IGMwj0gOCAjcJUSQEcotNnCCPMEnixawOQ+KeJPlgfjzx+FKQ1QSyZOWe7wmoJp7vhw==", - "dev": true, - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-class-static-block": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.12.0" - } - }, - "node_modules/@babel/plugin-proposal-dynamic-import": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.18.6.tgz", - "integrity": "sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-dynamic-import": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-export-namespace-from": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-export-namespace-from/-/plugin-proposal-export-namespace-from-7.18.9.tgz", - "integrity": "sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9", - "@babel/plugin-syntax-export-namespace-from": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-json-strings": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.18.6.tgz", - "integrity": "sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-json-strings": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-logical-assignment-operators": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-logical-assignment-operators/-/plugin-proposal-logical-assignment-operators-7.18.9.tgz", - "integrity": "sha512-128YbMpjCrP35IOExw2Fq+x55LMP42DzhOhX2aNNIdI9avSWl2PI0yuBWarr3RYpZBSPtabfadkH2yeRiMD61Q==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9", - "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-nullish-coalescing-operator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.18.6.tgz", - "integrity": "sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-numeric-separator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.18.6.tgz", - "integrity": "sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-numeric-separator": "^7.10.4" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-object-rest-spread": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.20.2.tgz", - "integrity": "sha512-Ks6uej9WFK+fvIMesSqbAto5dD8Dz4VuuFvGJFKgIGSkJuRGcrwGECPA1fDgQK3/DbExBJpEkTeYeB8geIFCSQ==", - "dev": true, - "dependencies": { - "@babel/compat-data": "^7.20.1", - "@babel/helper-compilation-targets": "^7.20.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-transform-parameters": "^7.20.1" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-optional-catch-binding": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.18.6.tgz", - "integrity": "sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-optional-chaining": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.18.9.tgz", - "integrity": "sha512-v5nwt4IqBXihxGsW2QmCWMDS3B3bzGIk/EQVZz2ei7f3NJl8NzAJVvUmpDW5q1CRNY+Beb/k58UAH1Km1N411w==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9", - "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9", - "@babel/plugin-syntax-optional-chaining": "^7.8.3" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-private-methods": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-methods/-/plugin-proposal-private-methods-7.18.6.tgz", - "integrity": "sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==", - "dev": true, - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-private-property-in-object": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-private-property-in-object/-/plugin-proposal-private-property-in-object-7.20.5.tgz", - "integrity": "sha512-Vq7b9dUA12ByzB4EjQTPo25sFhY+08pQDBSZRtUAkj7lb7jahaHR5igera16QZ+3my1nYR4dKsNdYj5IjPHilQ==", - "dev": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-create-class-features-plugin": "^7.20.5", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-private-property-in-object": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-proposal-unicode-property-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.18.6.tgz", - "integrity": "sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==", - "dev": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-async-generators": { - "version": "7.8.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", - "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-bigint": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz", - "integrity": "sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-class-properties": { - "version": "7.12.13", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz", - "integrity": "sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.12.13" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-class-static-block": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-class-static-block/-/plugin-syntax-class-static-block-7.14.5.tgz", - "integrity": "sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-dynamic-import": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", - "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-export-namespace-from": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-export-namespace-from/-/plugin-syntax-export-namespace-from-7.8.3.tgz", - "integrity": "sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.3" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-import-assertions": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.20.0.tgz", - "integrity": "sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-import-meta": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz", - "integrity": "sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.10.4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-json-strings": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", - "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-jsx": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.18.6.tgz", - "integrity": "sha512-6mmljtAedFGTWu2p/8WIORGwy+61PLgOMPOdazc7YoJ9ZCWUyFy3A6CpPkRKLKD1ToAesxX8KGEViAiLo9N+7Q==", - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-logical-assignment-operators": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz", - "integrity": "sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.10.4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-nullish-coalescing-operator": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", - "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-numeric-separator": { - "version": "7.10.4", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz", - "integrity": "sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.10.4" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-object-rest-spread": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", - "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-optional-catch-binding": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", - "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-optional-chaining": { - "version": "7.8.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", - "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.8.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-private-property-in-object": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-private-property-in-object/-/plugin-syntax-private-property-in-object-7.14.5.tgz", - "integrity": "sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-top-level-await": { - "version": "7.14.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz", - "integrity": "sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.14.5" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-syntax-typescript": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.20.0.tgz", - "integrity": "sha512-rd9TkG+u1CExzS4SM1BlMEhMXwFLKVjOAFFCDx9PbX5ycJWDoWMcwdJH9RhkPu1dOgn5TrxLot/Gx6lWFuAUNQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-arrow-functions": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.18.6.tgz", - "integrity": "sha512-9S9X9RUefzrsHZmKMbDXxweEH+YlE8JJEuat9FdvW9Qh1cw7W64jELCtWNkPBPX5En45uy28KGvA/AySqUh8CQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-async-to-generator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.18.6.tgz", - "integrity": "sha512-ARE5wZLKnTgPW7/1ftQmSi1CmkqqHo2DNmtztFhvgtOWSDfq0Cq9/9L+KnZNYSNrydBekhW3rwShduf59RoXag==", - "dev": true, - "dependencies": { - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-remap-async-to-generator": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-block-scoped-functions": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.18.6.tgz", - "integrity": "sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-block-scoping": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.20.5.tgz", - "integrity": "sha512-WvpEIW9Cbj9ApF3yJCjIEEf1EiNJLtXagOrL5LNWEZOo3jv8pmPoYTSNJQvqej8OavVlgOoOPw6/htGZro6IkA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-classes": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.20.2.tgz", - "integrity": "sha512-9rbPp0lCVVoagvtEyQKSo5L8oo0nQS/iif+lwlAz29MccX2642vWDlSZK+2T2buxbopotId2ld7zZAzRfz9j1g==", - "dev": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-compilation-targets": "^7.20.0", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.19.0", - "@babel/helper-optimise-call-expression": "^7.18.6", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-replace-supers": "^7.19.1", - "@babel/helper-split-export-declaration": "^7.18.6", - "globals": "^11.1.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-computed-properties": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.18.9.tgz", - "integrity": "sha512-+i0ZU1bCDymKakLxn5srGHrsAPRELC2WIbzwjLhHW9SIE1cPYkLCL0NlnXMZaM1vhfgA2+M7hySk42VBvrkBRw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-destructuring": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.20.2.tgz", - "integrity": "sha512-mENM+ZHrvEgxLTBXUiQ621rRXZes3KWUv6NdQlrnr1TkWVw+hUjQBZuP2X32qKlrlG2BzgR95gkuCRSkJl8vIw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-dotall-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.18.6.tgz", - "integrity": "sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==", - "dev": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-duplicate-keys": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.18.9.tgz", - "integrity": "sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-exponentiation-operator": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.18.6.tgz", - "integrity": "sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==", - "dev": true, - "dependencies": { - "@babel/helper-builder-binary-assignment-operator-visitor": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-for-of": { - "version": "7.18.8", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.18.8.tgz", - "integrity": "sha512-yEfTRnjuskWYo0k1mHUqrVWaZwrdq8AYbfrpqULOJOaucGSp4mNMVps+YtA8byoevxS/urwU75vyhQIxcCgiBQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-function-name": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.18.9.tgz", - "integrity": "sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==", - "dev": true, - "dependencies": { - "@babel/helper-compilation-targets": "^7.18.9", - "@babel/helper-function-name": "^7.18.9", - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-literals": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.18.9.tgz", - "integrity": "sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-member-expression-literals": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.18.6.tgz", - "integrity": "sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-amd": { - "version": "7.19.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.19.6.tgz", - "integrity": "sha512-uG3od2mXvAtIFQIh0xrpLH6r5fpSQN04gIVovl+ODLdUMANokxQLZnPBHcjmv3GxRjnqwLuHvppjjcelqUFZvg==", - "dev": true, - "dependencies": { - "@babel/helper-module-transforms": "^7.19.6", - "@babel/helper-plugin-utils": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-commonjs": { - "version": "7.19.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.19.6.tgz", - "integrity": "sha512-8PIa1ym4XRTKuSsOUXqDG0YaOlEuTVvHMe5JCfgBMOtHvJKw/4NGovEGN33viISshG/rZNVrACiBmPQLvWN8xQ==", - "dev": true, - "dependencies": { - "@babel/helper-module-transforms": "^7.19.6", - "@babel/helper-plugin-utils": "^7.19.0", - "@babel/helper-simple-access": "^7.19.4" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-systemjs": { - "version": "7.19.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.19.6.tgz", - "integrity": "sha512-fqGLBepcc3kErfR9R3DnVpURmckXP7gj7bAlrTQyBxrigFqszZCkFkcoxzCp2v32XmwXLvbw+8Yq9/b+QqksjQ==", - "dev": true, - "dependencies": { - "@babel/helper-hoist-variables": "^7.18.6", - "@babel/helper-module-transforms": "^7.19.6", - "@babel/helper-plugin-utils": "^7.19.0", - "@babel/helper-validator-identifier": "^7.19.1" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-modules-umd": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.18.6.tgz", - "integrity": "sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==", - "dev": true, - "dependencies": { - "@babel/helper-module-transforms": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-named-capturing-groups-regex": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.20.5.tgz", - "integrity": "sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA==", - "dev": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.20.5", - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@babel/plugin-transform-new-target": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.18.6.tgz", - "integrity": "sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-object-super": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.18.6.tgz", - "integrity": "sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-replace-supers": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-parameters": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.20.5.tgz", - "integrity": "sha512-h7plkOmcndIUWXZFLgpbrh2+fXAi47zcUX7IrOQuZdLD0I0KvjJ6cvo3BEcAOsDOcZhVKGJqv07mkSqK0y2isQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-property-literals": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.18.6.tgz", - "integrity": "sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-react-constant-elements": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-constant-elements/-/plugin-transform-react-constant-elements-7.20.2.tgz", - "integrity": "sha512-KS/G8YI8uwMGKErLFOHS/ekhqdHhpEloxs43NecQHVgo2QuQSyJhGIY1fL8UGl9wy5ItVwwoUL4YxVqsplGq2g==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-react-display-name": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.18.6.tgz", - "integrity": "sha512-TV4sQ+T013n61uMoygyMRm+xf04Bd5oqFpv2jAEQwSZ8NwQA7zeRPg1LMVg2PWi3zWBz+CLKD+v5bcpZ/BS0aA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-react-jsx": { - "version": "7.19.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.19.0.tgz", - "integrity": "sha512-UVEvX3tXie3Szm3emi1+G63jyw1w5IcMY0FSKM+CRnKRI5Mr1YbCNgsSTwoTwKphQEG9P+QqmuRFneJPZuHNhg==", - "dev": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-plugin-utils": "^7.19.0", - "@babel/plugin-syntax-jsx": "^7.18.6", - "@babel/types": "^7.19.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-react-jsx-development": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.18.6.tgz", - "integrity": "sha512-SA6HEjwYFKF7WDjWcMcMGUimmw/nhNRDWxr+KaLSCrkD/LMDBvWRmHAYgE1HDeF8KUuI8OAu+RT6EOtKxSW2qA==", - "dev": true, - "dependencies": { - "@babel/plugin-transform-react-jsx": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-react-pure-annotations": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-pure-annotations/-/plugin-transform-react-pure-annotations-7.18.6.tgz", - "integrity": "sha512-I8VfEPg9r2TRDdvnHgPepTKvuRomzA8+u+nhY7qSI1fR2hRNebasZEETLyM5mAUr0Ku56OkXJ0I7NHJnO6cJiQ==", - "dev": true, - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-regenerator": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.20.5.tgz", - "integrity": "sha512-kW/oO7HPBtntbsahzQ0qSE3tFvkFwnbozz3NWFhLGqH75vLEg+sCGngLlhVkePlCs3Jv0dBBHDzCHxNiFAQKCQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.20.2", - "regenerator-transform": "^0.15.1" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-reserved-words": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.18.6.tgz", - "integrity": "sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-runtime": { - "version": "7.19.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.19.6.tgz", - "integrity": "sha512-PRH37lz4JU156lYFW1p8OxE5i7d6Sl/zV58ooyr+q1J1lnQPyg5tIiXlIwNVhJaY4W3TmOtdc8jqdXQcB1v5Yw==", - "dev": true, - "dependencies": { - "@babel/helper-module-imports": "^7.18.6", - "@babel/helper-plugin-utils": "^7.19.0", - "babel-plugin-polyfill-corejs2": "^0.3.3", - "babel-plugin-polyfill-corejs3": "^0.6.0", - "babel-plugin-polyfill-regenerator": "^0.4.1", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-shorthand-properties": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.18.6.tgz", - "integrity": "sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-spread": { - "version": "7.19.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.19.0.tgz", - "integrity": "sha512-RsuMk7j6n+r752EtzyScnWkQyuJdli6LdO5Klv8Yx0OfPVTcQkIUfS8clx5e9yHXzlnhOZF3CbQ8C2uP5j074w==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.19.0", - "@babel/helper-skip-transparent-expression-wrappers": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-sticky-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.18.6.tgz", - "integrity": "sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-template-literals": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.18.9.tgz", - "integrity": "sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-typeof-symbol": { - "version": "7.18.9", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.18.9.tgz", - "integrity": "sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-typescript": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.20.2.tgz", - "integrity": "sha512-jvS+ngBfrnTUBfOQq8NfGnSbF9BrqlR6hjJ2yVxMkmO5nL/cdifNbI30EfjRlN4g5wYWNnMPyj5Sa6R1pbLeag==", - "dev": true, - "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.20.2", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/plugin-syntax-typescript": "^7.20.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-unicode-escapes": { - "version": "7.18.10", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.18.10.tgz", - "integrity": "sha512-kKAdAI+YzPgGY/ftStBFXTI1LZFju38rYThnfMykS+IXy8BVx+res7s2fxf1l8I35DV2T97ezo6+SGrXz6B3iQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.9" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/plugin-transform-unicode-regex": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.18.6.tgz", - "integrity": "sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==", - "dev": true, - "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.18.6", - "@babel/helper-plugin-utils": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-env": { - "version": "7.20.2", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.20.2.tgz", - "integrity": "sha512-1G0efQEWR1EHkKvKHqbG+IN/QdgwfByUpM5V5QroDzGV2t3S/WXNQd693cHiHTlCFMpr9B6FkPFXDA2lQcKoDg==", - "dev": true, - "dependencies": { - "@babel/compat-data": "^7.20.1", - "@babel/helper-compilation-targets": "^7.20.0", - "@babel/helper-plugin-utils": "^7.20.2", - "@babel/helper-validator-option": "^7.18.6", - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.18.6", - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.18.9", - "@babel/plugin-proposal-async-generator-functions": "^7.20.1", - "@babel/plugin-proposal-class-properties": "^7.18.6", - "@babel/plugin-proposal-class-static-block": "^7.18.6", - "@babel/plugin-proposal-dynamic-import": "^7.18.6", - "@babel/plugin-proposal-export-namespace-from": "^7.18.9", - "@babel/plugin-proposal-json-strings": "^7.18.6", - "@babel/plugin-proposal-logical-assignment-operators": "^7.18.9", - "@babel/plugin-proposal-nullish-coalescing-operator": "^7.18.6", - "@babel/plugin-proposal-numeric-separator": "^7.18.6", - "@babel/plugin-proposal-object-rest-spread": "^7.20.2", - "@babel/plugin-proposal-optional-catch-binding": "^7.18.6", - "@babel/plugin-proposal-optional-chaining": "^7.18.9", - "@babel/plugin-proposal-private-methods": "^7.18.6", - "@babel/plugin-proposal-private-property-in-object": "^7.18.6", - "@babel/plugin-proposal-unicode-property-regex": "^7.18.6", - "@babel/plugin-syntax-async-generators": "^7.8.4", - "@babel/plugin-syntax-class-properties": "^7.12.13", - "@babel/plugin-syntax-class-static-block": "^7.14.5", - "@babel/plugin-syntax-dynamic-import": "^7.8.3", - "@babel/plugin-syntax-export-namespace-from": "^7.8.3", - "@babel/plugin-syntax-import-assertions": "^7.20.0", - "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.10.4", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", - "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-private-property-in-object": "^7.14.5", - "@babel/plugin-syntax-top-level-await": "^7.14.5", - "@babel/plugin-transform-arrow-functions": "^7.18.6", - "@babel/plugin-transform-async-to-generator": "^7.18.6", - "@babel/plugin-transform-block-scoped-functions": "^7.18.6", - "@babel/plugin-transform-block-scoping": "^7.20.2", - "@babel/plugin-transform-classes": "^7.20.2", - "@babel/plugin-transform-computed-properties": "^7.18.9", - "@babel/plugin-transform-destructuring": "^7.20.2", - "@babel/plugin-transform-dotall-regex": "^7.18.6", - "@babel/plugin-transform-duplicate-keys": "^7.18.9", - "@babel/plugin-transform-exponentiation-operator": "^7.18.6", - "@babel/plugin-transform-for-of": "^7.18.8", - "@babel/plugin-transform-function-name": "^7.18.9", - "@babel/plugin-transform-literals": "^7.18.9", - "@babel/plugin-transform-member-expression-literals": "^7.18.6", - "@babel/plugin-transform-modules-amd": "^7.19.6", - "@babel/plugin-transform-modules-commonjs": "^7.19.6", - "@babel/plugin-transform-modules-systemjs": "^7.19.6", - "@babel/plugin-transform-modules-umd": "^7.18.6", - "@babel/plugin-transform-named-capturing-groups-regex": "^7.19.1", - "@babel/plugin-transform-new-target": "^7.18.6", - "@babel/plugin-transform-object-super": "^7.18.6", - "@babel/plugin-transform-parameters": "^7.20.1", - "@babel/plugin-transform-property-literals": "^7.18.6", - "@babel/plugin-transform-regenerator": "^7.18.6", - "@babel/plugin-transform-reserved-words": "^7.18.6", - "@babel/plugin-transform-shorthand-properties": "^7.18.6", - "@babel/plugin-transform-spread": "^7.19.0", - "@babel/plugin-transform-sticky-regex": "^7.18.6", - "@babel/plugin-transform-template-literals": "^7.18.9", - "@babel/plugin-transform-typeof-symbol": "^7.18.9", - "@babel/plugin-transform-unicode-escapes": "^7.18.10", - "@babel/plugin-transform-unicode-regex": "^7.18.6", - "@babel/preset-modules": "^0.1.5", - "@babel/types": "^7.20.2", - "babel-plugin-polyfill-corejs2": "^0.3.3", - "babel-plugin-polyfill-corejs3": "^0.6.0", - "babel-plugin-polyfill-regenerator": "^0.4.1", - "core-js-compat": "^3.25.1", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-modules": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/@babel/preset-modules/-/preset-modules-0.1.5.tgz", - "integrity": "sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/plugin-proposal-unicode-property-regex": "^7.4.4", - "@babel/plugin-transform-dotall-regex": "^7.4.4", - "@babel/types": "^7.4.4", - "esutils": "^2.0.2" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-react": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/preset-react/-/preset-react-7.18.6.tgz", - "integrity": "sha512-zXr6atUmyYdiWRVLOZahakYmOBHtWc2WGCkP8PYTgZi0iJXDY2CN180TdrIW4OGOAdLc7TifzDIvtx6izaRIzg==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-validator-option": "^7.18.6", - "@babel/plugin-transform-react-display-name": "^7.18.6", - "@babel/plugin-transform-react-jsx": "^7.18.6", - "@babel/plugin-transform-react-jsx-development": "^7.18.6", - "@babel/plugin-transform-react-pure-annotations": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/preset-typescript": { - "version": "7.18.6", - "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.18.6.tgz", - "integrity": "sha512-s9ik86kXBAnD760aybBucdpnLsAt0jK1xqJn2juOn9lkOvSHV60os5hxoVJsPzMQxvnUJFAlkont2DvvaYEBtQ==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.18.6", - "@babel/helper-validator-option": "^7.18.6", - "@babel/plugin-transform-typescript": "^7.18.6" - }, - "engines": { - "node": ">=6.9.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@babel/runtime": { - "version": "7.20.6", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.20.6.tgz", - "integrity": "sha512-Q+8MqP7TiHMWzSfwiJwXCjyf4GYA4Dgw3emg/7xmwsdLJOZUp+nMqcOwOzzYheuM1rhDu8FSj2l0aoMygEuXuA==", - "dependencies": { - "regenerator-runtime": "^0.13.11" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/runtime-corejs3": { - "version": "7.20.6", - "resolved": "https://registry.npmjs.org/@babel/runtime-corejs3/-/runtime-corejs3-7.20.6.tgz", - "integrity": "sha512-tqeujPiuEfcH067mx+7otTQWROVMKHXEaOQcAeNV5dDdbPWvPcFA8/W9LXw2NfjNmOetqLl03dfnG2WALPlsRQ==", - "dev": true, - "dependencies": { - "core-js-pure": "^3.25.1", - "regenerator-runtime": "^0.13.11" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/template": { - "version": "7.18.10", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.10.tgz", - "integrity": "sha512-TI+rCtooWHr3QJ27kJxfjutghu44DLnasDMwpDqCXVTal9RLp3RSYNh4NdBrRP2cQAoG9A8juOQl6P6oZG4JxA==", - "dependencies": { - "@babel/code-frame": "^7.18.6", - "@babel/parser": "^7.18.10", - "@babel/types": "^7.18.10" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/traverse": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.20.5.tgz", - "integrity": "sha512-WM5ZNN3JITQIq9tFZaw1ojLU3WgWdtkxnhM1AegMS+PvHjkM5IXjmYEGY7yukz5XS4sJyEf2VzWjI8uAavhxBQ==", - "dependencies": { - "@babel/code-frame": "^7.18.6", - "@babel/generator": "^7.20.5", - "@babel/helper-environment-visitor": "^7.18.9", - "@babel/helper-function-name": "^7.19.0", - "@babel/helper-hoist-variables": "^7.18.6", - "@babel/helper-split-export-declaration": "^7.18.6", - "@babel/parser": "^7.20.5", - "@babel/types": "^7.20.5", - "debug": "^4.1.0", - "globals": "^11.1.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@babel/types": { - "version": "7.20.5", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.20.5.tgz", - "integrity": "sha512-c9fst/h2/dcF7H+MJKZ2T0KjEQ8hY/BNnDk/H3XY8C4Aw/eWQXWn/lWntHF9ooUBnGmEvbfGrTgLWc+um0YDUg==", - "dependencies": { - "@babel/helper-string-parser": "^7.19.4", - "@babel/helper-validator-identifier": "^7.19.1", - "to-fast-properties": "^2.0.0" - }, - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/@bcoe/v8-coverage": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz", - "integrity": "sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==", - "dev": true - }, - "node_modules/@csstools/selector-specificity": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@csstools/selector-specificity/-/selector-specificity-2.0.2.tgz", - "integrity": "sha512-IkpVW/ehM1hWKln4fCA3NzJU8KwD+kIOvPZA4cqxoJHtE21CCzjyp+Kxbu0i5I4tBNOlXPL9mjwnWlL0VEG4Fg==", - "dev": true, - "engines": { - "node": "^12 || ^14 || >=16" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/csstools" - }, - "peerDependencies": { - "postcss": "^8.2", - "postcss-selector-parser": "^6.0.10" - } - }, - "node_modules/@discoveryjs/json-ext": { - "version": "0.5.7", - "resolved": "https://registry.npmjs.org/@discoveryjs/json-ext/-/json-ext-0.5.7.tgz", - "integrity": "sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==", - "dev": true, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/@emotion/babel-plugin": { - "version": "11.10.5", - "resolved": "https://registry.npmjs.org/@emotion/babel-plugin/-/babel-plugin-11.10.5.tgz", - "integrity": "sha512-xE7/hyLHJac7D2Ve9dKroBBZqBT7WuPQmWcq7HSGb84sUuP4mlOWoB8dvVfD9yk5DHkU1m6RW7xSoDtnQHNQeA==", - "dependencies": { - "@babel/helper-module-imports": "^7.16.7", - "@babel/plugin-syntax-jsx": "^7.17.12", - "@babel/runtime": "^7.18.3", - "@emotion/hash": "^0.9.0", - "@emotion/memoize": "^0.8.0", - "@emotion/serialize": "^1.1.1", - "babel-plugin-macros": "^3.1.0", - "convert-source-map": "^1.5.0", - "escape-string-regexp": "^4.0.0", - "find-root": "^1.1.0", - "source-map": "^0.5.7", - "stylis": "4.1.3" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/@emotion/cache": { - "version": "11.10.5", - "resolved": "https://registry.npmjs.org/@emotion/cache/-/cache-11.10.5.tgz", - "integrity": "sha512-dGYHWyzTdmK+f2+EnIGBpkz1lKc4Zbj2KHd4cX3Wi8/OWr5pKslNjc3yABKH4adRGCvSX4VDC0i04mrrq0aiRA==", - "dependencies": { - "@emotion/memoize": "^0.8.0", - "@emotion/sheet": "^1.2.1", - "@emotion/utils": "^1.2.0", - "@emotion/weak-memoize": "^0.3.0", - "stylis": "4.1.3" - } - }, - "node_modules/@emotion/css": { - "version": "11.10.5", - "resolved": "https://registry.npmjs.org/@emotion/css/-/css-11.10.5.tgz", - "integrity": "sha512-maJy0wG82hWsiwfJpc3WrYsyVwUbdu+sdIseKUB+/OLjB8zgc3tqkT6eO0Yt0AhIkJwGGnmMY/xmQwEAgQ4JHA==", - "dependencies": { - "@emotion/babel-plugin": "^11.10.5", - "@emotion/cache": "^11.10.5", - "@emotion/serialize": "^1.1.1", - "@emotion/sheet": "^1.2.1", - "@emotion/utils": "^1.2.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - }, - "peerDependenciesMeta": { - "@babel/core": { - "optional": true - } - } - }, - "node_modules/@emotion/hash": { - "version": "0.9.0", - "resolved": "https://registry.npmjs.org/@emotion/hash/-/hash-0.9.0.tgz", - "integrity": "sha512-14FtKiHhy2QoPIzdTcvh//8OyBlknNs2nXRwIhG904opCby3l+9Xaf/wuPvICBF0rc1ZCNBd3nKe9cd2mecVkQ==" - }, - "node_modules/@emotion/is-prop-valid": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-1.2.0.tgz", - "integrity": "sha512-3aDpDprjM0AwaxGE09bOPkNxHpBd+kA6jty3RnaEXdweX1DF1U3VQpPYb0g1IStAuK7SVQ1cy+bNBBKp4W3Fjg==", - "dependencies": { - "@emotion/memoize": "^0.8.0" - } - }, - "node_modules/@emotion/memoize": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.8.0.tgz", - "integrity": "sha512-G/YwXTkv7Den9mXDO7AhLWkE3q+I92B+VqAE+dYG4NGPaHZGvt3G8Q0p9vmE+sq7rTGphUbAvmQ9YpbfMQGGlA==" - }, - "node_modules/@emotion/react": { - "version": "11.10.5", - "resolved": "https://registry.npmjs.org/@emotion/react/-/react-11.10.5.tgz", - "integrity": "sha512-TZs6235tCJ/7iF6/rvTaOH4oxQg2gMAcdHemjwLKIjKz4rRuYe1HJ2TQJKnAcRAfOUDdU8XoDadCe1rl72iv8A==", - "dependencies": { - "@babel/runtime": "^7.18.3", - "@emotion/babel-plugin": "^11.10.5", - "@emotion/cache": "^11.10.5", - "@emotion/serialize": "^1.1.1", - "@emotion/use-insertion-effect-with-fallbacks": "^1.0.0", - "@emotion/utils": "^1.2.0", - "@emotion/weak-memoize": "^0.3.0", - "hoist-non-react-statics": "^3.3.1" - }, - "peerDependencies": { - "@babel/core": "^7.0.0", - "react": ">=16.8.0" - }, - "peerDependenciesMeta": { - "@babel/core": { - "optional": true - }, - "@types/react": { - "optional": true - } - } - }, - "node_modules/@emotion/serialize": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/@emotion/serialize/-/serialize-1.1.1.tgz", - "integrity": "sha512-Zl/0LFggN7+L1liljxXdsVSVlg6E/Z/olVWpfxUTxOAmi8NU7YoeWeLfi1RmnB2TATHoaWwIBRoL+FvAJiTUQA==", - "dependencies": { - "@emotion/hash": "^0.9.0", - "@emotion/memoize": "^0.8.0", - "@emotion/unitless": "^0.8.0", - "@emotion/utils": "^1.2.0", - "csstype": "^3.0.2" - } - }, - "node_modules/@emotion/sheet": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@emotion/sheet/-/sheet-1.2.1.tgz", - "integrity": "sha512-zxRBwl93sHMsOj4zs+OslQKg/uhF38MB+OMKoCrVuS0nyTkqnau+BM3WGEoOptg9Oz45T/aIGs1qbVAsEFo3nA==" - }, - "node_modules/@emotion/styled": { - "version": "11.10.5", - "resolved": "https://registry.npmjs.org/@emotion/styled/-/styled-11.10.5.tgz", - "integrity": "sha512-8EP6dD7dMkdku2foLoruPCNkRevzdcBaY6q0l0OsbyJK+x8D9HWjX27ARiSIKNF634hY9Zdoedh8bJCiva8yZw==", - "dependencies": { - "@babel/runtime": "^7.18.3", - "@emotion/babel-plugin": "^11.10.5", - "@emotion/is-prop-valid": "^1.2.0", - "@emotion/serialize": "^1.1.1", - "@emotion/use-insertion-effect-with-fallbacks": "^1.0.0", - "@emotion/utils": "^1.2.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0", - "@emotion/react": "^11.0.0-rc.0", - "react": ">=16.8.0" - }, - "peerDependenciesMeta": { - "@babel/core": { - "optional": true - }, - "@types/react": { - "optional": true - } - } - }, - "node_modules/@emotion/unitless": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/@emotion/unitless/-/unitless-0.8.0.tgz", - "integrity": "sha512-VINS5vEYAscRl2ZUDiT3uMPlrFQupiKgHz5AA4bCH1miKBg4qtwkim1qPmJj/4WG6TreYMY111rEFsjupcOKHw==" - }, - "node_modules/@emotion/use-insertion-effect-with-fallbacks": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.0.0.tgz", - "integrity": "sha512-1eEgUGmkaljiBnRMTdksDV1W4kUnmwgp7X9G8B++9GYwl1lUdqSndSriIrTJ0N7LQaoauY9JJ2yhiOYK5+NI4A==", - "peerDependencies": { - "react": ">=16.8.0" - } - }, - "node_modules/@emotion/utils": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/@emotion/utils/-/utils-1.2.0.tgz", - "integrity": "sha512-sn3WH53Kzpw8oQ5mgMmIzzyAaH2ZqFEbozVVBSYp538E06OSE6ytOp7pRAjNQR+Q/orwqdQYJSe2m3hCOeznkw==" - }, - "node_modules/@emotion/weak-memoize": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/@emotion/weak-memoize/-/weak-memoize-0.3.0.tgz", - "integrity": "sha512-AHPmaAx+RYfZz0eYu6Gviiagpmiyw98ySSlQvCUhVGDRtDFe4DBS0x1bSjdF3gqUDYOczB+yYvBTtEylYSdRhg==" - }, - "node_modules/@es-joy/jsdoccomment": { - "version": "0.20.1", - "resolved": "https://registry.npmjs.org/@es-joy/jsdoccomment/-/jsdoccomment-0.20.1.tgz", - "integrity": "sha512-oeJK41dcdqkvdZy/HctKklJNkt/jh+av3PZARrZEl+fs/8HaHeeYoAvEwOV0u5I6bArTF17JEsTZMY359e/nfQ==", - "dev": true, - "dependencies": { - "comment-parser": "1.3.0", - "esquery": "^1.4.0", - "jsdoc-type-pratt-parser": "~2.2.3" - }, - "engines": { - "node": "^12 || ^14 || ^16 || ^17" - } - }, - "node_modules/@eslint/eslintrc": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-1.3.3.tgz", - "integrity": "sha512-uj3pT6Mg+3t39fvLrj8iuCIJ38zKO9FpGtJ4BBJebJhEwjoT+KLVNCcHT5QC9NGRIEi7fZ0ZR8YRb884auB4Lg==", - "dev": true, - "dependencies": { - "ajv": "^6.12.4", - "debug": "^4.3.2", - "espree": "^9.4.0", - "globals": "^13.15.0", - "ignore": "^5.2.0", - "import-fresh": "^3.2.1", - "js-yaml": "^4.1.0", - "minimatch": "^3.1.2", - "strip-json-comments": "^3.1.1" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "url": "https://opencollective.com/eslint" - } - }, - "node_modules/@eslint/eslintrc/node_modules/argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true - }, - "node_modules/@eslint/eslintrc/node_modules/globals": { - "version": "13.19.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-13.19.0.tgz", - "integrity": "sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ==", - "dev": true, - "dependencies": { - "type-fest": "^0.20.2" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/@eslint/eslintrc/node_modules/js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", - "dev": true, - "dependencies": { - "argparse": "^2.0.1" - }, - "bin": { - "js-yaml": "bin/js-yaml.js" - } - }, - "node_modules/@eslint/eslintrc/node_modules/type-fest": { - "version": "0.20.2", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", - "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/@floating-ui/core": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/@floating-ui/core/-/core-1.0.4.tgz", - "integrity": "sha512-FPFLbg2b06MIw1dqk2SOEMAMX3xlrreGjcui5OTxfBDtaKTmh0kioOVjT8gcfl58juawL/yF+S+gnq8aUYQx/Q==" - }, - "node_modules/@floating-ui/dom": { - "version": "1.0.12", - "resolved": "https://registry.npmjs.org/@floating-ui/dom/-/dom-1.0.12.tgz", - "integrity": "sha512-HeG/wHoa2laUHlDX3xkzqlUqliAfa+zqV04LaKIwNCmCNaW2p0fQi4/Kd0LB4GdFoJ2UllLFq5gWnXAd67lg7w==", - "dependencies": { - "@floating-ui/core": "^1.0.4" - } - }, - "node_modules/@floating-ui/react-dom": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/@floating-ui/react-dom/-/react-dom-1.0.1.tgz", - "integrity": "sha512-UW0t1Gi8ikbDRr8cQPVcqIDMBwUEENe5V4wlHWdrJ5egFnRQFBV9JirauTBFI6S8sM1qFUC1i+qa3g87E6CLTw==", - "dependencies": { - "@floating-ui/dom": "^1.0.5" - }, - "peerDependencies": { - "react": ">=16.8.0", - "react-dom": ">=16.8.0" - } - }, - "node_modules/@hapi/hoek": { - "version": "9.3.0", - "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", - "integrity": "sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==", - "dev": true - }, - "node_modules/@hapi/topo": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-5.1.0.tgz", - "integrity": "sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==", - "dev": true, - "dependencies": { - "@hapi/hoek": "^9.0.0" - } - }, - "node_modules/@humanwhocodes/config-array": { - "version": "0.11.8", - "resolved": "https://registry.npmjs.org/@humanwhocodes/config-array/-/config-array-0.11.8.tgz", - "integrity": "sha512-UybHIJzJnR5Qc/MsD9Kr+RpO2h+/P1GhOwdiLPXK5TWk5sgTdu88bTD9UP+CKbPPh5Rni1u0GjAdYQLemG8g+g==", - "dev": true, - "dependencies": { - "@humanwhocodes/object-schema": "^1.2.1", - "debug": "^4.1.1", - "minimatch": "^3.0.5" - }, - "engines": { - "node": ">=10.10.0" - } - }, - "node_modules/@humanwhocodes/module-importer": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", - "integrity": "sha512-bxveV4V8v5Yb4ncFTT3rPSgZBOpCkjfK0y4oVVVJwIuDVBRMDXrPyXRL988i5ap9m9bnyEEjWfm5WkBmtffLfA==", - "dev": true, - "engines": { - "node": ">=12.22" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/nzakas" - } - }, - "node_modules/@humanwhocodes/object-schema": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz", - "integrity": "sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==", - "dev": true - }, - "node_modules/@istanbuljs/load-nyc-config": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz", - "integrity": "sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==", - "dev": true, - "dependencies": { - "camelcase": "^5.3.1", - "find-up": "^4.1.0", - "get-package-type": "^0.1.0", - "js-yaml": "^3.13.1", - "resolve-from": "^5.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@istanbuljs/load-nyc-config/node_modules/camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/@istanbuljs/load-nyc-config/node_modules/find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dev": true, - "dependencies": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@istanbuljs/load-nyc-config/node_modules/locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dev": true, - "dependencies": { - "p-locate": "^4.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@istanbuljs/load-nyc-config/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dev": true, - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/@istanbuljs/load-nyc-config/node_modules/p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dev": true, - "dependencies": { - "p-limit": "^2.2.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@istanbuljs/load-nyc-config/node_modules/resolve-from": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", - "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@istanbuljs/schema": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/@istanbuljs/schema/-/schema-0.1.3.tgz", - "integrity": "sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/console": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/console/-/console-27.5.1.tgz", - "integrity": "sha512-kZ/tNpS3NXn0mlXXXPNuDZnb4c0oZ20r4K5eemM2k30ZC3G0T02nXUvyhf5YdbXWHPEJLc9qGLxEZ216MdL+Zg==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "@types/node": "*", - "chalk": "^4.0.0", - "jest-message-util": "^27.5.1", - "jest-util": "^27.5.1", - "slash": "^3.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/console/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/@jest/console/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/@jest/console/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/@jest/console/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/@jest/console/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/console/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/core": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/core/-/core-27.5.1.tgz", - "integrity": "sha512-AK6/UTrvQD0Cd24NSqmIA6rKsu0tKIxfiCducZvqxYdmMisOYAsdItspT+fQDQYARPf8XgjAFZi0ogW2agH5nQ==", - "dev": true, - "dependencies": { - "@jest/console": "^27.5.1", - "@jest/reporters": "^27.5.1", - "@jest/test-result": "^27.5.1", - "@jest/transform": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "emittery": "^0.8.1", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "jest-changed-files": "^27.5.1", - "jest-config": "^27.5.1", - "jest-haste-map": "^27.5.1", - "jest-message-util": "^27.5.1", - "jest-regex-util": "^27.5.1", - "jest-resolve": "^27.5.1", - "jest-resolve-dependencies": "^27.5.1", - "jest-runner": "^27.5.1", - "jest-runtime": "^27.5.1", - "jest-snapshot": "^27.5.1", - "jest-util": "^27.5.1", - "jest-validate": "^27.5.1", - "jest-watcher": "^27.5.1", - "micromatch": "^4.0.4", - "rimraf": "^3.0.0", - "slash": "^3.0.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/@jest/core/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/@jest/core/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/@jest/core/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/@jest/core/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/@jest/core/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/core/node_modules/rimraf": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", - "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", - "dev": true, - "dependencies": { - "glob": "^7.1.3" - }, - "bin": { - "rimraf": "bin.js" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/@jest/core/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/environment": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-27.5.1.tgz", - "integrity": "sha512-/WQjhPJe3/ghaol/4Bq480JKXV/Rfw8nQdN7f41fM8VDHLcxKXou6QyXAh3EFr9/bVG3x74z1NWDkP87EiY8gA==", - "dev": true, - "dependencies": { - "@jest/fake-timers": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "jest-mock": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/fake-timers": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-27.5.1.tgz", - "integrity": "sha512-/aPowoolwa07k7/oM3aASneNeBGCmGQsc3ugN4u6s4C/+s5M64MFo/+djTdiwcbQlRfFElGuDXWzaWj6QgKObQ==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "@sinonjs/fake-timers": "^8.0.1", - "@types/node": "*", - "jest-message-util": "^27.5.1", - "jest-mock": "^27.5.1", - "jest-util": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/globals": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/globals/-/globals-27.5.1.tgz", - "integrity": "sha512-ZEJNB41OBQQgGzgyInAv0UUfDDj3upmHydjieSxFvTRuZElrx7tXg/uVQ5hYVEwiXs3+aMsAeEc9X7xiSKCm4Q==", - "dev": true, - "dependencies": { - "@jest/environment": "^27.5.1", - "@jest/types": "^27.5.1", - "expect": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/reporters": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-27.5.1.tgz", - "integrity": "sha512-cPXh9hWIlVJMQkVk84aIvXuBB4uQQmFqZiacloFuGiP3ah1sbCxCosidXFDfqG8+6fO1oR2dTJTlsOy4VFmUfw==", - "dev": true, - "dependencies": { - "@bcoe/v8-coverage": "^0.2.3", - "@jest/console": "^27.5.1", - "@jest/test-result": "^27.5.1", - "@jest/transform": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "chalk": "^4.0.0", - "collect-v8-coverage": "^1.0.0", - "exit": "^0.1.2", - "glob": "^7.1.2", - "graceful-fs": "^4.2.9", - "istanbul-lib-coverage": "^3.0.0", - "istanbul-lib-instrument": "^5.1.0", - "istanbul-lib-report": "^3.0.0", - "istanbul-lib-source-maps": "^4.0.0", - "istanbul-reports": "^3.1.3", - "jest-haste-map": "^27.5.1", - "jest-resolve": "^27.5.1", - "jest-util": "^27.5.1", - "jest-worker": "^27.5.1", - "slash": "^3.0.0", - "source-map": "^0.6.0", - "string-length": "^4.0.1", - "terminal-link": "^2.0.0", - "v8-to-istanbul": "^8.1.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/@jest/reporters/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/@jest/reporters/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/@jest/reporters/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/@jest/reporters/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/@jest/reporters/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/reporters/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/@jest/reporters/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/source-map": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-27.5.1.tgz", - "integrity": "sha512-y9NIHUYF3PJRlHk98NdC/N1gl88BL08aQQgu4k4ZopQkCw9t9cV8mtl3TV8b/YCB8XaVTFrmUTAJvjsntDireg==", - "dev": true, - "dependencies": { - "callsites": "^3.0.0", - "graceful-fs": "^4.2.9", - "source-map": "^0.6.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/source-map/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/@jest/test-result": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-27.5.1.tgz", - "integrity": "sha512-EW35l2RYFUcUQxFJz5Cv5MTOxlJIQs4I7gxzi2zVU7PJhOwfYq1MdC5nhSmYjX1gmMmLPvB3sIaC+BkcHRBfag==", - "dev": true, - "dependencies": { - "@jest/console": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/istanbul-lib-coverage": "^2.0.0", - "collect-v8-coverage": "^1.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/test-sequencer": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-27.5.1.tgz", - "integrity": "sha512-LCheJF7WB2+9JuCS7VB/EmGIdQuhtqjRNI9A43idHv3E4KltCTsPsLxvdaubFHSYwY/fNjMWjl6vNRhDiN7vpQ==", - "dev": true, - "dependencies": { - "@jest/test-result": "^27.5.1", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^27.5.1", - "jest-runtime": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/transform": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-27.5.1.tgz", - "integrity": "sha512-ipON6WtYgl/1329g5AIJVbUuEh0wZVbdpGwC99Jw4LwuoBNS95MVphU6zOeD9pDkon+LLbFL7lOQRapbB8SCHw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.1.0", - "@jest/types": "^27.5.1", - "babel-plugin-istanbul": "^6.1.1", - "chalk": "^4.0.0", - "convert-source-map": "^1.4.0", - "fast-json-stable-stringify": "^2.0.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^27.5.1", - "jest-regex-util": "^27.5.1", - "jest-util": "^27.5.1", - "micromatch": "^4.0.4", - "pirates": "^4.0.4", - "slash": "^3.0.0", - "source-map": "^0.6.1", - "write-file-atomic": "^3.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/transform/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/@jest/transform/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/@jest/transform/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/@jest/transform/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/@jest/transform/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/transform/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/@jest/transform/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/types": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/@jest/types/-/types-27.5.1.tgz", - "integrity": "sha512-Cx46iJ9QpwQTjIdq5VJu2QTMMs3QlEjI0x1QbBP5W1+nMzyc2XmimiRR/CbX9TO0cPTeUlxWMOu8mslYsJ8DEw==", - "dev": true, - "dependencies": { - "@types/istanbul-lib-coverage": "^2.0.0", - "@types/istanbul-reports": "^3.0.0", - "@types/node": "*", - "@types/yargs": "^16.0.0", - "chalk": "^4.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/@jest/types/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/@jest/types/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/@jest/types/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/@jest/types/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/@jest/types/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jest/types/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@jridgewell/gen-mapping": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", - "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==", - "dependencies": { - "@jridgewell/set-array": "^1.0.0", - "@jridgewell/sourcemap-codec": "^1.4.10" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@jridgewell/resolve-uri": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@jridgewell/source-map": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.2.tgz", - "integrity": "sha512-m7O9o2uR8k2ObDysZYzdfhb08VuEml5oWGiosa1VdaPZ/A6QyPkAJuwN0Q1lhULOf6B7MtQmHENS743hWtCrgw==", - "dev": true, - "dependencies": { - "@jridgewell/gen-mapping": "^0.3.0", - "@jridgewell/trace-mapping": "^0.3.9" - } - }, - "node_modules/@jridgewell/source-map/node_modules/@jridgewell/gen-mapping": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", - "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", - "dev": true, - "dependencies": { - "@jridgewell/set-array": "^1.0.1", - "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" - }, - "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.17", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz", - "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==", - "dependencies": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" - } - }, - "node_modules/@leichtgewicht/ip-codec": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@leichtgewicht/ip-codec/-/ip-codec-2.0.4.tgz", - "integrity": "sha512-Hcv+nVC0kZnQ3tD9GVu5xSMR4VVYOteQIr/hwFPVEvPdlXqgGEuRjiheChHgdM+JyqdgNcmzZOX/tnl0JOiI7A==", - "dev": true - }, - "node_modules/@motionone/animation": { - "version": "10.15.1", - "resolved": "https://registry.npmjs.org/@motionone/animation/-/animation-10.15.1.tgz", - "integrity": "sha512-mZcJxLjHor+bhcPuIFErMDNyrdb2vJur8lSfMCsuCB4UyV8ILZLvK+t+pg56erv8ud9xQGK/1OGPt10agPrCyQ==", - "dependencies": { - "@motionone/easing": "^10.15.1", - "@motionone/types": "^10.15.1", - "@motionone/utils": "^10.15.1", - "tslib": "^2.3.1" - } - }, - "node_modules/@motionone/dom": { - "version": "10.15.3", - "resolved": "https://registry.npmjs.org/@motionone/dom/-/dom-10.15.3.tgz", - "integrity": "sha512-FQ7a2zMBXc1UeU8CG9G3yDpst55fbb0+C9A0VGfwOITitBCzigKZnXRgsRSWWR+FW57GSc13eGQxtYB0lKG0Ng==", - "dependencies": { - "@motionone/animation": "^10.15.1", - "@motionone/generators": "^10.15.1", - "@motionone/types": "^10.15.1", - "@motionone/utils": "^10.15.1", - "hey-listen": "^1.0.8", - "tslib": "^2.3.1" - } - }, - "node_modules/@motionone/easing": { - "version": "10.15.1", - "resolved": "https://registry.npmjs.org/@motionone/easing/-/easing-10.15.1.tgz", - "integrity": "sha512-6hIHBSV+ZVehf9dcKZLT7p5PEKHGhDwky2k8RKkmOvUoYP3S+dXsKupyZpqx5apjd9f+php4vXk4LuS+ADsrWw==", - "dependencies": { - "@motionone/utils": "^10.15.1", - "tslib": "^2.3.1" - } - }, - "node_modules/@motionone/generators": { - "version": "10.15.1", - "resolved": "https://registry.npmjs.org/@motionone/generators/-/generators-10.15.1.tgz", - "integrity": "sha512-67HLsvHJbw6cIbLA/o+gsm7h+6D4Sn7AUrB/GPxvujse1cGZ38F5H7DzoH7PhX+sjvtDnt2IhFYF2Zp1QTMKWQ==", - "dependencies": { - "@motionone/types": "^10.15.1", - "@motionone/utils": "^10.15.1", - "tslib": "^2.3.1" - } - }, - "node_modules/@motionone/types": { - "version": "10.15.1", - "resolved": "https://registry.npmjs.org/@motionone/types/-/types-10.15.1.tgz", - "integrity": "sha512-iIUd/EgUsRZGrvW0jqdst8st7zKTzS9EsKkP+6c6n4MPZoQHwiHuVtTQLD6Kp0bsBLhNzKIBlHXponn/SDT4hA==" - }, - "node_modules/@motionone/utils": { - "version": "10.15.1", - "resolved": "https://registry.npmjs.org/@motionone/utils/-/utils-10.15.1.tgz", - "integrity": "sha512-p0YncgU+iklvYr/Dq4NobTRdAPv9PveRDUXabPEeOjBLSO/1FNB2phNTZxOxpi1/GZwYpAoECEa0Wam+nsmhSw==", - "dependencies": { - "@motionone/types": "^10.15.1", - "hey-listen": "^1.0.8", - "tslib": "^2.3.1" - } - }, - "node_modules/@newfold-labs/wp-module-ai": { - "version": "0.0.1", - "resolved": "git+ssh://git@github.com/newfold-labs/js-utility-ai.git#02a51a8706f03f83f76d143252155d84321a00eb", - "license": "GPL-2.0-or-later", - "dependencies": { - "@wordpress/api-fetch": "^6.28.0" - } - }, - "node_modules/@newfold-labs/wp-module-ai/node_modules/@wordpress/api-fetch": { - "version": "6.31.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.31.0.tgz", - "integrity": "sha512-3l2jT7eD6kOK+GM1qcXsk7BGmmrU+//uT1wWOSpx+x4vpPABKlm7yfPvjHG7SqbgHXQzLD6eFvo/nmwN3JbGNg==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.34.0", - "@wordpress/url": "^3.35.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@newfold-labs/wp-module-ai/node_modules/@wordpress/i18n": { - "version": "4.34.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.34.0.tgz", - "integrity": "sha512-rC1Ll/48GNsYHFF8cUU1V+bfqjBtHAsDsB7F8O81tXjfkJDFsNq7J8Gti47lAgeqvQ934y+sj5gAmFaM7A+AdA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.34.0", - "gettext-parser": "^1.3.1", - "memize": "^2.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@newfold-labs/wp-module-ai/node_modules/memize": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/memize/-/memize-2.1.0.tgz", - "integrity": "sha512-yywVJy8ctVlN5lNPxsep5urnZ6TTclwPEyigM9M3Bi8vseJBOfqNrGWN/r8NzuIt3PovM323W04blJfGQfQSVg==" - }, - "node_modules/@nicolo-ribaudo/eslint-scope-5-internals": { - "version": "5.1.1-v1", - "resolved": "https://registry.npmjs.org/@nicolo-ribaudo/eslint-scope-5-internals/-/eslint-scope-5-internals-5.1.1-v1.tgz", - "integrity": "sha512-54/JRvkLIzzDWshCWfuhadfrfZVPiElY8Fcgmg1HroEly/EDSszzhBAsarCux+D/kOslTRquNzuyGSmUSTTHGg==", - "dev": true, - "dependencies": { - "eslint-scope": "5.1.1" - } - }, - "node_modules/@nodelib/fs.scandir": { - "version": "2.1.5", - "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", - "integrity": "sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==", - "dev": true, - "dependencies": { - "@nodelib/fs.stat": "2.0.5", - "run-parallel": "^1.1.9" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/@nodelib/fs.stat": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-2.0.5.tgz", - "integrity": "sha512-RkhPPp2zrqDAQA/2jNhnztcPAlv64XdhIp7a7454A5ovI7Bukxgt7MX7udwAu3zg1DcpPU0rz3VV1SeaqvY4+A==", - "dev": true, - "engines": { - "node": ">= 8" - } - }, - "node_modules/@nodelib/fs.walk": { - "version": "1.2.8", - "resolved": "https://registry.npmjs.org/@nodelib/fs.walk/-/fs.walk-1.2.8.tgz", - "integrity": "sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==", - "dev": true, - "dependencies": { - "@nodelib/fs.scandir": "2.1.5", - "fastq": "^1.6.0" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/@pmmmwh/react-refresh-webpack-plugin": { - "version": "0.5.10", - "resolved": "https://registry.npmjs.org/@pmmmwh/react-refresh-webpack-plugin/-/react-refresh-webpack-plugin-0.5.10.tgz", - "integrity": "sha512-j0Ya0hCFZPd4x40qLzbhGsh9TMtdb+CJQiso+WxLOPNasohq9cc5SNUcwsZaRH6++Xh91Xkm/xHCkuIiIu0LUA==", - "dev": true, - "dependencies": { - "ansi-html-community": "^0.0.8", - "common-path-prefix": "^3.0.0", - "core-js-pure": "^3.23.3", - "error-stack-parser": "^2.0.6", - "find-up": "^5.0.0", - "html-entities": "^2.1.0", - "loader-utils": "^2.0.4", - "schema-utils": "^3.0.0", - "source-map": "^0.7.3" - }, - "engines": { - "node": ">= 10.13" - }, - "peerDependencies": { - "@types/webpack": "4.x || 5.x", - "react-refresh": ">=0.10.0 <1.0.0", - "sockjs-client": "^1.4.0", - "type-fest": ">=0.17.0 <4.0.0", - "webpack": ">=4.43.0 <6.0.0", - "webpack-dev-server": "3.x || 4.x", - "webpack-hot-middleware": "2.x", - "webpack-plugin-serve": "0.x || 1.x" - }, - "peerDependenciesMeta": { - "@types/webpack": { - "optional": true - }, - "sockjs-client": { - "optional": true - }, - "type-fest": { - "optional": true - }, - "webpack-dev-server": { - "optional": true - }, - "webpack-hot-middleware": { - "optional": true - }, - "webpack-plugin-serve": { - "optional": true - } - } - }, - "node_modules/@pmmmwh/react-refresh-webpack-plugin/node_modules/source-map": { - "version": "0.7.4", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", - "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", - "dev": true, - "engines": { - "node": ">= 8" - } - }, - "node_modules/@polka/url": { - "version": "1.0.0-next.21", - "resolved": "https://registry.npmjs.org/@polka/url/-/url-1.0.0-next.21.tgz", - "integrity": "sha512-a5Sab1C4/icpTZVzZc5Ghpz88yQtGOyNqYXcZgOssB2uuAr+wF/MvN6bgtW32q7HHrvBki+BsZ0OuNv6EV3K9g==", - "dev": true - }, - "node_modules/@popperjs/core": { - "version": "2.11.6", - "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.6.tgz", - "integrity": "sha512-50/17A98tWUfQ176raKiOGXuYpLyyVMkxxG6oylzL3BPOlA6ADGdK7EYunSa4I064xerltq9TGXs8HmOk5E+vw==", - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/popperjs" - } - }, - "node_modules/@react-spring/animated": { - "version": "9.6.1", - "resolved": "https://registry.npmjs.org/@react-spring/animated/-/animated-9.6.1.tgz", - "integrity": "sha512-ls/rJBrAqiAYozjLo5EPPLLOb1LM0lNVQcXODTC1SMtS6DbuBCPaKco5svFUQFMP2dso3O+qcC4k9FsKc0KxMQ==", - "dependencies": { - "@react-spring/shared": "~9.6.1", - "@react-spring/types": "~9.6.1" - }, - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0 || ^18.0.0" - } - }, - "node_modules/@react-spring/core": { - "version": "9.6.1", - "resolved": "https://registry.npmjs.org/@react-spring/core/-/core-9.6.1.tgz", - "integrity": "sha512-3HAAinAyCPessyQNNXe5W0OHzRfa8Yo5P748paPcmMowZ/4sMfaZ2ZB6e5x5khQI8NusOHj8nquoutd6FRY5WQ==", - "dependencies": { - "@react-spring/animated": "~9.6.1", - "@react-spring/rafz": "~9.6.1", - "@react-spring/shared": "~9.6.1", - "@react-spring/types": "~9.6.1" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/react-spring/donate" - }, - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0 || ^18.0.0" - } - }, - "node_modules/@react-spring/rafz": { - "version": "9.6.1", - "resolved": "https://registry.npmjs.org/@react-spring/rafz/-/rafz-9.6.1.tgz", - "integrity": "sha512-v6qbgNRpztJFFfSE3e2W1Uz+g8KnIBs6SmzCzcVVF61GdGfGOuBrbjIcp+nUz301awVmREKi4eMQb2Ab2gGgyQ==" - }, - "node_modules/@react-spring/shared": { - "version": "9.6.1", - "resolved": "https://registry.npmjs.org/@react-spring/shared/-/shared-9.6.1.tgz", - "integrity": "sha512-PBFBXabxFEuF8enNLkVqMC9h5uLRBo6GQhRMQT/nRTnemVENimgRd+0ZT4yFnAQ0AxWNiJfX3qux+bW2LbG6Bw==", - "dependencies": { - "@react-spring/rafz": "~9.6.1", - "@react-spring/types": "~9.6.1" - }, - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0 || ^18.0.0" - } - }, - "node_modules/@react-spring/types": { - "version": "9.6.1", - "resolved": "https://registry.npmjs.org/@react-spring/types/-/types-9.6.1.tgz", - "integrity": "sha512-POu8Mk0hIU3lRXB3bGIGe4VHIwwDsQyoD1F394OK7STTiX9w4dG3cTLljjYswkQN+hDSHRrj4O36kuVa7KPU8Q==" - }, - "node_modules/@react-spring/web": { - "version": "9.6.1", - "resolved": "https://registry.npmjs.org/@react-spring/web/-/web-9.6.1.tgz", - "integrity": "sha512-X2zR6q2Z+FjsWfGAmAXlQaoUHbPmfuCaXpuM6TcwXPpLE1ZD4A1eys/wpXboFQmDkjnrlTmKvpVna1MjWpZ5Hw==", - "dependencies": { - "@react-spring/animated": "~9.6.1", - "@react-spring/core": "~9.6.1", - "@react-spring/shared": "~9.6.1", - "@react-spring/types": "~9.6.1" - }, - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0 || ^18.0.0", - "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0" - } - }, - "node_modules/@remix-run/router": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@remix-run/router/-/router-1.2.1.tgz", - "integrity": "sha512-XiY0IsyHR+DXYS5vBxpoBe/8veTeoRpMHP+vDosLZxL5bnpetzI0igkxkLZS235ldLzyfkxF+2divEwWHP3vMQ==", - "engines": { - "node": ">=14" - } - }, - "node_modules/@sideway/address": { - "version": "4.1.4", - "resolved": "https://registry.npmjs.org/@sideway/address/-/address-4.1.4.tgz", - "integrity": "sha512-7vwq+rOHVWjyXxVlR76Agnvhy8I9rpzjosTESvmhNeXOXdZZB15Fl+TI9x1SiHZH5Jv2wTGduSxFDIaq0m3DUw==", - "dev": true, - "dependencies": { - "@hapi/hoek": "^9.0.0" - } - }, - "node_modules/@sideway/formula": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@sideway/formula/-/formula-3.0.0.tgz", - "integrity": "sha512-vHe7wZ4NOXVfkoRb8T5otiENVlT7a3IAiw7H5M2+GO+9CDgcVUUsX1zalAztCmwyOr2RUTGJdgB+ZvSVqmdHmg==", - "dev": true - }, - "node_modules/@sideway/pinpoint": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/@sideway/pinpoint/-/pinpoint-2.0.0.tgz", - "integrity": "sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==", - "dev": true - }, - "node_modules/@sinonjs/commons": { - "version": "1.8.6", - "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-1.8.6.tgz", - "integrity": "sha512-Ky+XkAkqPZSm3NLBeUng77EBQl3cmeJhITaGHdYH8kjVB+aun3S4XBRti2zt17mtt0mIUDiNxYeoJm6drVvBJQ==", - "dev": true, - "dependencies": { - "type-detect": "4.0.8" - } - }, - "node_modules/@sinonjs/fake-timers": { - "version": "8.1.0", - "resolved": "https://registry.npmjs.org/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz", - "integrity": "sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg==", - "dev": true, - "dependencies": { - "@sinonjs/commons": "^1.7.0" - } - }, - "node_modules/@svgr/babel-plugin-add-jsx-attribute": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-6.5.1.tgz", - "integrity": "sha512-9PYGcXrAxitycIjRmZB+Q0JaN07GZIWaTBIGQzfaZv+qr1n8X1XUEJ5rZ/vx6OVD9RRYlrNnXWExQXcmZeD/BQ==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-plugin-remove-jsx-attribute": { - "version": "6.5.0", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-attribute/-/babel-plugin-remove-jsx-attribute-6.5.0.tgz", - "integrity": "sha512-8zYdkym7qNyfXpWvu4yq46k41pyNM9SOstoWhKlm+IfdCE1DdnRKeMUPsWIEO/DEkaWxJ8T9esNdG3QwQ93jBA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-plugin-remove-jsx-empty-expression": { - "version": "6.5.0", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-empty-expression/-/babel-plugin-remove-jsx-empty-expression-6.5.0.tgz", - "integrity": "sha512-NFdxMq3xA42Kb1UbzCVxplUc0iqSyM9X8kopImvFnB+uSDdzIHOdbs1op8ofAvVRtbg4oZiyRl3fTYeKcOe9Iw==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-plugin-replace-jsx-attribute-value": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-replace-jsx-attribute-value/-/babel-plugin-replace-jsx-attribute-value-6.5.1.tgz", - "integrity": "sha512-8DPaVVE3fd5JKuIC29dqyMB54sA6mfgki2H2+swh+zNJoynC8pMPzOkidqHOSc6Wj032fhl8Z0TVn1GiPpAiJg==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-plugin-svg-dynamic-title": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-dynamic-title/-/babel-plugin-svg-dynamic-title-6.5.1.tgz", - "integrity": "sha512-FwOEi0Il72iAzlkaHrlemVurgSQRDFbk0OC8dSvD5fSBPHltNh7JtLsxmZUhjYBZo2PpcU/RJvvi6Q0l7O7ogw==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-plugin-svg-em-dimensions": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-em-dimensions/-/babel-plugin-svg-em-dimensions-6.5.1.tgz", - "integrity": "sha512-gWGsiwjb4tw+ITOJ86ndY/DZZ6cuXMNE/SjcDRg+HLuCmwpcjOktwRF9WgAiycTqJD/QXqL2f8IzE2Rzh7aVXA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-plugin-transform-react-native-svg": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-react-native-svg/-/babel-plugin-transform-react-native-svg-6.5.1.tgz", - "integrity": "sha512-2jT3nTayyYP7kI6aGutkyfJ7UMGtuguD72OjeGLwVNyfPRBD8zQthlvL+fAbAKk5n9ZNcvFkp/b1lZ7VsYqVJg==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-plugin-transform-svg-component": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-svg-component/-/babel-plugin-transform-svg-component-6.5.1.tgz", - "integrity": "sha512-a1p6LF5Jt33O3rZoVRBqdxL350oge54iZWHNI6LJB5tQ7EelvD/Mb1mfBiZNAan0dt4i3VArkFRjA4iObuNykQ==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/babel-preset": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/babel-preset/-/babel-preset-6.5.1.tgz", - "integrity": "sha512-6127fvO/FF2oi5EzSQOAjo1LE3OtNVh11R+/8FXa+mHx1ptAaS4cknIjnUA7e6j6fwGGJ17NzaTJFUwOV2zwCw==", - "dev": true, - "dependencies": { - "@svgr/babel-plugin-add-jsx-attribute": "^6.5.1", - "@svgr/babel-plugin-remove-jsx-attribute": "*", - "@svgr/babel-plugin-remove-jsx-empty-expression": "*", - "@svgr/babel-plugin-replace-jsx-attribute-value": "^6.5.1", - "@svgr/babel-plugin-svg-dynamic-title": "^6.5.1", - "@svgr/babel-plugin-svg-em-dimensions": "^6.5.1", - "@svgr/babel-plugin-transform-react-native-svg": "^6.5.1", - "@svgr/babel-plugin-transform-svg-component": "^6.5.1" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/@svgr/core": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/core/-/core-6.5.1.tgz", - "integrity": "sha512-/xdLSWxK5QkqG524ONSjvg3V/FkNyCv538OIBdQqPNaAta3AsXj/Bd2FbvR87yMbXO2hFSWiAe/Q6IkVPDw+mw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.19.6", - "@svgr/babel-preset": "^6.5.1", - "@svgr/plugin-jsx": "^6.5.1", - "camelcase": "^6.2.0", - "cosmiconfig": "^7.0.1" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - } - }, - "node_modules/@svgr/hast-util-to-babel-ast": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/hast-util-to-babel-ast/-/hast-util-to-babel-ast-6.5.1.tgz", - "integrity": "sha512-1hnUxxjd83EAxbL4a0JDJoD3Dao3hmjvyvyEV8PzWmLK3B9m9NPlW7GKjFyoWE8nM7HnXzPcmmSyOW8yOddSXw==", - "dev": true, - "dependencies": { - "@babel/types": "^7.20.0", - "entities": "^4.4.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - } - }, - "node_modules/@svgr/plugin-jsx": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/plugin-jsx/-/plugin-jsx-6.5.1.tgz", - "integrity": "sha512-+UdQxI3jgtSjCykNSlEMuy1jSRQlGC7pqBCPvkG/2dATdWo082zHTTK3uhnAju2/6XpE6B5mZ3z4Z8Ns01S8Gw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.19.6", - "@svgr/babel-preset": "^6.5.1", - "@svgr/hast-util-to-babel-ast": "^6.5.1", - "svg-parser": "^2.0.4" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@svgr/core": "^6.0.0" - } - }, - "node_modules/@svgr/plugin-svgo": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/plugin-svgo/-/plugin-svgo-6.5.1.tgz", - "integrity": "sha512-omvZKf8ixP9z6GWgwbtmP9qQMPX4ODXi+wzbVZgomNFsUIlHA1sf4fThdwTWSsZGgvGAG6yE+b/F5gWUkcZ/iQ==", - "dev": true, - "dependencies": { - "cosmiconfig": "^7.0.1", - "deepmerge": "^4.2.2", - "svgo": "^2.8.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - }, - "peerDependencies": { - "@svgr/core": "*" - } - }, - "node_modules/@svgr/webpack": { - "version": "6.5.1", - "resolved": "https://registry.npmjs.org/@svgr/webpack/-/webpack-6.5.1.tgz", - "integrity": "sha512-cQ/AsnBkXPkEK8cLbv4Dm7JGXq2XrumKnL1dRpJD9rIO2fTIlJI9a1uCciYG1F2aUsox/hJQyNGbt3soDxSRkA==", - "dev": true, - "dependencies": { - "@babel/core": "^7.19.6", - "@babel/plugin-transform-react-constant-elements": "^7.18.12", - "@babel/preset-env": "^7.19.4", - "@babel/preset-react": "^7.18.6", - "@babel/preset-typescript": "^7.18.6", - "@svgr/core": "^6.5.1", - "@svgr/plugin-jsx": "^6.5.1", - "@svgr/plugin-svgo": "^6.5.1" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/gregberge" - } - }, - "node_modules/@tannin/compile": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@tannin/compile/-/compile-1.1.0.tgz", - "integrity": "sha512-n8m9eNDfoNZoxdvWiTfW/hSPhehzLJ3zW7f8E7oT6mCROoMNWCB4TYtv041+2FMAxweiE0j7i1jubQU4MEC/Gg==", - "dependencies": { - "@tannin/evaluate": "^1.2.0", - "@tannin/postfix": "^1.1.0" - } - }, - "node_modules/@tannin/evaluate": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/@tannin/evaluate/-/evaluate-1.2.0.tgz", - "integrity": "sha512-3ioXvNowbO/wSrxsDG5DKIMxC81P0QrQTYai8zFNY+umuoHWRPbQ/TuuDEOju9E+jQDXmj6yI5GyejNuh8I+eg==" - }, - "node_modules/@tannin/plural-forms": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@tannin/plural-forms/-/plural-forms-1.1.0.tgz", - "integrity": "sha512-xl9R2mDZO/qiHam1AgMnAES6IKIg7OBhcXqy6eDsRCdXuxAFPcjrej9HMjyCLE0DJ/8cHf0i5OQTstuBRhpbHw==", - "dependencies": { - "@tannin/compile": "^1.1.0" - } - }, - "node_modules/@tannin/postfix": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@tannin/postfix/-/postfix-1.1.0.tgz", - "integrity": "sha512-oocsqY7g0cR+Gur5jRQLSrX2OtpMLMse1I10JQBm8CdGMrDkh1Mg2gjsiquMHRtBs4Qwu5wgEp5GgIYHk4SNPw==" - }, - "node_modules/@tootallnate/once": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz", - "integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==", - "dev": true, - "engines": { - "node": ">= 6" - } - }, - "node_modules/@trysound/sax": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/@trysound/sax/-/sax-0.2.0.tgz", - "integrity": "sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA==", - "dev": true, - "engines": { - "node": ">=10.13.0" - } - }, - "node_modules/@types/babel__core": { - "version": "7.1.20", - "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.20.tgz", - "integrity": "sha512-PVb6Bg2QuscZ30FvOU7z4guG6c926D9YRvOxEaelzndpMsvP+YM74Q/dAFASpg2l6+XLalxSGxcq/lrgYWZtyQ==", - "dev": true, - "dependencies": { - "@babel/parser": "^7.1.0", - "@babel/types": "^7.0.0", - "@types/babel__generator": "*", - "@types/babel__template": "*", - "@types/babel__traverse": "*" - } - }, - "node_modules/@types/babel__generator": { - "version": "7.6.4", - "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.4.tgz", - "integrity": "sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg==", - "dev": true, - "dependencies": { - "@babel/types": "^7.0.0" - } - }, - "node_modules/@types/babel__template": { - "version": "7.4.1", - "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.4.1.tgz", - "integrity": "sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g==", - "dev": true, - "dependencies": { - "@babel/parser": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "node_modules/@types/babel__traverse": { - "version": "7.18.3", - "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.18.3.tgz", - "integrity": "sha512-1kbcJ40lLB7MHsj39U4Sh1uTd2E7rLEa79kmDpI6cy+XiXsteB3POdQomoq4FxszMrO3ZYchkhYJw7A2862b3w==", - "dev": true, - "dependencies": { - "@babel/types": "^7.3.0" - } - }, - "node_modules/@types/body-parser": { - "version": "1.19.2", - "resolved": "https://registry.npmjs.org/@types/body-parser/-/body-parser-1.19.2.tgz", - "integrity": "sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==", - "dev": true, - "dependencies": { - "@types/connect": "*", - "@types/node": "*" - } - }, - "node_modules/@types/bonjour": { - "version": "3.5.10", - "resolved": "https://registry.npmjs.org/@types/bonjour/-/bonjour-3.5.10.tgz", - "integrity": "sha512-p7ienRMiS41Nu2/igbJxxLDWrSZ0WxM8UQgCeO9KhoVF7cOVFkrKsiDr1EsJIla8vV3oEEjGcz11jc5yimhzZw==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/connect": { - "version": "3.4.35", - "resolved": "https://registry.npmjs.org/@types/connect/-/connect-3.4.35.tgz", - "integrity": "sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/connect-history-api-fallback": { - "version": "1.3.5", - "resolved": "https://registry.npmjs.org/@types/connect-history-api-fallback/-/connect-history-api-fallback-1.3.5.tgz", - "integrity": "sha512-h8QJa8xSb1WD4fpKBDcATDNGXghFj6/3GRWG6dhmRcu0RX1Ubasur2Uvx5aeEwlf0MwblEC2bMzzMQntxnw/Cw==", - "dev": true, - "dependencies": { - "@types/express-serve-static-core": "*", - "@types/node": "*" - } - }, - "node_modules/@types/dom-speech-recognition": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/@types/dom-speech-recognition/-/dom-speech-recognition-0.0.1.tgz", - "integrity": "sha512-udCxb8DvjcDKfk1WTBzDsxFbLgYxmQGKrE/ricoMqHRNjSlSUCcamVTA5lIQqzY10mY5qCY0QDwBfFEwhfoDPw==" - }, - "node_modules/@types/eslint": { - "version": "8.4.10", - "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.4.10.tgz", - "integrity": "sha512-Sl/HOqN8NKPmhWo2VBEPm0nvHnu2LL3v9vKo8MEq0EtbJ4eVzGPl41VNPvn5E1i5poMk4/XD8UriLHpJvEP/Nw==", - "dev": true, - "dependencies": { - "@types/estree": "*", - "@types/json-schema": "*" - } - }, - "node_modules/@types/eslint-scope": { - "version": "3.7.4", - "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.4.tgz", - "integrity": "sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==", - "dev": true, - "dependencies": { - "@types/eslint": "*", - "@types/estree": "*" - } - }, - "node_modules/@types/estree": { - "version": "0.0.51", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-0.0.51.tgz", - "integrity": "sha512-CuPgU6f3eT/XgKKPqKd/gLZV1Xmvf1a2R5POBOGQa6uv82xpls89HU5zKeVoyR8XzHd1RGNOlQlvUe3CFkjWNQ==", - "dev": true - }, - "node_modules/@types/express": { - "version": "4.17.15", - "resolved": "https://registry.npmjs.org/@types/express/-/express-4.17.15.tgz", - "integrity": "sha512-Yv0k4bXGOH+8a+7bELd2PqHQsuiANB+A8a4gnQrkRWzrkKlb6KHaVvyXhqs04sVW/OWlbPyYxRgYlIXLfrufMQ==", - "dev": true, - "dependencies": { - "@types/body-parser": "*", - "@types/express-serve-static-core": "^4.17.31", - "@types/qs": "*", - "@types/serve-static": "*" - } - }, - "node_modules/@types/express-serve-static-core": { - "version": "4.17.31", - "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.17.31.tgz", - "integrity": "sha512-DxMhY+NAsTwMMFHBTtJFNp5qiHKJ7TeqOo23zVEM9alT1Ml27Q3xcTH0xwxn7Q0BbMcVEJOs/7aQtUWupUQN3Q==", - "dev": true, - "dependencies": { - "@types/node": "*", - "@types/qs": "*", - "@types/range-parser": "*" - } - }, - "node_modules/@types/glob": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.2.0.tgz", - "integrity": "sha512-ZUxbzKl0IfJILTS6t7ip5fQQM/J3TJYubDm3nMbgubNNYS62eXeUpoLUC8/7fJNiFYHTrGPQn7hspDUzIHX3UA==", - "dev": true, - "dependencies": { - "@types/minimatch": "*", - "@types/node": "*" - } - }, - "node_modules/@types/google.maps": { - "version": "3.52.6", - "resolved": "https://registry.npmjs.org/@types/google.maps/-/google.maps-3.52.6.tgz", - "integrity": "sha512-CnwN5UcezNiRuJzV0wGIsqXWNwMM6WzIxmy9lOUx+yauRQMee5XH/N7NaVOsiY5T5ygrnBwPO+csND652HYsTQ==" - }, - "node_modules/@types/graceful-fs": { - "version": "4.1.5", - "resolved": "https://registry.npmjs.org/@types/graceful-fs/-/graceful-fs-4.1.5.tgz", - "integrity": "sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/hogan.js": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/hogan.js/-/hogan.js-3.0.1.tgz", - "integrity": "sha512-D03i/2OY7kGyMq9wdQ7oD8roE49z/ZCZThe/nbahtvuqCNZY9T2MfedOWyeBdbEpY2W8Gnh/dyJLdFtUCOkYbg==" - }, - "node_modules/@types/http-proxy": { - "version": "1.17.9", - "resolved": "https://registry.npmjs.org/@types/http-proxy/-/http-proxy-1.17.9.tgz", - "integrity": "sha512-QsbSjA/fSk7xB+UXlCT3wHBy5ai9wOcNDWwZAtud+jXhwOM3l+EYZh8Lng4+/6n8uar0J7xILzqftJdJ/Wdfkw==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/istanbul-lib-coverage": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz", - "integrity": "sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g==", - "dev": true - }, - "node_modules/@types/istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", - "dev": true, - "dependencies": { - "@types/istanbul-lib-coverage": "*" - } - }, - "node_modules/@types/istanbul-reports": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz", - "integrity": "sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==", - "dev": true, - "dependencies": { - "@types/istanbul-lib-report": "*" - } - }, - "node_modules/@types/json-schema": { - "version": "7.0.11", - "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.11.tgz", - "integrity": "sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==", - "dev": true - }, - "node_modules/@types/json5": { - "version": "0.0.29", - "resolved": "https://registry.npmjs.org/@types/json5/-/json5-0.0.29.tgz", - "integrity": "sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==", - "dev": true - }, - "node_modules/@types/mime": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@types/mime/-/mime-3.0.1.tgz", - "integrity": "sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==", - "dev": true - }, - "node_modules/@types/minimatch": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-5.1.2.tgz", - "integrity": "sha512-K0VQKziLUWkVKiRVrx4a40iPaxTUefQmjtkQofBkYRcoaaL/8rhwDWww9qWbrgicNOgnpIsMxyNIUM4+n6dUIA==", - "dev": true - }, - "node_modules/@types/minimist": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/@types/minimist/-/minimist-1.2.2.tgz", - "integrity": "sha512-jhuKLIRrhvCPLqwPcx6INqmKeiA5EWrsCOPhrlFSrbrmU4ZMPjj5Ul/oLCMDO98XRUIwVm78xICz4EPCektzeQ==", - "dev": true - }, - "node_modules/@types/mousetrap": { - "version": "1.6.11", - "resolved": "https://registry.npmjs.org/@types/mousetrap/-/mousetrap-1.6.11.tgz", - "integrity": "sha512-F0oAily9Q9QQpv9JKxKn0zMKfOo36KHCW7myYsmUyf2t0g+sBTbG3UleTPoguHdE1z3GLFr3p7/wiOio52QFjQ==" - }, - "node_modules/@types/node": { - "version": "18.11.15", - "resolved": "https://registry.npmjs.org/@types/node/-/node-18.11.15.tgz", - "integrity": "sha512-VkhBbVo2+2oozlkdHXLrb3zjsRkpdnaU2bXmX8Wgle3PUi569eLRaHGlgETQHR7lLL1w7GiG3h9SnePhxNDecw==", - "dev": true - }, - "node_modules/@types/normalize-package-data": { - "version": "2.4.1", - "resolved": "https://registry.npmjs.org/@types/normalize-package-data/-/normalize-package-data-2.4.1.tgz", - "integrity": "sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw==", - "dev": true - }, - "node_modules/@types/parse-json": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", - "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==" - }, - "node_modules/@types/prettier": { - "version": "2.7.1", - "resolved": "https://registry.npmjs.org/@types/prettier/-/prettier-2.7.1.tgz", - "integrity": "sha512-ri0UmynRRvZiiUJdiz38MmIblKK+oH30MztdBVR95dv/Ubw6neWSb8u1XpRb72L4qsZOhz+L+z9JD40SJmfWow==", - "dev": true - }, - "node_modules/@types/prop-types": { - "version": "15.7.5", - "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.5.tgz", - "integrity": "sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==" - }, - "node_modules/@types/qs": { - "version": "6.9.7", - "resolved": "https://registry.npmjs.org/@types/qs/-/qs-6.9.7.tgz", - "integrity": "sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==" - }, - "node_modules/@types/range-parser": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/@types/range-parser/-/range-parser-1.2.4.tgz", - "integrity": "sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==", - "dev": true - }, - "node_modules/@types/react": { - "version": "18.0.26", - "resolved": "https://registry.npmjs.org/@types/react/-/react-18.0.26.tgz", - "integrity": "sha512-hCR3PJQsAIXyxhTNSiDFY//LhnMZWpNNr5etoCqx/iUfGc5gXWtQR2Phl908jVR6uPXacojQWTg4qRpkxTuGug==", - "dependencies": { - "@types/prop-types": "*", - "@types/scheduler": "*", - "csstype": "^3.0.2" - } - }, - "node_modules/@types/react-dom": { - "version": "18.0.9", - "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-18.0.9.tgz", - "integrity": "sha512-qnVvHxASt/H7i+XG1U1xMiY5t+IHcPGUK7TDMDzom08xa7e86eCeKOiLZezwCKVxJn6NEiiy2ekgX8aQssjIKg==", - "dependencies": { - "@types/react": "*" - } - }, - "node_modules/@types/retry": { - "version": "0.12.0", - "resolved": "https://registry.npmjs.org/@types/retry/-/retry-0.12.0.tgz", - "integrity": "sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==", - "dev": true - }, - "node_modules/@types/scheduler": { - "version": "0.16.2", - "resolved": "https://registry.npmjs.org/@types/scheduler/-/scheduler-0.16.2.tgz", - "integrity": "sha512-hppQEBDmlwhFAXKJX2KnWLYu5yMfi91yazPb2l+lbJiwW+wdo1gNeRA+3RgNSO39WYX2euey41KEwnqesU2Jew==" - }, - "node_modules/@types/semver": { - "version": "7.3.13", - "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.3.13.tgz", - "integrity": "sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==", - "dev": true - }, - "node_modules/@types/serve-index": { - "version": "1.9.1", - "resolved": "https://registry.npmjs.org/@types/serve-index/-/serve-index-1.9.1.tgz", - "integrity": "sha512-d/Hs3nWDxNL2xAczmOVZNj92YZCS6RGxfBPjKzuu/XirCgXdpKEb88dYNbrYGint6IVWLNP+yonwVAuRC0T2Dg==", - "dev": true, - "dependencies": { - "@types/express": "*" - } - }, - "node_modules/@types/serve-static": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/@types/serve-static/-/serve-static-1.15.0.tgz", - "integrity": "sha512-z5xyF6uh8CbjAu9760KDKsH2FcDxZ2tFCsA4HIMWE6IkiYMXfVoa+4f9KX+FN0ZLsaMw1WNG2ETLA6N+/YA+cg==", - "dev": true, - "dependencies": { - "@types/mime": "*", - "@types/node": "*" - } - }, - "node_modules/@types/sockjs": { - "version": "0.3.33", - "resolved": "https://registry.npmjs.org/@types/sockjs/-/sockjs-0.3.33.tgz", - "integrity": "sha512-f0KEEe05NvUnat+boPTZ0dgaLZ4SfSouXUgv5noUiefG2ajgKjmETo9ZJyuqsl7dfl2aHlLJUiki6B4ZYldiiw==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/source-list-map": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/@types/source-list-map/-/source-list-map-0.1.2.tgz", - "integrity": "sha512-K5K+yml8LTo9bWJI/rECfIPrGgxdpeNbj+d53lwN4QjW1MCwlkhUms+gtdzigTeUyBr09+u8BwOIY3MXvHdcsA==", - "dev": true - }, - "node_modules/@types/stack-utils": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-2.0.1.tgz", - "integrity": "sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==", - "dev": true - }, - "node_modules/@types/tapable": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/@types/tapable/-/tapable-1.0.8.tgz", - "integrity": "sha512-ipixuVrh2OdNmauvtT51o3d8z12p6LtFW9in7U79der/kwejjdNchQC5UMn5u/KxNoM7VHHOs/l8KS8uHxhODQ==", - "dev": true - }, - "node_modules/@types/uglify-js": { - "version": "3.17.1", - "resolved": "https://registry.npmjs.org/@types/uglify-js/-/uglify-js-3.17.1.tgz", - "integrity": "sha512-GkewRA4i5oXacU/n4MA9+bLgt5/L3F1mKrYvFGm7r2ouLXhRKjuWwo9XHNnbx6WF3vlGW21S3fCvgqxvxXXc5g==", - "dev": true, - "dependencies": { - "source-map": "^0.6.1" - } - }, - "node_modules/@types/uglify-js/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/@types/webpack": { - "version": "4.41.33", - "resolved": "https://registry.npmjs.org/@types/webpack/-/webpack-4.41.33.tgz", - "integrity": "sha512-PPajH64Ft2vWevkerISMtnZ8rTs4YmRbs+23c402J0INmxDKCrhZNvwZYtzx96gY2wAtXdrK1BS2fiC8MlLr3g==", - "dev": true, - "dependencies": { - "@types/node": "*", - "@types/tapable": "^1", - "@types/uglify-js": "*", - "@types/webpack-sources": "*", - "anymatch": "^3.0.0", - "source-map": "^0.6.0" - } - }, - "node_modules/@types/webpack-sources": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/@types/webpack-sources/-/webpack-sources-3.2.0.tgz", - "integrity": "sha512-Ft7YH3lEVRQ6ls8k4Ff1oB4jN6oy/XmU6tQISKdhfh+1mR+viZFphS6WL0IrtDOzvefmJg5a0s7ZQoRXwqTEFg==", - "dev": true, - "dependencies": { - "@types/node": "*", - "@types/source-list-map": "*", - "source-map": "^0.7.3" - } - }, - "node_modules/@types/webpack-sources/node_modules/source-map": { - "version": "0.7.4", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", - "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", - "dev": true, - "engines": { - "node": ">= 8" - } - }, - "node_modules/@types/webpack/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/@types/ws": { - "version": "8.5.3", - "resolved": "https://registry.npmjs.org/@types/ws/-/ws-8.5.3.tgz", - "integrity": "sha512-6YOoWjruKj1uLf3INHH7D3qTXwFfEsg1kf3c0uDdSBJwfa/llkwIjrAGV7j7mVgGNbzTQ3HiHKKDXl6bJPD97w==", - "dev": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@types/yargs": { - "version": "16.0.4", - "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-16.0.4.tgz", - "integrity": "sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw==", - "dev": true, - "dependencies": { - "@types/yargs-parser": "*" - } - }, - "node_modules/@types/yargs-parser": { - "version": "21.0.0", - "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-21.0.0.tgz", - "integrity": "sha512-iO9ZQHkZxHn4mSakYV0vFHAVDyEOIJQrV2uZ06HxEPcx+mt8swXoZHIbaaJ2crJYFfErySgktuTZ3BeLz+XmFA==", - "dev": true - }, - "node_modules/@types/yauzl": { - "version": "2.10.0", - "resolved": "https://registry.npmjs.org/@types/yauzl/-/yauzl-2.10.0.tgz", - "integrity": "sha512-Cn6WYCm0tXv8p6k+A8PvbDG763EDpBoTzHdA+Q/MF6H3sapGjCm9NzoaJncJS9tUKSuCoDs9XHxYYsQDgxR6kw==", - "dev": true, - "optional": true, - "dependencies": { - "@types/node": "*" - } - }, - "node_modules/@typescript-eslint/eslint-plugin": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-5.46.1.tgz", - "integrity": "sha512-YpzNv3aayRBwjs4J3oz65eVLXc9xx0PDbIRisHj+dYhvBn02MjYOD96P8YGiWEIFBrojaUjxvkaUpakD82phsA==", - "dev": true, - "dependencies": { - "@typescript-eslint/scope-manager": "5.46.1", - "@typescript-eslint/type-utils": "5.46.1", - "@typescript-eslint/utils": "5.46.1", - "debug": "^4.3.4", - "ignore": "^5.2.0", - "natural-compare-lite": "^1.4.0", - "regexpp": "^3.2.0", - "semver": "^7.3.7", - "tsutils": "^3.21.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "@typescript-eslint/parser": "^5.0.0", - "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" - }, - "peerDependenciesMeta": { - "typescript": { - "optional": true - } - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/@typescript-eslint/experimental-utils": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-5.46.1.tgz", - "integrity": "sha512-M79mkB+wOuiBG8jzOVNA2h5izOip5CNPZV1K3tvE/qry/1Oh/bnKYhNWQNiH2h9O3B73YK60GmiqrUpprnQ5sQ==", - "dev": true, - "dependencies": { - "@typescript-eslint/utils": "5.46.1" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" - } - }, - "node_modules/@typescript-eslint/parser": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-5.46.1.tgz", - "integrity": "sha512-RelQ5cGypPh4ySAtfIMBzBGyrNerQcmfA1oJvPj5f+H4jI59rl9xxpn4bonC0tQvUKOEN7eGBFWxFLK3Xepneg==", - "dev": true, - "dependencies": { - "@typescript-eslint/scope-manager": "5.46.1", - "@typescript-eslint/types": "5.46.1", - "@typescript-eslint/typescript-estree": "5.46.1", - "debug": "^4.3.4" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" - }, - "peerDependenciesMeta": { - "typescript": { - "optional": true - } - } - }, - "node_modules/@typescript-eslint/scope-manager": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.46.1.tgz", - "integrity": "sha512-iOChVivo4jpwUdrJZyXSMrEIM/PvsbbDOX1y3UCKjSgWn+W89skxWaYXACQfxmIGhPVpRWK/VWPYc+bad6smIA==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "5.46.1", - "@typescript-eslint/visitor-keys": "5.46.1" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/type-utils": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-5.46.1.tgz", - "integrity": "sha512-V/zMyfI+jDmL1ADxfDxjZ0EMbtiVqj8LUGPAGyBkXXStWmCUErMpW873zEHsyguWCuq2iN4BrlWUkmuVj84yng==", - "dev": true, - "dependencies": { - "@typescript-eslint/typescript-estree": "5.46.1", - "@typescript-eslint/utils": "5.46.1", - "debug": "^4.3.4", - "tsutils": "^3.21.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "eslint": "*" - }, - "peerDependenciesMeta": { - "typescript": { - "optional": true - } - } - }, - "node_modules/@typescript-eslint/types": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.46.1.tgz", - "integrity": "sha512-Z5pvlCaZgU+93ryiYUwGwLl9AQVB/PQ1TsJ9NZ/gHzZjN7g9IAn6RSDkpCV8hqTwAiaj6fmCcKSQeBPlIpW28w==", - "dev": true, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/typescript-estree": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.46.1.tgz", - "integrity": "sha512-j9W4t67QiNp90kh5Nbr1w92wzt+toiIsaVPnEblB2Ih2U9fqBTyqV9T3pYWZBRt6QoMh/zVWP59EpuCjc4VRBg==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "5.46.1", - "@typescript-eslint/visitor-keys": "5.46.1", - "debug": "^4.3.4", - "globby": "^11.1.0", - "is-glob": "^4.0.3", - "semver": "^7.3.7", - "tsutils": "^3.21.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependenciesMeta": { - "typescript": { - "optional": true - } - } - }, - "node_modules/@typescript-eslint/typescript-estree/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@typescript-eslint/typescript-estree/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@typescript-eslint/typescript-estree/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/@typescript-eslint/utils": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.46.1.tgz", - "integrity": "sha512-RBdBAGv3oEpFojaCYT4Ghn4775pdjvwfDOfQ2P6qzNVgQOVrnSPe5/Pb88kv7xzYQjoio0eKHKB9GJ16ieSxvA==", - "dev": true, - "dependencies": { - "@types/json-schema": "^7.0.9", - "@types/semver": "^7.3.12", - "@typescript-eslint/scope-manager": "5.46.1", - "@typescript-eslint/types": "5.46.1", - "@typescript-eslint/typescript-estree": "5.46.1", - "eslint-scope": "^5.1.1", - "eslint-utils": "^3.0.0", - "semver": "^7.3.7" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" - } - }, - "node_modules/@typescript-eslint/utils/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@typescript-eslint/utils/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/@typescript-eslint/utils/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/@typescript-eslint/visitor-keys": { - "version": "5.46.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.46.1.tgz", - "integrity": "sha512-jczZ9noovXwy59KjRTk1OftT78pwygdcmCuBf8yMoWt/8O8l+6x2LSEze0E4TeepXK4MezW3zGSyoDRZK7Y9cg==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "5.46.1", - "eslint-visitor-keys": "^3.3.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/visitor-keys/node_modules/eslint-visitor-keys": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", - "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", - "dev": true, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - } - }, - "node_modules/@use-gesture/core": { - "version": "10.2.23", - "resolved": "https://registry.npmjs.org/@use-gesture/core/-/core-10.2.23.tgz", - "integrity": "sha512-Ynap/Uh6RX1Vgn3zNmFTyKapapdf7Av+GzAe6h+RsBZaxMF1z3cK6aohHPJP6T1hLrPyH/yehxa7RBqyESG9RA==" - }, - "node_modules/@use-gesture/react": { - "version": "10.2.23", - "resolved": "https://registry.npmjs.org/@use-gesture/react/-/react-10.2.23.tgz", - "integrity": "sha512-anj9j3Lm4l+/s60Jv1FD2m13r+T+aYstSHUT62hTugojM64LPe9XatfEVHRyWOrGjRU2buQhlm03xN8oxkg/OQ==", - "dependencies": { - "@use-gesture/core": "10.2.23" - }, - "peerDependencies": { - "react": ">= 16.8.0" - } - }, - "node_modules/@webassemblyjs/ast": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.11.1.tgz", - "integrity": "sha512-ukBh14qFLjxTQNTXocdyksN5QdM28S1CxHt2rdskFyL+xFV7VremuBLVbmCePj+URalXBENx/9Lm7lnhihtCSw==", - "dev": true, - "dependencies": { - "@webassemblyjs/helper-numbers": "1.11.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.1" - } - }, - "node_modules/@webassemblyjs/floating-point-hex-parser": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.1.tgz", - "integrity": "sha512-iGRfyc5Bq+NnNuX8b5hwBrRjzf0ocrJPI6GWFodBFzmFnyvrQ83SHKhmilCU/8Jv67i4GJZBMhEzltxzcNagtQ==", - "dev": true - }, - "node_modules/@webassemblyjs/helper-api-error": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.1.tgz", - "integrity": "sha512-RlhS8CBCXfRUR/cwo2ho9bkheSXG0+NwooXcc3PAILALf2QLdFyj7KGsKRbVc95hZnhnERon4kW/D3SZpp6Tcg==", - "dev": true - }, - "node_modules/@webassemblyjs/helper-buffer": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.11.1.tgz", - "integrity": "sha512-gwikF65aDNeeXa8JxXa2BAk+REjSyhrNC9ZwdT0f8jc4dQQeDQ7G4m0f2QCLPJiMTTO6wfDmRmj/pW0PsUvIcA==", - "dev": true - }, - "node_modules/@webassemblyjs/helper-numbers": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.1.tgz", - "integrity": "sha512-vDkbxiB8zfnPdNK9Rajcey5C0w+QJugEglN0of+kmO8l7lDb77AnlKYQF7aarZuCrv+l0UvqL+68gSDr3k9LPQ==", - "dev": true, - "dependencies": { - "@webassemblyjs/floating-point-hex-parser": "1.11.1", - "@webassemblyjs/helper-api-error": "1.11.1", - "@xtuc/long": "4.2.2" - } - }, - "node_modules/@webassemblyjs/helper-wasm-bytecode": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.1.tgz", - "integrity": "sha512-PvpoOGiJwXeTrSf/qfudJhwlvDQxFgelbMqtq52WWiXC6Xgg1IREdngmPN3bs4RoO83PnL/nFrxucXj1+BX62Q==", - "dev": true - }, - "node_modules/@webassemblyjs/helper-wasm-section": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.11.1.tgz", - "integrity": "sha512-10P9No29rYX1j7F3EVPX3JvGPQPae+AomuSTPiF9eBQeChHI6iqjMIwR9JmOJXwpnn/oVGDk7I5IlskuMwU/pg==", - "dev": true, - "dependencies": { - "@webassemblyjs/ast": "1.11.1", - "@webassemblyjs/helper-buffer": "1.11.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.1", - "@webassemblyjs/wasm-gen": "1.11.1" - } - }, - "node_modules/@webassemblyjs/ieee754": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.1.tgz", - "integrity": "sha512-hJ87QIPtAMKbFq6CGTkZYJivEwZDbQUgYd3qKSadTNOhVY7p+gfP6Sr0lLRVTaG1JjFj+r3YchoqRYxNH3M0GQ==", - "dev": true, - "dependencies": { - "@xtuc/ieee754": "^1.2.0" - } - }, - "node_modules/@webassemblyjs/leb128": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.1.tgz", - "integrity": "sha512-BJ2P0hNZ0u+Th1YZXJpzW6miwqQUGcIHT1G/sf72gLVD9DZ5AdYTqPNbHZh6K1M5VmKvFXwGSWZADz+qBWxeRw==", - "dev": true, - "dependencies": { - "@xtuc/long": "4.2.2" - } - }, - "node_modules/@webassemblyjs/utf8": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.1.tgz", - "integrity": "sha512-9kqcxAEdMhiwQkHpkNiorZzqpGrodQQ2IGrHHxCy+Ozng0ofyMA0lTqiLkVs1uzTRejX+/O0EOT7KxqVPuXosQ==", - "dev": true - }, - "node_modules/@webassemblyjs/wasm-edit": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.11.1.tgz", - "integrity": "sha512-g+RsupUC1aTHfR8CDgnsVRVZFJqdkFHpsHMfJuWQzWU3tvnLC07UqHICfP+4XyL2tnr1amvl1Sdp06TnYCmVkA==", - "dev": true, - "dependencies": { - "@webassemblyjs/ast": "1.11.1", - "@webassemblyjs/helper-buffer": "1.11.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.1", - "@webassemblyjs/helper-wasm-section": "1.11.1", - "@webassemblyjs/wasm-gen": "1.11.1", - "@webassemblyjs/wasm-opt": "1.11.1", - "@webassemblyjs/wasm-parser": "1.11.1", - "@webassemblyjs/wast-printer": "1.11.1" - } - }, - "node_modules/@webassemblyjs/wasm-gen": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.11.1.tgz", - "integrity": "sha512-F7QqKXwwNlMmsulj6+O7r4mmtAlCWfO/0HdgOxSklZfQcDu0TpLiD1mRt/zF25Bk59FIjEuGAIyn5ei4yMfLhA==", - "dev": true, - "dependencies": { - "@webassemblyjs/ast": "1.11.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.1", - "@webassemblyjs/ieee754": "1.11.1", - "@webassemblyjs/leb128": "1.11.1", - "@webassemblyjs/utf8": "1.11.1" - } - }, - "node_modules/@webassemblyjs/wasm-opt": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.11.1.tgz", - "integrity": "sha512-VqnkNqnZlU5EB64pp1l7hdm3hmQw7Vgqa0KF/KCNO9sIpI6Fk6brDEiX+iCOYrvMuBWDws0NkTOxYEb85XQHHw==", - "dev": true, - "dependencies": { - "@webassemblyjs/ast": "1.11.1", - "@webassemblyjs/helper-buffer": "1.11.1", - "@webassemblyjs/wasm-gen": "1.11.1", - "@webassemblyjs/wasm-parser": "1.11.1" - } - }, - "node_modules/@webassemblyjs/wasm-parser": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.11.1.tgz", - "integrity": "sha512-rrBujw+dJu32gYB7/Lup6UhdkPx9S9SnobZzRVL7VcBH9Bt9bCBLEuX/YXOOtBsOZ4NQrRykKhffRWHvigQvOA==", - "dev": true, - "dependencies": { - "@webassemblyjs/ast": "1.11.1", - "@webassemblyjs/helper-api-error": "1.11.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.1", - "@webassemblyjs/ieee754": "1.11.1", - "@webassemblyjs/leb128": "1.11.1", - "@webassemblyjs/utf8": "1.11.1" - } - }, - "node_modules/@webassemblyjs/wast-printer": { - "version": "1.11.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.11.1.tgz", - "integrity": "sha512-IQboUWM4eKzWW+N/jij2sRatKMh99QEelo3Eb2q0qXkvPRISAj8Qxtmw5itwqK+TTkBuUIE45AxYPToqPtL5gg==", - "dev": true, - "dependencies": { - "@webassemblyjs/ast": "1.11.1", - "@xtuc/long": "4.2.2" - } - }, - "node_modules/@webpack-cli/configtest": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/@webpack-cli/configtest/-/configtest-1.2.0.tgz", - "integrity": "sha512-4FB8Tj6xyVkyqjj1OaTqCjXYULB9FMkqQ8yGrZjRDrYh0nOE+7Lhs45WioWQQMV+ceFlE368Ukhe6xdvJM9Egg==", - "dev": true, - "peerDependencies": { - "webpack": "4.x.x || 5.x.x", - "webpack-cli": "4.x.x" - } - }, - "node_modules/@webpack-cli/info": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/@webpack-cli/info/-/info-1.5.0.tgz", - "integrity": "sha512-e8tSXZpw2hPl2uMJY6fsMswaok5FdlGNRTktvFk2sD8RjH0hE2+XistawJx1vmKteh4NmGmNUrp+Tb2w+udPcQ==", - "dev": true, - "dependencies": { - "envinfo": "^7.7.3" - }, - "peerDependencies": { - "webpack-cli": "4.x.x" - } - }, - "node_modules/@webpack-cli/serve": { - "version": "1.7.0", - "resolved": "https://registry.npmjs.org/@webpack-cli/serve/-/serve-1.7.0.tgz", - "integrity": "sha512-oxnCNGj88fL+xzV+dacXs44HcDwf1ovs3AuEzvP7mqXw7fQntqIhQ1BRmynh4qEKQSSSRSWVyXRjmTbZIX9V2Q==", - "dev": true, - "peerDependencies": { - "webpack-cli": "4.x.x" - }, - "peerDependenciesMeta": { - "webpack-dev-server": { - "optional": true - } - } - }, - "node_modules/@wordpress/a11y": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/a11y/-/a11y-3.25.0.tgz", - "integrity": "sha512-EAsrCLv5Kh9jhDnhe2GgGVyiJ5YzhDZXi9UDgfKsi1XSTFD0IJ0nEQ0adyNMms5C5PPBXL7ygjxQO9domKdzTw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/dom-ready": "^3.25.0", - "@wordpress/i18n": "^4.25.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/a11y/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/api-fetch": { - "version": "6.20.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.20.0.tgz", - "integrity": "sha512-FZxugM4PZT778I3NZM9z+JmskPG+xCNdAwxFtetjurgMvlflB5dJ8FrXvGNSawA+HONdbK2KTlF4wVAtzkieRA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.23.0", - "@wordpress/url": "^3.24.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/autop": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/autop/-/autop-3.25.0.tgz", - "integrity": "sha512-7u8+FKkZnv8S6Gxy+7znyofETxZAzSkO9cGXlb6MQYps2t5o4KojV8jGh5sq663cxvbEW1lr8xhmHNWCaftJRg==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/babel-plugin-import-jsx-pragma": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/babel-plugin-import-jsx-pragma/-/babel-plugin-import-jsx-pragma-4.6.0.tgz", - "integrity": "sha512-Ca20Qrn31jVZ+6IsrXqBJo81FqVI3LUE63tPYyICFQf6GX7giqTt4GKnHBUDNpbwbHiV6Pk+IlsveYundvCHqw==", - "dev": true, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "@babel/core": "^7.12.9" - } - }, - "node_modules/@wordpress/babel-preset-default": { - "version": "7.7.0", - "resolved": "https://registry.npmjs.org/@wordpress/babel-preset-default/-/babel-preset-default-7.7.0.tgz", - "integrity": "sha512-9o4//xh15M/qfn8rkmZnhqthJW5oY3JbiadqDdqK7iQyBcDnSVzLH3057a5D8e8mM93bpNb57F50IbtESnBUTw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.16.0", - "@babel/plugin-transform-react-jsx": "^7.16.0", - "@babel/plugin-transform-runtime": "^7.16.0", - "@babel/preset-env": "^7.16.0", - "@babel/preset-typescript": "^7.16.0", - "@babel/runtime": "^7.16.0", - "@wordpress/babel-plugin-import-jsx-pragma": "^4.6.0", - "@wordpress/browserslist-config": "^5.6.0", - "@wordpress/element": "^5.0.0", - "@wordpress/warning": "^2.23.0", - "browserslist": "^4.17.6", - "core-js": "^3.19.1" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/@wordpress/base-styles": { - "version": "4.14.0", - "resolved": "https://registry.npmjs.org/@wordpress/base-styles/-/base-styles-4.14.0.tgz", - "integrity": "sha512-L7O5I/zklZsolzLOtG9gPf3opYnuB7/UJK8LAK7kJc//2jxaPAlUjvP8bqX35y5a9fMpPGfQS4CHxGZbik8WYg==", - "dev": true - }, - "node_modules/@wordpress/blob": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/blob/-/blob-3.25.0.tgz", - "integrity": "sha512-jgjcgiliYG4edS7ky+zKR2jms+7mJ/Gfe0vQLn194S4nIAW5IcsRZUqHyL1O41VRF6XXtvWyMksXqgTNgUGePA==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/block-editor": { - "version": "11.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/block-editor/-/block-editor-11.2.0.tgz", - "integrity": "sha512-7ILJa0XO5ZkeJ9iDGkCJXtrFRxZr1zKOdClFyq4ddhP6hsFISvhS4Q1hGejmtIQkvyfJbEKza17yzLCMcoRE4w==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@react-spring/web": "^9.4.5", - "@wordpress/a11y": "^3.25.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/blob": "^3.25.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/components": "^23.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/html-entities": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keyboard-shortcuts": "^4.2.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/notices": "^3.25.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/shortcode": "^3.25.0", - "@wordpress/style-engine": "^1.8.0", - "@wordpress/token-list": "^2.25.0", - "@wordpress/url": "^3.26.0", - "@wordpress/warning": "^2.25.0", - "@wordpress/wordcount": "^3.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "diff": "^4.0.2", - "dom-scroll-into-view": "^1.2.1", - "fast-deep-equal": "^3.1.3", - "inherits": "^2.0.3", - "lodash": "^4.17.21", - "react-autosize-textarea": "^7.1.0", - "react-easy-crop": "^4.5.1", - "rememo": "^4.0.0", - "remove-accents": "^0.4.2", - "traverse": "^0.6.6" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/block-editor/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/block-editor/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/block-editor/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/block-editor/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/block-library": { - "version": "8.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/block-library/-/block-library-8.2.0.tgz", - "integrity": "sha512-wYutqssQjr78HDfYHUVkjBHRn5T/TKSbqmx0novznfLuhOVOAubH+L04mjh3g/DpA1x6qAHh873OA9T812gWeA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/a11y": "^3.25.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/autop": "^3.25.0", - "@wordpress/blob": "^3.25.0", - "@wordpress/block-editor": "^11.2.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/components": "^23.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/core-data": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/html-entities": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/notices": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/reusable-blocks": "^4.2.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/server-side-render": "^4.2.0", - "@wordpress/url": "^3.26.0", - "@wordpress/viewport": "^5.2.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "escape-html": "^1.0.3", - "fast-average-color": "^9.1.1", - "fast-deep-equal": "^3.1.3", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "micromodal": "^0.4.10", - "remove-accents": "^0.4.2" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/block-library/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/block-library/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/block-library/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/block-library/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/block-serialization-default-parser": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/block-serialization-default-parser/-/block-serialization-default-parser-4.25.0.tgz", - "integrity": "sha512-ntUx+K0souSoTb6RkovYWb+KIc9FYsYMZwbStwDWuO4p1StgVYAFVQ2NX2hKeyXJU2RQEincYi2OLHsjnoV1yQ==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/blocks": { - "version": "12.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/blocks/-/blocks-12.2.0.tgz", - "integrity": "sha512-UF4fSyjOgdul8lAKY/ohFKFZdVXTXJzuSmKULKVJR/nkLNw+UpCVbQB1tj12yNaLqzQK05o//dmg6Y3u+fFjhA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/autop": "^3.25.0", - "@wordpress/blob": "^3.25.0", - "@wordpress/block-serialization-default-parser": "^4.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/html-entities": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/shortcode": "^3.25.0", - "change-case": "^4.1.2", - "colord": "^2.7.0", - "fast-deep-equal": "^3.1.3", - "hpq": "^1.3.0", - "is-plain-object": "^5.0.0", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "rememo": "^4.0.0", - "remove-accents": "^0.4.2", - "showdown": "^1.9.1", - "simple-html-tokenizer": "^0.5.7", - "uuid": "^8.3.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/blocks/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/blocks/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/browserslist-config": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/browserslist-config/-/browserslist-config-5.6.0.tgz", - "integrity": "sha512-utn4U1Hy4Csq9i+BSCN6YzSn603IMrhOX6ChdCW7vrNVVoDWsOwAGPPPTbnxSf39x761mu2Uts6zgKAoSlguUQ==", - "dev": true, - "engines": { - "node": ">=14" - } - }, - "node_modules/@wordpress/components": { - "version": "23.0.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.0.0.tgz", - "integrity": "sha512-EuWvm1DZ+b5JVdxVUnWgJewN4M9VCtCxwyOiitv7IfreLhOr/3ikZJFc7u0F3AWvH8GiBs4g+88oaNwujzssMQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.23.0", - "@wordpress/compose": "^6.0.0", - "@wordpress/date": "^4.23.0", - "@wordpress/deprecated": "^3.23.0", - "@wordpress/dom": "^3.23.0", - "@wordpress/element": "^5.0.0", - "@wordpress/escape-html": "^2.23.0", - "@wordpress/hooks": "^3.23.0", - "@wordpress/i18n": "^4.23.0", - "@wordpress/icons": "^9.14.0", - "@wordpress/is-shallow-equal": "^4.23.0", - "@wordpress/keycodes": "^3.23.0", - "@wordpress/primitives": "^3.21.0", - "@wordpress/rich-text": "^6.0.0", - "@wordpress/warning": "^2.23.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/compose": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/@wordpress/compose/-/compose-6.3.0.tgz", - "integrity": "sha512-VenvmENQGbuKyer+oy4Ij/qzhZfvdzyW8WCfn1cjcNYvU7WuoHhwvNxZ4Cvtwo0WiTyeV1+bgMUwkAjXtpqkdw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/mousetrap": "^1.6.8", - "@wordpress/deprecated": "^3.26.0", - "@wordpress/dom": "^3.26.0", - "@wordpress/element": "^5.3.0", - "@wordpress/is-shallow-equal": "^4.26.0", - "@wordpress/keycodes": "^3.26.0", - "@wordpress/priority-queue": "^2.26.0", - "change-case": "^4.1.2", - "clipboard": "^2.0.8", - "mousetrap": "^1.6.5", - "use-memo-one": "^1.1.1" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/compose/node_modules/@wordpress/element": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.3.0.tgz", - "integrity": "sha512-sgBrPm9suYx9sAtMLnfqgJem54Vew+BvVRpQoKQjpoXAKklGKSr52xOERek2TZQuZl/hMCCdvScrLIIW96UNAw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.26.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/core-data": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/core-data/-/core-data-6.2.0.tgz", - "integrity": "sha512-+SDHNjiZFJIdEJYTQvP3Cs87oS7OobpqonRbAD1qWJo4U/3/Xf5xLStRNrDHuq9emN3eJ2mK/CkobrtMl+rdRQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/html-entities": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/url": "^3.26.0", - "change-case": "^4.1.2", - "equivalent-key-map": "^0.2.2", - "fast-deep-equal": "^3.1.3", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "rememo": "^4.0.0", - "uuid": "^8.3.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/core-data/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/core-data/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/core-data/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/data": { - "version": "8.3.0", - "resolved": "https://registry.npmjs.org/@wordpress/data/-/data-8.3.0.tgz", - "integrity": "sha512-cKpZXI3jJW4iuH3pCJYzwAMAVwRrk9iSK4rQz5H0sGWAzedd0+n6yUVTWUVhoihpCdfgqVkVRoCOQ9Diek0hBA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/compose": "^6.3.0", - "@wordpress/deprecated": "^3.26.0", - "@wordpress/element": "^5.3.0", - "@wordpress/experiments": "^0.8.0", - "@wordpress/is-shallow-equal": "^4.26.0", - "@wordpress/priority-queue": "^2.26.0", - "@wordpress/redux-routine": "^4.26.0", - "equivalent-key-map": "^0.2.2", - "is-plain-object": "^5.0.0", - "is-promise": "^4.0.0", - "lodash": "^4.17.21", - "redux": "^4.1.2", - "turbo-combine-reducers": "^1.0.2", - "use-memo-one": "^1.1.1" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/data/node_modules/@wordpress/element": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.3.0.tgz", - "integrity": "sha512-sgBrPm9suYx9sAtMLnfqgJem54Vew+BvVRpQoKQjpoXAKklGKSr52xOERek2TZQuZl/hMCCdvScrLIIW96UNAw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.26.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/date": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/date/-/date-4.25.0.tgz", - "integrity": "sha512-aHDezuzMJQrSb+Yb2X36xmb4RZV0cPkAcZcyTk5KYz80glKTsTwIP+5dGVpFEpHL6ytOAWA9sWSPdynzqNSmhQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/deprecated": "^3.25.0", - "moment": "^2.22.1", - "moment-timezone": "^0.5.31" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/dependency-extraction-webpack-plugin": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/dependency-extraction-webpack-plugin/-/dependency-extraction-webpack-plugin-4.6.0.tgz", - "integrity": "sha512-xLF0sZ/SB1mk0iZHc5Rs1uMyXrv9ZNXIEeTdmyX0I7u74LgQcxYcTA3zqYiiDPcqPZiBes/jSgJu2Ju0UzsRYQ==", - "dev": true, - "dependencies": { - "json2php": "^0.0.5", - "webpack-sources": "^3.2.2" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "webpack": "^4.8.3 || ^5.0.0" - } - }, - "node_modules/@wordpress/deprecated": { - "version": "3.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/deprecated/-/deprecated-3.26.0.tgz", - "integrity": "sha512-njxd5FkFG12QF0ekcEl96jlgcxQ38Z9l41BxHGAoT27ibO8LDOr08dEKjO8l+QXaKRiFlDLfg4iSVEuMQms1Gw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/dom": { - "version": "3.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/dom/-/dom-3.26.0.tgz", - "integrity": "sha512-Y404VmJFYeauZbOd+3Dz6WDgyRnYe8E6kfwhOyUijSg6CvEvwOqBeURJJVH9FTqVa/b027lrz3SdR1EXtM8Jpw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/deprecated": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/dom-ready": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/dom-ready/-/dom-ready-3.25.0.tgz", - "integrity": "sha512-O9Qo01H9+f3gasu/mPLOOH92YpyRTgIhkfe680UyXTT6Q5QRYImk1TFE0y88RqW29WQ92rVi7XO5LErf6VULEQ==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/edit-post": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/edit-post/-/edit-post-7.2.0.tgz", - "integrity": "sha512-D/qOFbbW0B8cWUSKeHDIOjgVUap9vjRiuz80Ng6F2stgaBFKPaav2FG+5SK3GPLMjGoWbnW8177hPVGLxj+zfw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/a11y": "^3.25.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/block-editor": "^11.2.0", - "@wordpress/block-library": "^8.2.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/components": "^23.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/core-data": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/editor": "^13.2.0", - "@wordpress/element": "^5.2.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/interface": "^5.2.0", - "@wordpress/keyboard-shortcuts": "^4.2.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/media-utils": "^4.16.0", - "@wordpress/notices": "^3.25.0", - "@wordpress/plugins": "^5.2.0", - "@wordpress/preferences": "^3.2.0", - "@wordpress/url": "^3.26.0", - "@wordpress/viewport": "^5.2.0", - "@wordpress/warning": "^2.25.0", - "@wordpress/widgets": "^3.2.0", - "classnames": "^2.3.1", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "rememo": "^4.0.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/edit-post/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/edit-post/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/edit-post/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/edit-post/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/editor": { - "version": "13.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/editor/-/editor-13.2.0.tgz", - "integrity": "sha512-ZCcxmqiQumzfipKm6cm90Csqb2ff74f5NALur2+zxfhY5f+H+pAjAJKg5l2nY1eJzPcFFDqTfYVUupoaYOiluQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/a11y": "^3.25.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/blob": "^3.25.0", - "@wordpress/block-editor": "^11.2.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/components": "^23.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/core-data": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/html-entities": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/keyboard-shortcuts": "^4.2.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/media-utils": "^4.16.0", - "@wordpress/notices": "^3.25.0", - "@wordpress/preferences": "^3.2.0", - "@wordpress/reusable-blocks": "^4.2.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/server-side-render": "^4.2.0", - "@wordpress/url": "^3.26.0", - "@wordpress/wordcount": "^3.25.0", - "classnames": "^2.3.1", - "date-fns": "^2.28.0", - "escape-html": "^1.0.3", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "react-autosize-textarea": "^7.1.0", - "rememo": "^4.0.0", - "remove-accents": "^0.4.2" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/editor/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/editor/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/editor/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/editor/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/element": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.0.0.tgz", - "integrity": "sha512-u1DhVIdb6VEe8wzxKCrLfRWbeFLrlhYTFSOY6yrtl2z9vr9bCdlLp9aAppTxLNUs8cFcdoCEMpakVRYFyfZwTQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.23.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/escape-html": { - "version": "2.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/escape-html/-/escape-html-2.26.0.tgz", - "integrity": "sha512-uWumpNH4hnmeepTw9K3gC5LmoZECom5L1P6HuZXYXyld8eU5L9p/JdvAPOwLmjffHyJO3hiB2JqYd+nKElbtrw==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/eslint-plugin": { - "version": "13.7.0", - "resolved": "https://registry.npmjs.org/@wordpress/eslint-plugin/-/eslint-plugin-13.7.0.tgz", - "integrity": "sha512-4ETWJKWO6hwco+NboGqHb5E01CNUTsuMdCkG/ISiuusSaMT1G48YQ60Wx+Ocp/z9aFy5zz/XCK4S3EFYDiibYg==", - "dev": true, - "dependencies": { - "@babel/eslint-parser": "^7.16.0", - "@typescript-eslint/eslint-plugin": "^5.3.0", - "@typescript-eslint/parser": "^5.3.0", - "@wordpress/babel-preset-default": "^7.7.0", - "@wordpress/prettier-config": "^2.6.0", - "cosmiconfig": "^7.0.0", - "eslint-config-prettier": "^8.3.0", - "eslint-plugin-import": "^2.25.2", - "eslint-plugin-jest": "^25.2.3", - "eslint-plugin-jsdoc": "^37.0.3", - "eslint-plugin-jsx-a11y": "^6.5.1", - "eslint-plugin-prettier": "^3.3.0", - "eslint-plugin-react": "^7.27.0", - "eslint-plugin-react-hooks": "^4.3.0", - "globals": "^13.12.0", - "requireindex": "^1.2.0" - }, - "engines": { - "node": ">=14", - "npm": ">=6.14.4" - }, - "peerDependencies": { - "@babel/core": ">=7", - "eslint": ">=8", - "prettier": ">=2", - "typescript": ">=4" - }, - "peerDependenciesMeta": { - "prettier": { - "optional": true - }, - "typescript": { - "optional": true - } - } - }, - "node_modules/@wordpress/eslint-plugin/node_modules/globals": { - "version": "13.19.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-13.19.0.tgz", - "integrity": "sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ==", - "dev": true, - "dependencies": { - "type-fest": "^0.20.2" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/@wordpress/eslint-plugin/node_modules/type-fest": { - "version": "0.20.2", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", - "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/@wordpress/experiments": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/@wordpress/experiments/-/experiments-0.8.0.tgz", - "integrity": "sha512-3IPbENoxHWjIe/fVSsbB6jh5kC94pqwe3sZsX+iLVV/ritGr0XVoML0pZLrM+8m+U4roTyGiD23Xq6mmBK7ykg==", - "deprecated": "Package no longer supported. Contact Support at https://www.npmjs.com/support for more info.", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/hooks": { - "version": "3.34.0", - "resolved": "https://registry.npmjs.org/@wordpress/hooks/-/hooks-3.34.0.tgz", - "integrity": "sha512-qVBtsA8bjACRTL5tkeGkg9jb5O66JmLJY3zSFnQ4v97CTXdtNAFXSCVEIbwDsZSsXOu/ybX06teKsvS9v3tnXg==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/html-entities": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/html-entities/-/html-entities-3.25.0.tgz", - "integrity": "sha512-A48mGvD2bx69rOee0q+aAXofWK0t27IK5ngcwBi3RY1GYI38K6WW+BykWXTt13I1p+3sJPd8mUYizg6pT+GrFg==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/i18n": { - "version": "4.23.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.23.0.tgz", - "integrity": "sha512-SF9aJ2gajHtYDLMA9nhnMPerLmKJofUM4qQypwrW5AYwi5JS7jxvZHNETIqqYq5UdhRwsubPjAUfFosIonmfnA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.23.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/icons": { - "version": "9.16.0", - "resolved": "https://registry.npmjs.org/@wordpress/icons/-/icons-9.16.0.tgz", - "integrity": "sha512-t6BPT5FXlh1VsTvO+I4X1UBZYgtwPVnZWOWyKJSGFas2MgdHh++LJ6avPQoPdGNsaixpfXsVvSZ5Snqhb7pfXQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/element": "^5.2.0", - "@wordpress/primitives": "^3.23.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/icons/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/interface": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/interface/-/interface-5.2.0.tgz", - "integrity": "sha512-OkQdTDYSLOhO8g4a0bcTcDyYqjOFfpfHyBs3ZHLyuIID3kc3LN8n6FDBOqd6soStJVB6dQlL5Cm6VwYcLWTjNw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/a11y": "^3.25.0", - "@wordpress/components": "^23.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/plugins": "^5.2.0", - "@wordpress/preferences": "^3.2.0", - "@wordpress/viewport": "^5.2.0", - "classnames": "^2.3.1" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/interface/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/interface/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/interface/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/is-shallow-equal": { - "version": "4.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.26.0.tgz", - "integrity": "sha512-NuCcnQs+UbMi8ZHLYHDeH+pC56CFrDfc1oD7y4J02RMcBZ+zwP1zg8XWDFC37r+KJM4Xy7lHThZq0nCIAKpjiw==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/jest-console": { - "version": "6.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/jest-console/-/jest-console-6.6.0.tgz", - "integrity": "sha512-9AIiRC2VkkGBChXIT9sfMEgByOi0EIr7t/oOUyB3pYSps/iLH3lYScrUIWZthXxUk8afi5re8ZxgrL0ENPk5wQ==", - "dev": true, - "dependencies": { - "@babel/runtime": "^7.16.0", - "jest-matcher-utils": "^27.4.2" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "jest": ">=27" - } - }, - "node_modules/@wordpress/jest-preset-default": { - "version": "10.4.0", - "resolved": "https://registry.npmjs.org/@wordpress/jest-preset-default/-/jest-preset-default-10.4.0.tgz", - "integrity": "sha512-1CFYsqXTg/JWZ0yjMoeVZ9CRMsNMap8CsJOfoI7e/XwSzNwWbs0bqgkJxWLTLMDMHqssI1D+e/w6L8/156mK9w==", - "dev": true, - "dependencies": { - "@wordpress/jest-console": "^6.6.0", - "babel-jest": "^27.4.5" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "@babel/core": ">=7", - "jest": ">=27" - } - }, - "node_modules/@wordpress/keyboard-shortcuts": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/keyboard-shortcuts/-/keyboard-shortcuts-4.2.0.tgz", - "integrity": "sha512-lX6Yw7BmEvGXdA5vLHBqUMeADoc/e2GiAqw4JJQj12R0+wDJ53Ljry1JSmALevcr3hc0C9ZFwsHn5xtP29nM8w==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/data": "^8.2.0", - "@wordpress/element": "^5.2.0", - "@wordpress/keycodes": "^3.25.0", - "rememo": "^4.0.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/keyboard-shortcuts/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/keycodes": { - "version": "3.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/keycodes/-/keycodes-3.26.0.tgz", - "integrity": "sha512-W0ljzR6dl6ugp94xN+QlzKe4l3WrzWW6TeiQN/1XAVUmQTsBhNTsudK0u8sDXwXvT79HLuSg2zIJsHwI2z1r/w==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.26.0", - "change-case": "^4.1.2", - "lodash": "^4.17.21" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/keycodes/node_modules/@wordpress/i18n": { - "version": "4.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.26.0.tgz", - "integrity": "sha512-W94aIByO+3YraI7fJbk+3STnz3e0hhrtBPPjKK1XvT4+3RZiKPaVN2Y8mvCCknbaAILCT+CixUBJOgq6m6bwjQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.26.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/media-utils": { - "version": "4.16.0", - "resolved": "https://registry.npmjs.org/@wordpress/media-utils/-/media-utils-4.16.0.tgz", - "integrity": "sha512-Sb4UhV5F8dadS80VgcFTXq8ytUT1e7BaCJq965KYVHWtHr1uN6buE/e9uLp2W4zyw6JKatiG/ar0xml/E+SERw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/blob": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/i18n": "^4.25.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/media-utils/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/media-utils/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/media-utils/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/notices": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/notices/-/notices-3.25.0.tgz", - "integrity": "sha512-4VTtCJan83vQj78feMPJuhD1vHkotFMpwRpIwZE4bIgDBJS2faq8eiSMP89iPlbDwh3fa0qLQh34STFQSgvZOg==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/a11y": "^3.25.0", - "@wordpress/data": "^8.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/npm-package-json-lint-config": { - "version": "4.8.0", - "resolved": "https://registry.npmjs.org/@wordpress/npm-package-json-lint-config/-/npm-package-json-lint-config-4.8.0.tgz", - "integrity": "sha512-g6Nx3UL/YEhW0jEAi3PdHJJAtWCvBO0MKtOjvFamC4NyJ7LHEe1QzhxlTToVhbs/AxST3jga0z+atPFAg6UtFg==", - "dev": true, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "npm-package-json-lint": ">=3.6.0" - } - }, - "node_modules/@wordpress/plugins": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/plugins/-/plugins-5.2.0.tgz", - "integrity": "sha512-sxtMVlWDLl326rY5nZJviKTx8ZKoqJ7n/SZkPrGeDEHaYTrwY/wyoJ7LY9vJj9rcbqYVpUzltHBfJah71GN4sA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/element": "^5.2.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/icons": "^9.16.0", - "memize": "^1.1.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/plugins/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/postcss-plugins-preset": { - "version": "4.7.0", - "resolved": "https://registry.npmjs.org/@wordpress/postcss-plugins-preset/-/postcss-plugins-preset-4.7.0.tgz", - "integrity": "sha512-ox1VfLUrIZCY2qcjqz8CiFJ6U11sY+QUdReby5ap6gNGzOD559v+mI1jSCE1sVckz4+OZJoXCfE5xxtqvq/YVA==", - "dev": true, - "dependencies": { - "@wordpress/base-styles": "^4.14.0", - "autoprefixer": "^10.2.5" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "postcss": "^8.0.0" - } - }, - "node_modules/@wordpress/preferences": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/preferences/-/preferences-3.2.0.tgz", - "integrity": "sha512-Tr2zFfBIK+xGv8BCNUlandYGbuaKGFDBgiz4ZI1JUjla3unmNTOVXSSfdAwXtpcLTuaf1wuhwM+sc4Igd0QTig==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/a11y": "^3.25.0", - "@wordpress/components": "^23.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "classnames": "^2.3.1" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/preferences/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/preferences/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/preferences/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/prettier-config": { - "version": "2.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/prettier-config/-/prettier-config-2.6.0.tgz", - "integrity": "sha512-yvs/GhA1HTpgh1gA7sp0yDxRgvXYDvyTgFSIgCBkYYKyNnynED/D140BJjS4s4LGqdCFfEmcib/DHxL5HTWJ4g==", - "dev": true, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "prettier": ">=2" - } - }, - "node_modules/@wordpress/primitives": { - "version": "3.23.0", - "resolved": "https://registry.npmjs.org/@wordpress/primitives/-/primitives-3.23.0.tgz", - "integrity": "sha512-HeE1aVrQF8fT4qrVKFzGAjEMua9OBYXvhPa+3WQlGXfz0gRAgf17X+PABFeJRbwypZ+SVNA/21Bkf+/BL/V/0w==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/element": "^5.2.0", - "classnames": "^2.3.1" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/primitives/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/priority-queue": { - "version": "2.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/priority-queue/-/priority-queue-2.26.0.tgz", - "integrity": "sha512-05/HC5hya6qKKxiydA7F/Gac97J5GzRCYU7tvCMtFKR0mY6ZQzxagq5i4az5W3mGTuB2X6PTXR5HhQ1c4fxnTQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "requestidlecallback": "^0.3.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/redux-routine": { - "version": "4.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/redux-routine/-/redux-routine-4.26.0.tgz", - "integrity": "sha512-CzkyU8+SD7ZrMcQGYyfVfuAJzK69td6YMx9yOYrHh/Ow2mImls2FdcNmQNGMBEAc8qXd9Ub+FyUMAui8IbFI4g==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "is-plain-object": "^5.0.0", - "is-promise": "^4.0.0", - "rungen": "^0.3.2" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "redux": ">=4" - } - }, - "node_modules/@wordpress/reusable-blocks": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/reusable-blocks/-/reusable-blocks-4.2.0.tgz", - "integrity": "sha512-rzXXyx2P3pN1PhCIlDPAhrtnIQbkE1NlESr+B8OgUsmmGVWO1qkohtedg7Bzmeu5filAx3dy/KmQCFr3ORCYMQ==", - "dependencies": { - "@wordpress/block-editor": "^11.2.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/components": "^23.2.0", - "@wordpress/core-data": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/element": "^5.2.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/notices": "^3.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/reusable-blocks/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/reusable-blocks/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/reusable-blocks/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/rich-text": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/rich-text/-/rich-text-6.2.0.tgz", - "integrity": "sha512-5WQuLMYPdUOvx87es15AqV79CRpMDwgz5NmtDB6l90ZhEIMSit5qA/4dClTXALS4uKzOYPj6Cy2l0ewJES41Tw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "memize": "^1.1.0", - "rememo": "^4.0.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/rich-text/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/rich-text/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/scripts": { - "version": "25.0.0", - "resolved": "https://registry.npmjs.org/@wordpress/scripts/-/scripts-25.0.0.tgz", - "integrity": "sha512-wNrFlE2umzjxEeBWn3Q4soIDYN3daK+BWrT3ngwlXDgBIT7hbT5vLNpx4Tfrb89SY9R7b7JE/IJ+A0WRw8gXBw==", - "dev": true, - "dependencies": { - "@babel/core": "^7.16.0", - "@pmmmwh/react-refresh-webpack-plugin": "^0.5.2", - "@svgr/webpack": "^6.2.1", - "@wordpress/babel-preset-default": "^7.7.0", - "@wordpress/browserslist-config": "^5.6.0", - "@wordpress/dependency-extraction-webpack-plugin": "^4.6.0", - "@wordpress/eslint-plugin": "^13.7.0", - "@wordpress/jest-preset-default": "^10.4.0", - "@wordpress/npm-package-json-lint-config": "^4.8.0", - "@wordpress/postcss-plugins-preset": "^4.7.0", - "@wordpress/prettier-config": "^2.6.0", - "@wordpress/stylelint-config": "^21.6.0", - "adm-zip": "^0.5.9", - "babel-jest": "^27.4.5", - "babel-loader": "^8.2.3", - "browserslist": "^4.17.6", - "chalk": "^4.0.0", - "check-node-version": "^4.1.0", - "clean-webpack-plugin": "^3.0.0", - "copy-webpack-plugin": "^10.2.0", - "cross-spawn": "^5.1.0", - "css-loader": "^6.2.0", - "cssnano": "^5.0.7", - "cwd": "^0.10.0", - "dir-glob": "^3.0.1", - "eslint": "^8.3.0", - "expect-puppeteer": "^4.4.0", - "fast-glob": "^3.2.7", - "filenamify": "^4.2.0", - "jest": "^27.4.5", - "jest-dev-server": "^6.0.2", - "jest-environment-node": "^27.4.4", - "markdownlint-cli": "^0.31.1", - "merge-deep": "^3.0.3", - "mini-css-extract-plugin": "^2.5.1", - "minimist": "^1.2.0", - "npm-package-json-lint": "^5.0.0", - "npm-packlist": "^3.0.0", - "postcss": "^8.4.5", - "postcss-loader": "^6.2.1", - "prettier": "npm:wp-prettier@2.6.2", - "puppeteer-core": "^13.2.0", - "react-refresh": "^0.10.0", - "read-pkg-up": "^7.0.1", - "resolve-bin": "^0.4.0", - "sass": "^1.35.2", - "sass-loader": "^12.1.0", - "source-map-loader": "^3.0.0", - "stylelint": "^14.2.0", - "terser-webpack-plugin": "^5.1.4", - "url-loader": "^4.1.1", - "webpack": "^5.47.1", - "webpack-bundle-analyzer": "^4.4.2", - "webpack-cli": "^4.9.1", - "webpack-dev-server": "^4.4.0" - }, - "bin": { - "wp-scripts": "bin/wp-scripts.js" - }, - "engines": { - "node": ">=14", - "npm": ">=6.14.4" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/scripts/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/@wordpress/scripts/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/@wordpress/scripts/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/@wordpress/scripts/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/@wordpress/scripts/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/@wordpress/scripts/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/@wordpress/server-side-render": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/server-side-render/-/server-side-render-4.2.0.tgz", - "integrity": "sha512-LGNRtyBz6DI6frxo2V9Ro9U3elQ/+inJ8f8liTqnAERgViZz1sLCIWGE5jhif9pjz6c8qIo4KwSc4pFu+rEaeQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/components": "^23.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0", - "fast-deep-equal": "^3.1.3" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/server-side-render/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/server-side-render/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/server-side-render/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/server-side-render/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/shortcode": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/shortcode/-/shortcode-3.25.0.tgz", - "integrity": "sha512-hHMwEgtylk8x1htG2GgwhQIuTOmZnKQHBnjwzua3Tr0x1nfOpG0FitT7EFoXArj13DbfcMy3+iwW8q8FJKRUxA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "memize": "^1.1.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/style-engine": { - "version": "1.8.0", - "resolved": "https://registry.npmjs.org/@wordpress/style-engine/-/style-engine-1.8.0.tgz", - "integrity": "sha512-TcA4vNQlrewKoZUvuIYUAAQEetfZYT4ddkNzMs6ODORTX/pkZUiC2UH5yt+mfVQUlYchoQBmJ7FdMZsT0Bz52A==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "lodash": "^4.17.21" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/stylelint-config": { - "version": "21.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/stylelint-config/-/stylelint-config-21.6.0.tgz", - "integrity": "sha512-IbukumKSfAsY3PgAT0hkTrij2TfJBckbeVWXSarVfgTXXJrV3Ew87gQ1lqovOauvE63jv4g49P7nZLJqmwh7OQ==", - "dev": true, - "dependencies": { - "stylelint-config-recommended": "^6.0.0", - "stylelint-config-recommended-scss": "^5.0.2" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "stylelint": "^14.2" - } - }, - "node_modules/@wordpress/token-list": { - "version": "2.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/token-list/-/token-list-2.25.0.tgz", - "integrity": "sha512-cS/1QAYTXgBT3I6VzLXRGe7vBesaSttzKGz+krxoKMc3A8cm5/jAA+5q++0ysZLChkze5BnHvp4AAeOn8oGahg==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/url": { - "version": "3.35.0", - "resolved": "https://registry.npmjs.org/@wordpress/url/-/url-3.35.0.tgz", - "integrity": "sha512-lJoGQhKRcuLD07yMKqoYPbQQjZzo4791DXdq3icA1Fx9yjvCJYsFu78sbiNCCKEJIY4mfrDbL/k6lP0EpDCX6Q==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "remove-accents": "^0.4.2" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/viewport": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/viewport/-/viewport-5.2.0.tgz", - "integrity": "sha512-ZIZ6oLm4V7IfLnPEwYAmynbJjcEr6lrZuXU2l3HWrtNUIB8V+jTsyxS7/4hdiS6gP7kkGorIUaRN7Pn11tvuig==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/data": "^8.2.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0" - } - }, - "node_modules/@wordpress/warning": { - "version": "2.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/warning/-/warning-2.25.0.tgz", - "integrity": "sha512-w8+zalxDN2SLBa/SbkMgSvNJpRF9wXYps85+310Dm+s9dPkjPz6T4ZIKFdjEpRCvw8MhUhEylzR3FZa/CnhoHw==", - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/widgets": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/widgets/-/widgets-3.2.0.tgz", - "integrity": "sha512-BN+xR4fL3BPyukr5o6SJhPakfJRS9ur3SSlOJBXmx9sLdMw53R1EQAw8K94eD7DawQ5ic+22S6sLQ1zbzU27ag==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/api-fetch": "^6.22.0", - "@wordpress/block-editor": "^11.2.0", - "@wordpress/blocks": "^12.2.0", - "@wordpress/components": "^23.2.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/core-data": "^6.2.0", - "@wordpress/data": "^8.2.0", - "@wordpress/element": "^5.2.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/notices": "^3.25.0", - "classnames": "^2.3.1" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/widgets/node_modules/@wordpress/api-fetch": { - "version": "6.22.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.22.0.tgz", - "integrity": "sha512-IO7Shv1Qz93bo/Rq20beAV+p1qSOCs4uUi98rzhhih7U0SF88Jo69mlNmQbpALWcG040a2DRQR8E18Mj7JwViQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/url": "^3.26.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/widgets/node_modules/@wordpress/components": { - "version": "23.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/components/-/components-23.2.0.tgz", - "integrity": "sha512-zyYQLedemzTPBWDsIRyfeSfeiGIXEAgetsjXL0KuNKStGPY+w9bnBfyRQh+zYU3/TMssm2imqN+yOhUte1DBVQ==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@emotion/cache": "^11.7.1", - "@emotion/css": "^11.7.1", - "@emotion/react": "^11.7.1", - "@emotion/serialize": "^1.0.2", - "@emotion/styled": "^11.6.0", - "@emotion/utils": "^1.0.0", - "@floating-ui/react-dom": "^1.0.0", - "@use-gesture/react": "^10.2.6", - "@wordpress/a11y": "^3.25.0", - "@wordpress/compose": "^6.2.0", - "@wordpress/date": "^4.25.0", - "@wordpress/deprecated": "^3.25.0", - "@wordpress/dom": "^3.25.0", - "@wordpress/element": "^5.2.0", - "@wordpress/escape-html": "^2.25.0", - "@wordpress/hooks": "^3.25.0", - "@wordpress/i18n": "^4.25.0", - "@wordpress/icons": "^9.16.0", - "@wordpress/is-shallow-equal": "^4.25.0", - "@wordpress/keycodes": "^3.25.0", - "@wordpress/primitives": "^3.23.0", - "@wordpress/rich-text": "^6.2.0", - "@wordpress/warning": "^2.25.0", - "change-case": "^4.1.2", - "classnames": "^2.3.1", - "colord": "^2.7.0", - "date-fns": "^2.28.0", - "dom-scroll-into-view": "^1.2.1", - "downshift": "^6.0.15", - "fast-deep-equal": "^3.1.3", - "framer-motion": "^7.6.1", - "gradient-parser": "^0.1.5", - "highlight-words-core": "^1.2.2", - "lodash": "^4.17.21", - "memize": "^1.1.0", - "re-resizable": "^6.4.0", - "react-colorful": "^5.3.1", - "reakit": "^1.3.8", - "remove-accents": "^0.4.2", - "use-lilius": "^2.0.1", - "uuid": "^8.3.0", - "valtio": "^1.7.0" - }, - "engines": { - "node": ">=12" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/@wordpress/widgets/node_modules/@wordpress/element": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.2.0.tgz", - "integrity": "sha512-0hhFhzcQChSIT5pcOCSGVSK4DEi3xBtuu3uRj3HrYefcthmRdZnAeLGUGaebO5HgcxnImJ/Y0u4r948XFjj9SA==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@types/react": "^18.0.21", - "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.25.0", - "change-case": "^4.1.2", - "is-plain-object": "^5.0.0", - "react": "^18.2.0", - "react-dom": "^18.2.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/widgets/node_modules/@wordpress/i18n": { - "version": "4.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.25.0.tgz", - "integrity": "sha512-cKU5Ox1DKa3WShRu+QrCU+QzNvyoQhrNtS6kcvw17DfMBjPe7AsYjd7ZBb7Io327jP97Oqh5BtaYdUq/4S1cIw==", - "dependencies": { - "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.25.0", - "gettext-parser": "^1.3.1", - "memize": "^1.1.0", - "sprintf-js": "^1.1.1", - "tannin": "^1.2.0" - }, - "bin": { - "pot-to-php": "tools/pot-to-php.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@wordpress/wordcount": { - "version": "3.25.0", - "resolved": "https://registry.npmjs.org/@wordpress/wordcount/-/wordcount-3.25.0.tgz", - "integrity": "sha512-4q46JkcijwcA5pRW/MRaMEQQn9IMR7szltjFfJwkqKg6QFG5SunFLgklnmKY6ZDXq8KW10/av6JVerBVF6bKDA==", - "dependencies": { - "@babel/runtime": "^7.16.0" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/@xtuc/ieee754": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", - "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==", - "dev": true - }, - "node_modules/@xtuc/long": { - "version": "4.2.2", - "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", - "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", - "dev": true - }, - "node_modules/abab": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.6.tgz", - "integrity": "sha512-j2afSsaIENvHZN2B8GOpF566vZ5WVk5opAiMTvWgaQT8DkbOqsTfvNAvHoRGU2zzP8cPoqys+xHTRDWW8L+/BA==", - "dev": true - }, - "node_modules/abbrev": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", - "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==" - }, - "node_modules/accepts": { - "version": "1.3.8", - "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", - "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", - "dev": true, - "dependencies": { - "mime-types": "~2.1.34", - "negotiator": "0.6.3" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/acorn": { - "version": "8.8.1", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.8.1.tgz", - "integrity": "sha512-7zFpHzhnqYKrkYdUjF1HI1bzd0VygEGX8lFk4k5zVMqHEoES+P+7TKI+EvLO9WVMJ8eekdO0aDEK044xTXwPPA==", - "dev": true, - "bin": { - "acorn": "bin/acorn" - }, - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/acorn-globals": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz", - "integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==", - "dev": true, - "dependencies": { - "acorn": "^7.1.1", - "acorn-walk": "^7.1.1" - } - }, - "node_modules/acorn-globals/node_modules/acorn": { - "version": "7.4.1", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz", - "integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==", - "dev": true, - "bin": { - "acorn": "bin/acorn" - }, - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/acorn-import-assertions": { - "version": "1.8.0", - "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz", - "integrity": "sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==", - "dev": true, - "peerDependencies": { - "acorn": "^8" - } - }, - "node_modules/acorn-jsx": { - "version": "5.3.2", - "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", - "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", - "dev": true, - "peerDependencies": { - "acorn": "^6.0.0 || ^7.0.0 || ^8.0.0" - } - }, - "node_modules/acorn-walk": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz", - "integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==", - "dev": true, - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/adm-zip": { - "version": "0.5.9", - "resolved": "https://registry.npmjs.org/adm-zip/-/adm-zip-0.5.9.tgz", - "integrity": "sha512-s+3fXLkeeLjZ2kLjCBwQufpI5fuN+kIGBxu6530nVQZGVol0d7Y/M88/xw9HGGUcJjKf8LutN3VPRUBq6N7Ajg==", - "dev": true, - "engines": { - "node": ">=6.0" - } - }, - "node_modules/agent-base": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz", - "integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==", - "dev": true, - "dependencies": { - "debug": "4" - }, - "engines": { - "node": ">= 6.0.0" - } - }, - "node_modules/ajv": { - "version": "6.12.6", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.6.tgz", - "integrity": "sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/epoberezkin" - } - }, - "node_modules/ajv-errors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/ajv-errors/-/ajv-errors-1.0.1.tgz", - "integrity": "sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ==", - "dev": true, - "peerDependencies": { - "ajv": ">=5.0.0" - } - }, - "node_modules/ajv-formats": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz", - "integrity": "sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==", - "dev": true, - "dependencies": { - "ajv": "^8.0.0" - }, - "peerDependencies": { - "ajv": "^8.0.0" - }, - "peerDependenciesMeta": { - "ajv": { - "optional": true - } - } - }, - "node_modules/ajv-formats/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.1", - "json-schema-traverse": "^1.0.0", - "require-from-string": "^2.0.2", - "uri-js": "^4.2.2" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/epoberezkin" - } - }, - "node_modules/ajv-formats/node_modules/json-schema-traverse": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", - "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", - "dev": true - }, - "node_modules/ajv-keywords": { - "version": "3.5.2", - "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", - "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", - "dev": true, - "peerDependencies": { - "ajv": "^6.9.1" - } - }, - "node_modules/algoliasearch": { - "version": "4.17.0", - "resolved": "https://registry.npmjs.org/algoliasearch/-/algoliasearch-4.17.0.tgz", - "integrity": "sha512-JMRh2Mw6sEnVMiz6+APsi7lx9a2jiDFF+WUtANaUVCv6uSU9UOLdo5h9K3pdP6frRRybaM2fX8b1u0nqICS9aA==", - "dependencies": { - "@algolia/cache-browser-local-storage": "4.17.0", - "@algolia/cache-common": "4.17.0", - "@algolia/cache-in-memory": "4.17.0", - "@algolia/client-account": "4.17.0", - "@algolia/client-analytics": "4.17.0", - "@algolia/client-common": "4.17.0", - "@algolia/client-personalization": "4.17.0", - "@algolia/client-search": "4.17.0", - "@algolia/logger-common": "4.17.0", - "@algolia/logger-console": "4.17.0", - "@algolia/requester-browser-xhr": "4.17.0", - "@algolia/requester-common": "4.17.0", - "@algolia/requester-node-http": "4.17.0", - "@algolia/transporter": "4.17.0" - } - }, - "node_modules/algoliasearch-helper": { - "version": "3.12.0", - "resolved": "https://registry.npmjs.org/algoliasearch-helper/-/algoliasearch-helper-3.12.0.tgz", - "integrity": "sha512-/j1U3PEwdan0n6P/QqSnSpNSLC5+cEMvyljd5CnmNmUjDlGrys+vFEOwjVEnqELIiAGMHEA/Nl3CiKVFBUYqyQ==", - "dependencies": { - "@algolia/events": "^4.0.1" - }, - "peerDependencies": { - "algoliasearch": ">= 3.1 < 6" - } - }, - "node_modules/ansi-escapes": { - "version": "4.3.2", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", - "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", - "dev": true, - "dependencies": { - "type-fest": "^0.21.3" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/ansi-html-community": { - "version": "0.0.8", - "resolved": "https://registry.npmjs.org/ansi-html-community/-/ansi-html-community-0.0.8.tgz", - "integrity": "sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==", - "dev": true, - "engines": [ - "node >= 0.8.0" - ], - "bin": { - "ansi-html": "bin/ansi-html" - } - }, - "node_modules/ansi-regex": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", - "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/ansi-styles": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", - "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", - "dependencies": { - "color-convert": "^1.9.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/anymatch": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", - "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", - "dev": true, - "dependencies": { - "normalize-path": "^3.0.0", - "picomatch": "^2.0.4" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/argparse": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", - "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", - "dev": true, - "dependencies": { - "sprintf-js": "~1.0.2" - } - }, - "node_modules/argparse/node_modules/sprintf-js": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", - "integrity": "sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==", - "dev": true - }, - "node_modules/aria-query": { - "version": "4.2.2", - "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-4.2.2.tgz", - "integrity": "sha512-o/HelwhuKpTj/frsOsbNLNgnNGVIFsVP/SW2BSF14gVl7kAfMOJ6/8wUAUvG1R1NHKrfG+2sHZTu0yauT1qBrA==", - "dev": true, - "dependencies": { - "@babel/runtime": "^7.10.2", - "@babel/runtime-corejs3": "^7.10.2" - }, - "engines": { - "node": ">=6.0" - } - }, - "node_modules/arr-union": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", - "integrity": "sha512-sKpyeERZ02v1FeCZT8lrfJq5u6goHCtpTAzPwJYe7c8SPFOboNjNg1vz2L4VTn9T4PQxEx13TbXLmYUcS6Ug7Q==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/array-flatten": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.2.tgz", - "integrity": "sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==", - "dev": true - }, - "node_modules/array-includes": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.6.tgz", - "integrity": "sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "get-intrinsic": "^1.1.3", - "is-string": "^1.0.7" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/array-union": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/array-union/-/array-union-2.1.0.tgz", - "integrity": "sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/array-uniq": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", - "integrity": "sha512-MNha4BWQ6JbwhFhj03YK552f7cb3AzoE8SzeljgChvL1dl3IcvggXVz1DilzySZkCja+CXuZbdW7yATchWn8/Q==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/array.prototype.flat": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.3.1.tgz", - "integrity": "sha512-roTU0KWIOmJ4DRLmwKd19Otg0/mT3qPNt0Qb3GWW8iObuZXxrjB/pzn0R3hqpRSWg4HCwqx+0vwOnWnvlOyeIA==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "es-shim-unscopables": "^1.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/array.prototype.flatmap": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/array.prototype.flatmap/-/array.prototype.flatmap-1.3.1.tgz", - "integrity": "sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "es-shim-unscopables": "^1.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/array.prototype.tosorted": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/array.prototype.tosorted/-/array.prototype.tosorted-1.1.1.tgz", - "integrity": "sha512-pZYPXPRl2PqWcsUs6LOMn+1f1532nEoPTYowBtqLwAW+W8vSVhkIGnmOX1t/UQjD6YGI0vcD2B1U7ZFGQH9jnQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "es-shim-unscopables": "^1.0.0", - "get-intrinsic": "^1.1.3" - } - }, - "node_modules/arrify": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", - "integrity": "sha512-3CYzex9M9FGQjCGMGyi6/31c8GJbgb0qGyrx5HWxPd0aCwh4cB2YjMb2Xf9UuoogrMrlO9cTqnB5rI5GHZTcUA==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/ast-types-flow": { - "version": "0.0.7", - "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.7.tgz", - "integrity": "sha512-eBvWn1lvIApYMhzQMsu9ciLfkBY499mFZlNqG+/9WR7PVlroQw0vG30cOQQbaKz3sCEc44TAOu2ykzqXSNnwag==", - "dev": true - }, - "node_modules/astral-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-2.0.0.tgz", - "integrity": "sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/asynckit": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", - "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", - "dev": true - }, - "node_modules/autoprefixer": { - "version": "10.4.13", - "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-10.4.13.tgz", - "integrity": "sha512-49vKpMqcZYsJjwotvt4+h/BCjJVnhGwcLpDt5xkcaOG3eLrG/HUYLagrihYsQ+qrIBgIzX1Rw7a6L8I/ZA1Atg==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/autoprefixer" - } - ], - "dependencies": { - "browserslist": "^4.21.4", - "caniuse-lite": "^1.0.30001426", - "fraction.js": "^4.2.0", - "normalize-range": "^0.1.2", - "picocolors": "^1.0.0", - "postcss-value-parser": "^4.2.0" - }, - "bin": { - "autoprefixer": "bin/autoprefixer" - }, - "engines": { - "node": "^10 || ^12 || >=14" - }, - "peerDependencies": { - "postcss": "^8.1.0" - } - }, - "node_modules/autosize": { - "version": "4.0.4", - "resolved": "https://registry.npmjs.org/autosize/-/autosize-4.0.4.tgz", - "integrity": "sha512-5yxLQ22O0fCRGoxGfeLSNt3J8LB1v+umtpMnPW6XjkTWXKoN0AmXAIhelJcDtFT/Y/wYWmfE+oqU10Q0b8FhaQ==" - }, - "node_modules/axe-core": { - "version": "4.6.1", - "resolved": "https://registry.npmjs.org/axe-core/-/axe-core-4.6.1.tgz", - "integrity": "sha512-lCZN5XRuOnpG4bpMq8v0khrWtUOn+i8lZSb6wHZH56ZfbIEv6XwJV84AAueh9/zi7qPVJ/E4yz6fmsiyOmXR4w==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/axios": { - "version": "0.25.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-0.25.0.tgz", - "integrity": "sha512-cD8FOb0tRH3uuEe6+evtAbgJtfxr7ly3fQjYcMcuPlgkwVS9xboaVIpcDV+cYQe+yGykgwZCs1pzjntcGa6l5g==", - "dev": true, - "dependencies": { - "follow-redirects": "^1.14.7" - } - }, - "node_modules/axobject-query": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-2.2.0.tgz", - "integrity": "sha512-Td525n+iPOOyUQIeBfcASuG6uJsDOITl7Mds5gFyerkWiX7qhUTdYUBlSgNMyVqtSJqwpt1kXGLdUt6SykLMRA==", - "dev": true - }, - "node_modules/babel-jest": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-27.5.1.tgz", - "integrity": "sha512-cdQ5dXjGRd0IBRATiQ4mZGlGlRE8kJpjPOixdNRdT+m3UcNqmYWN6rK6nvtXYfY3D76cb8s/O1Ss8ea24PIwcg==", - "dev": true, - "dependencies": { - "@jest/transform": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/babel__core": "^7.1.14", - "babel-plugin-istanbul": "^6.1.1", - "babel-preset-jest": "^27.5.1", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "slash": "^3.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "peerDependencies": { - "@babel/core": "^7.8.0" - } - }, - "node_modules/babel-jest/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/babel-jest/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/babel-jest/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/babel-jest/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/babel-jest/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/babel-jest/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/babel-loader": { - "version": "8.3.0", - "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-8.3.0.tgz", - "integrity": "sha512-H8SvsMF+m9t15HNLMipppzkC+Y2Yq+v3SonZyU70RBL/h1gxPkH08Ot8pEE9Z4Kd+czyWJClmFS8qzIP9OZ04Q==", - "dev": true, - "dependencies": { - "find-cache-dir": "^3.3.1", - "loader-utils": "^2.0.0", - "make-dir": "^3.1.0", - "schema-utils": "^2.6.5" - }, - "engines": { - "node": ">= 8.9" - }, - "peerDependencies": { - "@babel/core": "^7.0.0", - "webpack": ">=2" - } - }, - "node_modules/babel-loader/node_modules/schema-utils": { - "version": "2.7.1", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-2.7.1.tgz", - "integrity": "sha512-SHiNtMOUGWBQJwzISiVYKu82GiV4QYGePp3odlY1tuKO7gPtphAT5R/py0fA6xtbgLL/RvtJZnU9b8s0F1q0Xg==", - "dev": true, - "dependencies": { - "@types/json-schema": "^7.0.5", - "ajv": "^6.12.4", - "ajv-keywords": "^3.5.2" - }, - "engines": { - "node": ">= 8.9.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - } - }, - "node_modules/babel-plugin-istanbul": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz", - "integrity": "sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==", - "dev": true, - "dependencies": { - "@babel/helper-plugin-utils": "^7.0.0", - "@istanbuljs/load-nyc-config": "^1.0.0", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-instrument": "^5.0.4", - "test-exclude": "^6.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/babel-plugin-jest-hoist": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.5.1.tgz", - "integrity": "sha512-50wCwD5EMNW4aRpOwtqzyZHIewTYNxLA4nhB+09d8BIssfNfzBRhkBIHiaPv1Si226TQSvp8gxAJm2iY2qs2hQ==", - "dev": true, - "dependencies": { - "@babel/template": "^7.3.3", - "@babel/types": "^7.3.3", - "@types/babel__core": "^7.0.0", - "@types/babel__traverse": "^7.0.6" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/babel-plugin-macros": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-3.1.0.tgz", - "integrity": "sha512-Cg7TFGpIr01vOQNODXOOaGz2NpCU5gl8x1qJFbb6hbZxR7XrcE2vtbAsTAbJ7/xwJtUuJEw8K8Zr/AE0LHlesg==", - "dependencies": { - "@babel/runtime": "^7.12.5", - "cosmiconfig": "^7.0.0", - "resolve": "^1.19.0" - }, - "engines": { - "node": ">=10", - "npm": ">=6" - } - }, - "node_modules/babel-plugin-polyfill-corejs2": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs2/-/babel-plugin-polyfill-corejs2-0.3.3.tgz", - "integrity": "sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q==", - "dev": true, - "dependencies": { - "@babel/compat-data": "^7.17.7", - "@babel/helper-define-polyfill-provider": "^0.3.3", - "semver": "^6.1.1" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/babel-plugin-polyfill-corejs3": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.6.0.tgz", - "integrity": "sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA==", - "dev": true, - "dependencies": { - "@babel/helper-define-polyfill-provider": "^0.3.3", - "core-js-compat": "^3.25.1" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/babel-plugin-polyfill-regenerator": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-regenerator/-/babel-plugin-polyfill-regenerator-0.4.1.tgz", - "integrity": "sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw==", - "dev": true, - "dependencies": { - "@babel/helper-define-polyfill-provider": "^0.3.3" - }, - "peerDependencies": { - "@babel/core": "^7.0.0-0" - } - }, - "node_modules/babel-preset-current-node-syntax": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz", - "integrity": "sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==", - "dev": true, - "dependencies": { - "@babel/plugin-syntax-async-generators": "^7.8.4", - "@babel/plugin-syntax-bigint": "^7.8.3", - "@babel/plugin-syntax-class-properties": "^7.8.3", - "@babel/plugin-syntax-import-meta": "^7.8.3", - "@babel/plugin-syntax-json-strings": "^7.8.3", - "@babel/plugin-syntax-logical-assignment-operators": "^7.8.3", - "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3", - "@babel/plugin-syntax-numeric-separator": "^7.8.3", - "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-syntax-optional-catch-binding": "^7.8.3", - "@babel/plugin-syntax-optional-chaining": "^7.8.3", - "@babel/plugin-syntax-top-level-await": "^7.8.3" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/babel-preset-jest": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-27.5.1.tgz", - "integrity": "sha512-Nptf2FzlPCWYuJg41HBqXVT8ym6bXOevuCTbhxlUpjwtysGaIWFvDEjp4y+G7fl13FgOdjs7P/DmErqH7da0Ag==", - "dev": true, - "dependencies": { - "babel-plugin-jest-hoist": "^27.5.1", - "babel-preset-current-node-syntax": "^1.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "peerDependencies": { - "@babel/core": "^7.0.0" - } - }, - "node_modules/balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==", - "dev": true - }, - "node_modules/base64-js": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.5.1.tgz", - "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/batch": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz", - "integrity": "sha512-x+VAiMRL6UPkx+kudNvxTl6hB2XNNCG2r+7wixVfIYwu/2HKRXimwQyaumLjMveWvT2Hkd/cAJw+QBMfJ/EKVw==", - "dev": true - }, - "node_modules/big.js": { - "version": "5.2.2", - "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", - "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", - "dev": true, - "engines": { - "node": "*" - } - }, - "node_modules/binary-extensions": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", - "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/bl": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/bl/-/bl-4.1.0.tgz", - "integrity": "sha512-1W07cM9gS6DcLperZfFSj+bWLtaPGSOHWhPiGzXmvVJbRLdG82sH/Kn8EtW1VqWVA54AKf2h5k5BbnIbwF3h6w==", - "dev": true, - "dependencies": { - "buffer": "^5.5.0", - "inherits": "^2.0.4", - "readable-stream": "^3.4.0" - } - }, - "node_modules/body-parser": { - "version": "1.20.1", - "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.1.tgz", - "integrity": "sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==", - "dev": true, - "dependencies": { - "bytes": "3.1.2", - "content-type": "~1.0.4", - "debug": "2.6.9", - "depd": "2.0.0", - "destroy": "1.2.0", - "http-errors": "2.0.0", - "iconv-lite": "0.4.24", - "on-finished": "2.4.1", - "qs": "6.11.0", - "raw-body": "2.5.1", - "type-is": "~1.6.18", - "unpipe": "1.0.0" - }, - "engines": { - "node": ">= 0.8", - "npm": "1.2.8000 || >= 1.4.16" - } - }, - "node_modules/body-parser/node_modules/bytes": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", - "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/body-parser/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/body-parser/node_modules/iconv-lite": { - "version": "0.4.24", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", - "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dev": true, - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/body-parser/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true - }, - "node_modules/body-scroll-lock": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/body-scroll-lock/-/body-scroll-lock-3.1.5.tgz", - "integrity": "sha512-Yi1Xaml0EvNA0OYWxXiYNqY24AfWkbA6w5vxE7GWxtKfzIbZM+Qw+aSmkgsbWzbHiy/RCSkUZBplVxTA+E4jJg==" - }, - "node_modules/bonjour-service": { - "version": "1.0.14", - "resolved": "https://registry.npmjs.org/bonjour-service/-/bonjour-service-1.0.14.tgz", - "integrity": "sha512-HIMbgLnk1Vqvs6B4Wq5ep7mxvj9sGz5d1JJyDNSGNIdA/w2MCz6GTjWTdjqOJV1bEPj+6IkxDvWNFKEBxNt4kQ==", - "dev": true, - "dependencies": { - "array-flatten": "^2.1.2", - "dns-equal": "^1.0.0", - "fast-deep-equal": "^3.1.3", - "multicast-dns": "^7.2.5" - } - }, - "node_modules/boolbase": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", - "integrity": "sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==", - "dev": true - }, - "node_modules/brace-expansion": { - "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", - "dev": true, - "dependencies": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "node_modules/braces": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", - "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", - "dev": true, - "dependencies": { - "fill-range": "^7.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/browser-process-hrtime": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz", - "integrity": "sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==", - "dev": true - }, - "node_modules/browserslist": { - "version": "4.21.4", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.4.tgz", - "integrity": "sha512-CBHJJdDmgjl3daYjN5Cp5kbTf1mUhZoS+beLklHIvkOWscs83YAhLlF3Wsh/lciQYAcbBJgTOD44VtG31ZM4Hw==", - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/browserslist" - } - ], - "dependencies": { - "caniuse-lite": "^1.0.30001400", - "electron-to-chromium": "^1.4.251", - "node-releases": "^2.0.6", - "update-browserslist-db": "^1.0.9" - }, - "bin": { - "browserslist": "cli.js" - }, - "engines": { - "node": "^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7" - } - }, - "node_modules/bser": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", - "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", - "dev": true, - "dependencies": { - "node-int64": "^0.4.0" - } - }, - "node_modules/buffer": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/buffer/-/buffer-5.7.1.tgz", - "integrity": "sha512-EHcyIPBQ4BSGlvjB16k5KgAJ27CIsHY/2JBmCRReo48y9rQ3MaUzWX3KVlBa4U7MyX02HdVj0K7C3WaB3ju7FQ==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "dependencies": { - "base64-js": "^1.3.1", - "ieee754": "^1.1.13" - } - }, - "node_modules/buffer-crc32": { - "version": "0.2.13", - "resolved": "https://registry.npmjs.org/buffer-crc32/-/buffer-crc32-0.2.13.tgz", - "integrity": "sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==", - "dev": true, - "engines": { - "node": "*" - } - }, - "node_modules/buffer-from": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.2.tgz", - "integrity": "sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==", - "dev": true - }, - "node_modules/bytes": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", - "integrity": "sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/call-bind": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.2.tgz", - "integrity": "sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==", - "dev": true, - "dependencies": { - "function-bind": "^1.1.1", - "get-intrinsic": "^1.0.2" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/callsites": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", - "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==", - "engines": { - "node": ">=6" - } - }, - "node_modules/camel-case": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-4.1.2.tgz", - "integrity": "sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw==", - "dependencies": { - "pascal-case": "^3.1.2", - "tslib": "^2.0.3" - } - }, - "node_modules/camelcase": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-6.3.0.tgz", - "integrity": "sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/camelcase-keys": { - "version": "6.2.2", - "resolved": "https://registry.npmjs.org/camelcase-keys/-/camelcase-keys-6.2.2.tgz", - "integrity": "sha512-YrwaA0vEKazPBkn0ipTiMpSajYDSe+KjQfrjhcBMxJt/znbvlHd8Pw/Vamaz5EB4Wfhs3SUR3Z9mwRu/P3s3Yg==", - "dev": true, - "dependencies": { - "camelcase": "^5.3.1", - "map-obj": "^4.0.0", - "quick-lru": "^4.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/camelcase-keys/node_modules/camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/caniuse-api": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz", - "integrity": "sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==", - "dev": true, - "dependencies": { - "browserslist": "^4.0.0", - "caniuse-lite": "^1.0.0", - "lodash.memoize": "^4.1.2", - "lodash.uniq": "^4.5.0" - } - }, - "node_modules/caniuse-lite": { - "version": "1.0.30001439", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001439.tgz", - "integrity": "sha512-1MgUzEkoMO6gKfXflStpYgZDlFM7M/ck/bgfVCACO5vnAf0fXoNVHdWtqGU+MYca+4bL9Z5bpOVmR33cWW9G2A==", - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/caniuse-lite" - } - ] - }, - "node_modules/capital-case": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/capital-case/-/capital-case-1.0.4.tgz", - "integrity": "sha512-ds37W8CytHgwnhGGTi88pcPyR15qoNkOpYwmMMfnWqqWgESapLqvDx6huFjQ5vqWSn2Z06173XNA7LtMOeUh1A==", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3", - "upper-case-first": "^2.0.2" - } - }, - "node_modules/chalk": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", - "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", - "dependencies": { - "ansi-styles": "^3.2.1", - "escape-string-regexp": "^1.0.5", - "supports-color": "^5.3.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/chalk/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/change-case": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/change-case/-/change-case-4.1.2.tgz", - "integrity": "sha512-bSxY2ws9OtviILG1EiY5K7NNxkqg/JnRnFxLtKQ96JaviiIxi7djMrSd0ECT9AC+lttClmYwKw53BWpOMblo7A==", - "dependencies": { - "camel-case": "^4.1.2", - "capital-case": "^1.0.4", - "constant-case": "^3.0.4", - "dot-case": "^3.0.4", - "header-case": "^2.0.4", - "no-case": "^3.0.4", - "param-case": "^3.0.4", - "pascal-case": "^3.1.2", - "path-case": "^3.0.4", - "sentence-case": "^3.0.4", - "snake-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/char-regex": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/char-regex/-/char-regex-1.0.2.tgz", - "integrity": "sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/check-node-version": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/check-node-version/-/check-node-version-4.2.1.tgz", - "integrity": "sha512-YYmFYHV/X7kSJhuN/QYHUu998n/TRuDe8UenM3+m5NrkiH670lb9ILqHIvBencvJc4SDh+XcbXMR4b+TtubJiw==", - "dev": true, - "dependencies": { - "chalk": "^3.0.0", - "map-values": "^1.0.1", - "minimist": "^1.2.0", - "object-filter": "^1.0.2", - "run-parallel": "^1.1.4", - "semver": "^6.3.0" - }, - "bin": { - "check-node-version": "bin.js" - }, - "engines": { - "node": ">=8.3.0" - } - }, - "node_modules/check-node-version/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/check-node-version/node_modules/chalk": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-3.0.0.tgz", - "integrity": "sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/check-node-version/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/check-node-version/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/check-node-version/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/check-node-version/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/chokidar": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", - "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], - "dependencies": { - "anymatch": "~3.1.2", - "braces": "~3.0.2", - "glob-parent": "~5.1.2", - "is-binary-path": "~2.1.0", - "is-glob": "~4.0.1", - "normalize-path": "~3.0.0", - "readdirp": "~3.6.0" - }, - "engines": { - "node": ">= 8.10.0" - }, - "optionalDependencies": { - "fsevents": "~2.3.2" - } - }, - "node_modules/chokidar/node_modules/glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, - "dependencies": { - "is-glob": "^4.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/chownr": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", - "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==", - "dev": true - }, - "node_modules/chrome-trace-event": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz", - "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==", - "dev": true, - "engines": { - "node": ">=6.0" - } - }, - "node_modules/ci-info": { - "version": "3.7.0", - "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-3.7.0.tgz", - "integrity": "sha512-2CpRNYmImPx+RXKLq6jko/L07phmS9I02TyqkcNU20GCF/GgaWvc58hPtjxDX8lPpkdwc9sNh72V9k00S7ezog==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/cjs-module-lexer": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz", - "integrity": "sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA==", - "dev": true - }, - "node_modules/classnames": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/classnames/-/classnames-2.3.2.tgz", - "integrity": "sha512-CSbhY4cFEJRe6/GQzIk5qXZ4Jeg5pcsP7b5peFSDpffpe1cqjASH/n9UTjBwOp6XpMSTwQ8Za2K5V02ueA7Tmw==" - }, - "node_modules/clean-webpack-plugin": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/clean-webpack-plugin/-/clean-webpack-plugin-3.0.0.tgz", - "integrity": "sha512-MciirUH5r+cYLGCOL5JX/ZLzOZbVr1ot3Fw+KcvbhUb6PM+yycqd9ZhIlcigQ5gl+XhppNmw3bEFuaaMNyLj3A==", - "dev": true, - "dependencies": { - "@types/webpack": "^4.4.31", - "del": "^4.1.1" - }, - "engines": { - "node": ">=8.9.0" - }, - "peerDependencies": { - "webpack": "*" - } - }, - "node_modules/clipboard": { - "version": "2.0.11", - "resolved": "https://registry.npmjs.org/clipboard/-/clipboard-2.0.11.tgz", - "integrity": "sha512-C+0bbOqkezLIsmWSvlsXS0Q0bmkugu7jcfMIACB+RDEntIzQIkdr148we28AfSloQLRdZlYL/QYyrq05j/3Faw==", - "dependencies": { - "good-listener": "^1.2.2", - "select": "^1.1.2", - "tiny-emitter": "^2.0.0" - } - }, - "node_modules/cliui": { - "version": "7.0.4", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-7.0.4.tgz", - "integrity": "sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ==", - "dev": true, - "dependencies": { - "string-width": "^4.2.0", - "strip-ansi": "^6.0.0", - "wrap-ansi": "^7.0.0" - } - }, - "node_modules/clone-deep": { - "version": "0.2.4", - "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-0.2.4.tgz", - "integrity": "sha512-we+NuQo2DHhSl+DP6jlUiAhyAjBQrYnpOk15rN6c6JSPScjiCLh8IbSU+VTcph6YS3o7mASE8a0+gbZ7ChLpgg==", - "dev": true, - "dependencies": { - "for-own": "^0.1.3", - "is-plain-object": "^2.0.1", - "kind-of": "^3.0.2", - "lazy-cache": "^1.0.3", - "shallow-clone": "^0.1.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/clone-deep/node_modules/is-plain-object": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", - "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", - "dev": true, - "dependencies": { - "isobject": "^3.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/co": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", - "integrity": "sha512-QVb0dM5HvG+uaxitm8wONl7jltx8dqhfU33DcqtOZcLSVIKSDDLDi7+0LbAKiyI8hD9u42m2YxXSkMGWThaecQ==", - "dev": true, - "engines": { - "iojs": ">= 1.0.0", - "node": ">= 0.12.0" - } - }, - "node_modules/collect-v8-coverage": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz", - "integrity": "sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg==", - "dev": true - }, - "node_modules/color-convert": { - "version": "1.9.3", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", - "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", - "dependencies": { - "color-name": "1.1.3" - } - }, - "node_modules/color-name": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", - "integrity": "sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==" - }, - "node_modules/colord": { - "version": "2.9.3", - "resolved": "https://registry.npmjs.org/colord/-/colord-2.9.3.tgz", - "integrity": "sha512-jeC1axXpnb0/2nn/Y1LPuLdgXBLH7aDcHu4KEKfqw3CUhX7ZpfBSlPKyqXE6btIgEzfWtrX3/tyBCaCvXvMkOw==" - }, - "node_modules/colorette": { - "version": "2.0.19", - "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.19.tgz", - "integrity": "sha512-3tlv/dIP7FWvj3BsbHrGLJ6l/oKh1O3TcgBqMn+yyCagOxc23fyzDS6HypQbgxWbkpDnf52p1LuR4eWDQ/K9WQ==", - "dev": true - }, - "node_modules/combined-stream": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", - "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", - "dev": true, - "dependencies": { - "delayed-stream": "~1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/commander": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-5.1.0.tgz", - "integrity": "sha512-P0CysNDQ7rtVw4QIQtm+MRxV66vKFSvlsQvGYXZWR3qFU0jlMKHZZZgw8e+8DSah4UDKMqnknRDQz+xuQXQ/Zg==", - "dev": true, - "engines": { - "node": ">= 6" - } - }, - "node_modules/comment-parser": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/comment-parser/-/comment-parser-1.3.0.tgz", - "integrity": "sha512-hRpmWIKgzd81vn0ydoWoyPoALEOnF4wt8yKD35Ib1D6XC2siLiYaiqfGkYrunuKdsXGwpBpHU3+9r+RVw2NZfA==", - "dev": true, - "engines": { - "node": ">= 12.0.0" - } - }, - "node_modules/common-path-prefix": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/common-path-prefix/-/common-path-prefix-3.0.0.tgz", - "integrity": "sha512-QE33hToZseCH3jS0qN96O/bSh3kaw/h+Tq7ngyY9eWDUnTlTNUyqfqvCXioLe5Na5jFsL78ra/wuBU4iuEgd4w==", - "dev": true - }, - "node_modules/commondir": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", - "integrity": "sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==", - "dev": true - }, - "node_modules/compressible": { - "version": "2.0.18", - "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", - "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", - "dev": true, - "dependencies": { - "mime-db": ">= 1.43.0 < 2" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/compression": { - "version": "1.7.4", - "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", - "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", - "dev": true, - "dependencies": { - "accepts": "~1.3.5", - "bytes": "3.0.0", - "compressible": "~2.0.16", - "debug": "2.6.9", - "on-headers": "~1.0.2", - "safe-buffer": "5.1.2", - "vary": "~1.1.2" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/compression/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/compression/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true - }, - "node_modules/compression/node_modules/safe-buffer": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", - "dev": true - }, - "node_modules/compute-scroll-into-view": { - "version": "1.0.20", - "resolved": "https://registry.npmjs.org/compute-scroll-into-view/-/compute-scroll-into-view-1.0.20.tgz", - "integrity": "sha512-UCB0ioiyj8CRjtrvaceBLqqhZCVP+1B8+NWQhmdsm0VXOJtobBCf1dBQmebCCo34qZmUwZfIH2MZLqNHazrfjg==" - }, - "node_modules/computed-style": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/computed-style/-/computed-style-0.1.4.tgz", - "integrity": "sha512-WpAmaKbMNmS3OProfHIdJiNleNJdgUrJfbKArXua28QF7+0CoZjlLn0lp6vlc+dl5r2/X9GQiQRQQU4BzSa69w==" - }, - "node_modules/concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==", - "dev": true - }, - "node_modules/connect-history-api-fallback": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-2.0.0.tgz", - "integrity": "sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA==", - "dev": true, - "engines": { - "node": ">=0.8" - } - }, - "node_modules/constant-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/constant-case/-/constant-case-3.0.4.tgz", - "integrity": "sha512-I2hSBi7Vvs7BEuJDr5dDHfzb/Ruj3FyvFyh7KLilAjNQw3Be+xgqUBA2W6scVEcL0hL1dwPRtIqEPVUCKkSsyQ==", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3", - "upper-case": "^2.0.2" - } - }, - "node_modules/content-disposition": { - "version": "0.5.4", - "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", - "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", - "dev": true, - "dependencies": { - "safe-buffer": "5.2.1" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/content-type": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", - "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/convert-source-map": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.9.0.tgz", - "integrity": "sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==" - }, - "node_modules/cookie": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", - "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/cookie-signature": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", - "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==", - "dev": true - }, - "node_modules/copy-webpack-plugin": { - "version": "10.2.4", - "resolved": "https://registry.npmjs.org/copy-webpack-plugin/-/copy-webpack-plugin-10.2.4.tgz", - "integrity": "sha512-xFVltahqlsRcyyJqQbDY6EYTtyQZF9rf+JPjwHObLdPFMEISqkFkr7mFoVOC6BfYS/dNThyoQKvziugm+OnwBg==", - "dev": true, - "dependencies": { - "fast-glob": "^3.2.7", - "glob-parent": "^6.0.1", - "globby": "^12.0.2", - "normalize-path": "^3.0.0", - "schema-utils": "^4.0.0", - "serialize-javascript": "^6.0.0" - }, - "engines": { - "node": ">= 12.20.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "^5.1.0" - } - }, - "node_modules/copy-webpack-plugin/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.1", - "json-schema-traverse": "^1.0.0", - "require-from-string": "^2.0.2", - "uri-js": "^4.2.2" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/epoberezkin" - } - }, - "node_modules/copy-webpack-plugin/node_modules/ajv-keywords": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz", - "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.3" - }, - "peerDependencies": { - "ajv": "^8.8.2" - } - }, - "node_modules/copy-webpack-plugin/node_modules/array-union": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/array-union/-/array-union-3.0.1.tgz", - "integrity": "sha512-1OvF9IbWwaeiM9VhzYXVQacMibxpXOMYVNIvMtKRyX9SImBXpKcFr8XvFDeEslCyuH/t6KRt7HEO94AlP8Iatw==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/copy-webpack-plugin/node_modules/globby": { - "version": "12.2.0", - "resolved": "https://registry.npmjs.org/globby/-/globby-12.2.0.tgz", - "integrity": "sha512-wiSuFQLZ+urS9x2gGPl1H5drc5twabmm4m2gTR27XDFyjUHJUNsS8o/2aKyIF6IoBaR630atdher0XJ5g6OMmA==", - "dev": true, - "dependencies": { - "array-union": "^3.0.1", - "dir-glob": "^3.0.1", - "fast-glob": "^3.2.7", - "ignore": "^5.1.9", - "merge2": "^1.4.1", - "slash": "^4.0.0" - }, - "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/copy-webpack-plugin/node_modules/json-schema-traverse": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", - "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", - "dev": true - }, - "node_modules/copy-webpack-plugin/node_modules/schema-utils": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz", - "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==", - "dev": true, - "dependencies": { - "@types/json-schema": "^7.0.9", - "ajv": "^8.8.0", - "ajv-formats": "^2.1.1", - "ajv-keywords": "^5.0.0" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - } - }, - "node_modules/copy-webpack-plugin/node_modules/slash": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-4.0.0.tgz", - "integrity": "sha512-3dOsAHXXUkQTpOYcoAxLIorMTp4gIQr5IW3iVb7A7lFIp0VHhnynm9izx6TssdrIcVIESAlVjtnO2K8bg+Coew==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/core-js": { - "version": "3.26.1", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.26.1.tgz", - "integrity": "sha512-21491RRQVzUn0GGM9Z1Jrpr6PNPxPi+Za8OM9q4tksTSnlbXXGKK1nXNg/QvwFYettXvSX6zWKCtHHfjN4puyA==", - "dev": true, - "hasInstallScript": true, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/core-js" - } - }, - "node_modules/core-js-compat": { - "version": "3.26.1", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.26.1.tgz", - "integrity": "sha512-622/KzTudvXCDLRw70iHW4KKs1aGpcRcowGWyYJr2DEBfRrd6hNJybxSWJFuZYD4ma86xhrwDDHxmDaIq4EA8A==", - "dev": true, - "dependencies": { - "browserslist": "^4.21.4" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/core-js" - } - }, - "node_modules/core-js-pure": { - "version": "3.26.1", - "resolved": "https://registry.npmjs.org/core-js-pure/-/core-js-pure-3.26.1.tgz", - "integrity": "sha512-VVXcDpp/xJ21KdULRq/lXdLzQAtX7+37LzpyfFM973il0tWSsDEoyzG38G14AjTpK9VTfiNM9jnFauq/CpaWGQ==", - "dev": true, - "hasInstallScript": true, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/core-js" - } - }, - "node_modules/core-util-is": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.3.tgz", - "integrity": "sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==", - "dev": true - }, - "node_modules/cosmiconfig": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-7.1.0.tgz", - "integrity": "sha512-AdmX6xUzdNASswsFtmwSt7Vj8po9IuqXm0UXz7QKPuEUmPB4XyjGfaAr2PSuELMwkRMVH1EpIkX5bTZGRB3eCA==", - "dependencies": { - "@types/parse-json": "^4.0.0", - "import-fresh": "^3.2.1", - "parse-json": "^5.0.0", - "path-type": "^4.0.0", - "yaml": "^1.10.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/cross-fetch": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-3.1.5.tgz", - "integrity": "sha512-lvb1SBsI0Z7GDwmuid+mU3kWVBwTVUbe7S0H52yaaAdQOXq2YktTCZdlAcNKFzE6QtRz0snpw9bNiPeOIkkQvw==", - "dev": true, - "dependencies": { - "node-fetch": "2.6.7" - } - }, - "node_modules/cross-spawn": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-5.1.0.tgz", - "integrity": "sha512-pTgQJ5KC0d2hcY8eyL1IzlBPYjTkyH72XRZPnLyKus2mBfNjQs3klqbJU2VILqZryAZUt9JOb3h/mWMy23/f5A==", - "dev": true, - "dependencies": { - "lru-cache": "^4.0.1", - "shebang-command": "^1.2.0", - "which": "^1.2.9" - } - }, - "node_modules/css-declaration-sorter": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-6.3.1.tgz", - "integrity": "sha512-fBffmak0bPAnyqc/HO8C3n2sHrp9wcqQz6ES9koRF2/mLOVAx9zIQ3Y7R29sYCteTPqMCwns4WYQoCX91Xl3+w==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >=14" - }, - "peerDependencies": { - "postcss": "^8.0.9" - } - }, - "node_modules/css-functions-list": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/css-functions-list/-/css-functions-list-3.1.0.tgz", - "integrity": "sha512-/9lCvYZaUbBGvYUgYGFJ4dcYiyqdhSjG7IPVluoV8A1ILjkF7ilmhp1OGUz8n+nmBcu0RNrQAzgD8B6FJbrt2w==", - "dev": true, - "engines": { - "node": ">=12.22" - } - }, - "node_modules/css-loader": { - "version": "6.7.3", - "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.7.3.tgz", - "integrity": "sha512-qhOH1KlBMnZP8FzRO6YCH9UHXQhVMcEGLyNdb7Hv2cpcmJbW0YrddO+tG1ab5nT41KpHIYGsbeHqxB9xPu1pKQ==", - "dev": true, - "dependencies": { - "icss-utils": "^5.1.0", - "postcss": "^8.4.19", - "postcss-modules-extract-imports": "^3.0.0", - "postcss-modules-local-by-default": "^4.0.0", - "postcss-modules-scope": "^3.0.0", - "postcss-modules-values": "^4.0.0", - "postcss-value-parser": "^4.2.0", - "semver": "^7.3.8" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "^5.0.0" - } - }, - "node_modules/css-loader/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/css-loader/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/css-loader/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/css-select": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/css-select/-/css-select-4.3.0.tgz", - "integrity": "sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==", - "dev": true, - "dependencies": { - "boolbase": "^1.0.0", - "css-what": "^6.0.1", - "domhandler": "^4.3.1", - "domutils": "^2.8.0", - "nth-check": "^2.0.1" - }, - "funding": { - "url": "https://github.com/sponsors/fb55" - } - }, - "node_modules/css-tree": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.1.3.tgz", - "integrity": "sha512-tRpdppF7TRazZrjJ6v3stzv93qxRcSsFmW6cX0Zm2NVKpxE1WV1HblnghVv9TreireHkqI/VDEsfolRF1p6y7Q==", - "dev": true, - "dependencies": { - "mdn-data": "2.0.14", - "source-map": "^0.6.1" - }, - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/css-tree/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/css-what": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/css-what/-/css-what-6.1.0.tgz", - "integrity": "sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==", - "dev": true, - "engines": { - "node": ">= 6" - }, - "funding": { - "url": "https://github.com/sponsors/fb55" - } - }, - "node_modules/cssesc": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", - "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", - "dev": true, - "bin": { - "cssesc": "bin/cssesc" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/cssnano": { - "version": "5.1.14", - "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-5.1.14.tgz", - "integrity": "sha512-Oou7ihiTocbKqi0J1bB+TRJIQX5RMR3JghA8hcWSw9mjBLQ5Y3RWqEDoYG3sRNlAbCIXpqMoZGbq5KDR3vdzgw==", - "dev": true, - "dependencies": { - "cssnano-preset-default": "^5.2.13", - "lilconfig": "^2.0.3", - "yaml": "^1.10.2" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/cssnano" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/cssnano-preset-default": { - "version": "5.2.13", - "resolved": "https://registry.npmjs.org/cssnano-preset-default/-/cssnano-preset-default-5.2.13.tgz", - "integrity": "sha512-PX7sQ4Pb+UtOWuz8A1d+Rbi+WimBIxJTRyBdgGp1J75VU0r/HFQeLnMYgHiCAp6AR4rqrc7Y4R+1Rjk3KJz6DQ==", - "dev": true, - "dependencies": { - "css-declaration-sorter": "^6.3.1", - "cssnano-utils": "^3.1.0", - "postcss-calc": "^8.2.3", - "postcss-colormin": "^5.3.0", - "postcss-convert-values": "^5.1.3", - "postcss-discard-comments": "^5.1.2", - "postcss-discard-duplicates": "^5.1.0", - "postcss-discard-empty": "^5.1.1", - "postcss-discard-overridden": "^5.1.0", - "postcss-merge-longhand": "^5.1.7", - "postcss-merge-rules": "^5.1.3", - "postcss-minify-font-values": "^5.1.0", - "postcss-minify-gradients": "^5.1.1", - "postcss-minify-params": "^5.1.4", - "postcss-minify-selectors": "^5.2.1", - "postcss-normalize-charset": "^5.1.0", - "postcss-normalize-display-values": "^5.1.0", - "postcss-normalize-positions": "^5.1.1", - "postcss-normalize-repeat-style": "^5.1.1", - "postcss-normalize-string": "^5.1.0", - "postcss-normalize-timing-functions": "^5.1.0", - "postcss-normalize-unicode": "^5.1.1", - "postcss-normalize-url": "^5.1.0", - "postcss-normalize-whitespace": "^5.1.1", - "postcss-ordered-values": "^5.1.3", - "postcss-reduce-initial": "^5.1.1", - "postcss-reduce-transforms": "^5.1.0", - "postcss-svgo": "^5.1.0", - "postcss-unique-selectors": "^5.1.1" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/cssnano-utils": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/cssnano-utils/-/cssnano-utils-3.1.0.tgz", - "integrity": "sha512-JQNR19/YZhz4psLX/rQ9M83e3z2Wf/HdJbryzte4a3NSuafyp9w/I4U+hx5C2S9g41qlstH7DEWnZaaj83OuEA==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/csso": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/csso/-/csso-4.2.0.tgz", - "integrity": "sha512-wvlcdIbf6pwKEk7vHj8/Bkc0B4ylXZruLvOgs9doS5eOsOpuodOV2zJChSpkp+pRpYQLQMeF04nr3Z68Sta9jA==", - "dev": true, - "dependencies": { - "css-tree": "^1.1.2" - }, - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/cssom": { - "version": "0.4.4", - "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", - "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", - "dev": true - }, - "node_modules/cssstyle": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.3.0.tgz", - "integrity": "sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==", - "dev": true, - "dependencies": { - "cssom": "~0.3.6" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/cssstyle/node_modules/cssom": { - "version": "0.3.8", - "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", - "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", - "dev": true - }, - "node_modules/csstype": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/csstype/-/csstype-3.1.1.tgz", - "integrity": "sha512-DJR/VvkAvSZW9bTouZue2sSxDwdTN92uHjqeKVm+0dAqdfNykRzQ95tay8aXMBAAPpUiq4Qcug2L7neoRh2Egw==" - }, - "node_modules/cwd": { - "version": "0.10.0", - "resolved": "https://registry.npmjs.org/cwd/-/cwd-0.10.0.tgz", - "integrity": "sha512-YGZxdTTL9lmLkCUTpg4j0zQ7IhRB5ZmqNBbGCl3Tg6MP/d5/6sY7L5mmTjzbc6JKgVZYiqTQTNhPFsbXNGlRaA==", - "dev": true, - "dependencies": { - "find-pkg": "^0.1.2", - "fs-exists-sync": "^0.1.0" - }, - "engines": { - "node": ">=0.8" - } - }, - "node_modules/damerau-levenshtein": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.8.tgz", - "integrity": "sha512-sdQSFB7+llfUcQHUQO3+B8ERRj0Oa4w9POWMI/puGtuf7gFywGmkaLCElnudfTiKZV+NvHqL0ifzdrI8Ro7ESA==", - "dev": true - }, - "node_modules/data-urls": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-2.0.0.tgz", - "integrity": "sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ==", - "dev": true, - "dependencies": { - "abab": "^2.0.3", - "whatwg-mimetype": "^2.3.0", - "whatwg-url": "^8.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/date-fns": { - "version": "2.29.3", - "resolved": "https://registry.npmjs.org/date-fns/-/date-fns-2.29.3.tgz", - "integrity": "sha512-dDCnyH2WnnKusqvZZ6+jA1O51Ibt8ZMRNkDZdyAyK4YfbDwa/cEmuztzG5pk6hqlp9aSBPYcjOlktquahGwGeA==", - "engines": { - "node": ">=0.11" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/date-fns" - } - }, - "node_modules/debug": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", - "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", - "dependencies": { - "ms": "2.1.2" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } - } - }, - "node_modules/decamelize": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", - "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/decamelize-keys": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/decamelize-keys/-/decamelize-keys-1.1.1.tgz", - "integrity": "sha512-WiPxgEirIV0/eIOMcnFBA3/IJZAZqKnwAwWyvvdi4lsr1WCN22nhdf/3db3DoZcUjTV2SqfzIwNyp6y2xs3nmg==", - "dev": true, - "dependencies": { - "decamelize": "^1.1.0", - "map-obj": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/decamelize-keys/node_modules/map-obj": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-1.0.1.tgz", - "integrity": "sha512-7N/q3lyZ+LVCp7PzuxrJr4KMbBE2hW7BT7YNia330OFxIf4d3r5zVpicP2650l7CPN6RM9zOJRl3NGpqSiw3Eg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/decimal.js": { - "version": "10.4.3", - "resolved": "https://registry.npmjs.org/decimal.js/-/decimal.js-10.4.3.tgz", - "integrity": "sha512-VBBaLc1MgL5XpzgIP7ny5Z6Nx3UrRkIViUkPUdtl9aya5amy3De1gsUUSB1g3+3sExYNjCAsAznmukyxCb1GRA==", - "dev": true - }, - "node_modules/dedent": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", - "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", - "dev": true - }, - "node_modules/deep-extend": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", - "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", - "dev": true, - "engines": { - "node": ">=4.0.0" - } - }, - "node_modules/deep-is": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.4.tgz", - "integrity": "sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==", - "dev": true - }, - "node_modules/deepmerge": { - "version": "4.2.2", - "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.2.2.tgz", - "integrity": "sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/default-gateway": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-6.0.3.tgz", - "integrity": "sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg==", - "dev": true, - "dependencies": { - "execa": "^5.0.0" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/define-lazy-prop": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz", - "integrity": "sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/define-properties": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.4.tgz", - "integrity": "sha512-uckOqKcfaVvtBdsVkdPv3XjveQJsNQqmhXgRi8uhvWWuPYZCNlzT8qAyblUgNoXdHdjMTzAqeGjAoli8f+bzPA==", - "dev": true, - "dependencies": { - "has-property-descriptors": "^1.0.0", - "object-keys": "^1.1.1" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/del": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/del/-/del-4.1.1.tgz", - "integrity": "sha512-QwGuEUouP2kVwQenAsOof5Fv8K9t3D8Ca8NxcXKrIpEHjTXK5J2nXLdP+ALI1cgv8wj7KuwBhTwBkOZSJKM5XQ==", - "dev": true, - "dependencies": { - "@types/glob": "^7.1.1", - "globby": "^6.1.0", - "is-path-cwd": "^2.0.0", - "is-path-in-cwd": "^2.0.0", - "p-map": "^2.0.0", - "pify": "^4.0.1", - "rimraf": "^2.6.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/del/node_modules/array-union": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", - "integrity": "sha512-Dxr6QJj/RdU/hCaBjOfxW+q6lyuVE6JFWIrAUpuOOhoJJoQ99cUn3igRaHVB5P9WrgFVN0FfArM3x0cueOU8ng==", - "dev": true, - "dependencies": { - "array-uniq": "^1.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/del/node_modules/globby": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", - "integrity": "sha512-KVbFv2TQtbzCoxAnfD6JcHZTYCzyliEaaeM/gH8qQdkKr5s0OP9scEgvdcngyk7AVdY6YVW/TJHd+lQ/Df3Daw==", - "dev": true, - "dependencies": { - "array-union": "^1.0.1", - "glob": "^7.0.3", - "object-assign": "^4.0.1", - "pify": "^2.0.0", - "pinkie-promise": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/del/node_modules/globby/node_modules/pify": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", - "integrity": "sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/delayed-stream": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", - "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", - "dev": true, - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/delegate": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/delegate/-/delegate-3.2.0.tgz", - "integrity": "sha512-IofjkYBZaZivn0V8nnsMJGBr4jVLxHDheKSW88PyxS5QC4Vo9ZbZVvhzlSxY87fVq3STR6r+4cGepyHkcWOQSw==" - }, - "node_modules/depd": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", - "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/destroy": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", - "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", - "dev": true, - "engines": { - "node": ">= 0.8", - "npm": "1.2.8000 || >= 1.4.16" - } - }, - "node_modules/detect-newline": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-3.1.0.tgz", - "integrity": "sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/detect-node": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.1.0.tgz", - "integrity": "sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==", - "dev": true - }, - "node_modules/devtools-protocol": { - "version": "0.0.981744", - "resolved": "https://registry.npmjs.org/devtools-protocol/-/devtools-protocol-0.0.981744.tgz", - "integrity": "sha512-0cuGS8+jhR67Fy7qG3i3Pc7Aw494sb9yG9QgpG97SFVWwolgYjlhJg7n+UaHxOQT30d1TYu/EYe9k01ivLErIg==", - "dev": true - }, - "node_modules/diff": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/diff/-/diff-4.0.2.tgz", - "integrity": "sha512-58lmxKSA4BNyLz+HHMUzlOEpg09FV+ev6ZMe3vJihgdxzgcwZ8VoEEPmALCZG9LmqfVoNMMKpttIYTVG6uDY7A==", - "engines": { - "node": ">=0.3.1" - } - }, - "node_modules/diff-sequences": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-27.5.1.tgz", - "integrity": "sha512-k1gCAXAsNgLwEL+Y8Wvl+M6oEFj5bgazfZULpS5CneoPPXRaCCW7dm+q21Ky2VEE5X+VeRDBVg1Pcvvsr4TtNQ==", - "dev": true, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/dir-glob": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-3.0.1.tgz", - "integrity": "sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==", - "dev": true, - "dependencies": { - "path-type": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/dns-equal": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz", - "integrity": "sha512-z+paD6YUQsk+AbGCEM4PrOXSss5gd66QfcVBFTKR/HpFL9jCqikS94HYwKww6fQyO7IxrIIyUu+g0Ka9tUS2Cg==", - "dev": true - }, - "node_modules/dns-packet": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-5.4.0.tgz", - "integrity": "sha512-EgqGeaBB8hLiHLZtp/IbaDQTL8pZ0+IvwzSHA6d7VyMDM+B9hgddEMa9xjK5oYnw0ci0JQ6g2XCD7/f6cafU6g==", - "dev": true, - "dependencies": { - "@leichtgewicht/ip-codec": "^2.0.1" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/doctrine": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", - "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", - "dev": true, - "dependencies": { - "esutils": "^2.0.2" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/dom-scroll-into-view": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/dom-scroll-into-view/-/dom-scroll-into-view-1.2.1.tgz", - "integrity": "sha512-LwNVg3GJOprWDO+QhLL1Z9MMgWe/KAFLxVWKzjRTxNSPn8/LLDIfmuG71YHznXCqaqTjvHJDYO1MEAgX6XCNbQ==" - }, - "node_modules/dom-serializer": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-1.4.1.tgz", - "integrity": "sha512-VHwB3KfrcOOkelEG2ZOfxqLZdfkil8PtJi4P8N2MMXucZq2yLp75ClViUlOVwyoHEDjYU433Aq+5zWP61+RGag==", - "dev": true, - "dependencies": { - "domelementtype": "^2.0.1", - "domhandler": "^4.2.0", - "entities": "^2.0.0" - }, - "funding": { - "url": "https://github.com/cheeriojs/dom-serializer?sponsor=1" - } - }, - "node_modules/dom-serializer/node_modules/entities": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-2.2.0.tgz", - "integrity": "sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==", - "dev": true, - "funding": { - "url": "https://github.com/fb55/entities?sponsor=1" - } - }, - "node_modules/domelementtype": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.3.0.tgz", - "integrity": "sha512-OLETBj6w0OsagBwdXnPdN0cnMfF9opN69co+7ZrbfPGrdpPVNBUj02spi6B1N7wChLQiPn4CSH/zJvXw56gmHw==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/fb55" - } - ] - }, - "node_modules/domexception": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/domexception/-/domexception-2.0.1.tgz", - "integrity": "sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg==", - "dev": true, - "dependencies": { - "webidl-conversions": "^5.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/domexception/node_modules/webidl-conversions": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-5.0.0.tgz", - "integrity": "sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/domhandler": { - "version": "4.3.1", - "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-4.3.1.tgz", - "integrity": "sha512-GrwoxYN+uWlzO8uhUXRl0P+kHE4GtVPfYzVLcUxPL7KNdHKj66vvlhiweIHqYYXWlw+T8iLMp42Lm67ghw4WMQ==", - "dev": true, - "dependencies": { - "domelementtype": "^2.2.0" - }, - "engines": { - "node": ">= 4" - }, - "funding": { - "url": "https://github.com/fb55/domhandler?sponsor=1" - } - }, - "node_modules/domutils": { - "version": "2.8.0", - "resolved": "https://registry.npmjs.org/domutils/-/domutils-2.8.0.tgz", - "integrity": "sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==", - "dev": true, - "dependencies": { - "dom-serializer": "^1.0.1", - "domelementtype": "^2.2.0", - "domhandler": "^4.2.0" - }, - "funding": { - "url": "https://github.com/fb55/domutils?sponsor=1" - } - }, - "node_modules/dot-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.4.tgz", - "integrity": "sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/downshift": { - "version": "6.1.12", - "resolved": "https://registry.npmjs.org/downshift/-/downshift-6.1.12.tgz", - "integrity": "sha512-7XB/iaSJVS4T8wGFT3WRXmSF1UlBHAA40DshZtkrIscIN+VC+Lh363skLxFTvJwtNgHxAMDGEHT4xsyQFWL+UA==", - "dependencies": { - "@babel/runtime": "^7.14.8", - "compute-scroll-into-view": "^1.0.17", - "prop-types": "^15.7.2", - "react-is": "^17.0.2", - "tslib": "^2.3.0" - }, - "peerDependencies": { - "react": ">=16.12.0" - } - }, - "node_modules/duplexer": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", - "integrity": "sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==", - "dev": true - }, - "node_modules/ee-first": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", - "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", - "dev": true - }, - "node_modules/electron-to-chromium": { - "version": "1.4.284", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz", - "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==" - }, - "node_modules/emittery": { - "version": "0.8.1", - "resolved": "https://registry.npmjs.org/emittery/-/emittery-0.8.1.tgz", - "integrity": "sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sindresorhus/emittery?sponsor=1" - } - }, - "node_modules/emoji-regex": { - "version": "9.2.2", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-9.2.2.tgz", - "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", - "dev": true - }, - "node_modules/emojis-list": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz", - "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==", - "dev": true, - "engines": { - "node": ">= 4" - } - }, - "node_modules/encodeurl": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", - "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/encoding": { - "version": "0.1.13", - "resolved": "https://registry.npmjs.org/encoding/-/encoding-0.1.13.tgz", - "integrity": "sha512-ETBauow1T35Y/WZMkio9jiM0Z5xjHHmJ4XmjZOq1l/dXz3lr2sRn87nJy20RupqSh1F2m3HHPSp8ShIPQJrJ3A==", - "dependencies": { - "iconv-lite": "^0.6.2" - } - }, - "node_modules/end-of-stream": { - "version": "1.4.4", - "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", - "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", - "dev": true, - "dependencies": { - "once": "^1.4.0" - } - }, - "node_modules/enhanced-resolve": { - "version": "5.12.0", - "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.12.0.tgz", - "integrity": "sha512-QHTXI/sZQmko1cbDoNAa3mJ5qhWUUNAq3vR0/YiD379fWQrcfuoX1+HW2S0MTt7XmoPLapdaDKUtelUSPic7hQ==", - "dev": true, - "dependencies": { - "graceful-fs": "^4.2.4", - "tapable": "^2.2.0" - }, - "engines": { - "node": ">=10.13.0" - } - }, - "node_modules/entities": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-4.4.0.tgz", - "integrity": "sha512-oYp7156SP8LkeGD0GF85ad1X9Ai79WtRsZ2gxJqtBuzH+98YUV6jkHEKlZkMbcrjJjIVJNIDP/3WL9wQkoPbWA==", - "dev": true, - "engines": { - "node": ">=0.12" - }, - "funding": { - "url": "https://github.com/fb55/entities?sponsor=1" - } - }, - "node_modules/envinfo": { - "version": "7.8.1", - "resolved": "https://registry.npmjs.org/envinfo/-/envinfo-7.8.1.tgz", - "integrity": "sha512-/o+BXHmB7ocbHEAs6F2EnG0ogybVVUdkRunTT2glZU9XAaGmhqskrvKwqXuDfNjEO0LZKWdejEEpnq8aM0tOaw==", - "dev": true, - "bin": { - "envinfo": "dist/cli.js" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/equivalent-key-map": { - "version": "0.2.2", - "resolved": "https://registry.npmjs.org/equivalent-key-map/-/equivalent-key-map-0.2.2.tgz", - "integrity": "sha512-xvHeyCDbZzkpN4VHQj/n+j2lOwL0VWszG30X4cOrc9Y7Tuo2qCdZK/0AMod23Z5dCtNUbaju6p0rwOhHUk05ew==" - }, - "node_modules/error-ex": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", - "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", - "dependencies": { - "is-arrayish": "^0.2.1" - } - }, - "node_modules/error-stack-parser": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/error-stack-parser/-/error-stack-parser-2.1.4.tgz", - "integrity": "sha512-Sk5V6wVazPhq5MhpO+AUxJn5x7XSXGl1R93Vn7i+zS15KDVxQijejNCrz8340/2bgLBjR9GtEG8ZVKONDjcqGQ==", - "dev": true, - "dependencies": { - "stackframe": "^1.3.4" - } - }, - "node_modules/es-abstract": { - "version": "1.20.5", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.20.5.tgz", - "integrity": "sha512-7h8MM2EQhsCA7pU/Nv78qOXFpD8Rhqd12gYiSJVkrH9+e8VuA8JlPJK/hQjjlLv6pJvx/z1iRFKzYb0XT/RuAQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "es-to-primitive": "^1.2.1", - "function-bind": "^1.1.1", - "function.prototype.name": "^1.1.5", - "get-intrinsic": "^1.1.3", - "get-symbol-description": "^1.0.0", - "gopd": "^1.0.1", - "has": "^1.0.3", - "has-property-descriptors": "^1.0.0", - "has-symbols": "^1.0.3", - "internal-slot": "^1.0.3", - "is-callable": "^1.2.7", - "is-negative-zero": "^2.0.2", - "is-regex": "^1.1.4", - "is-shared-array-buffer": "^1.0.2", - "is-string": "^1.0.7", - "is-weakref": "^1.0.2", - "object-inspect": "^1.12.2", - "object-keys": "^1.1.1", - "object.assign": "^4.1.4", - "regexp.prototype.flags": "^1.4.3", - "safe-regex-test": "^1.0.0", - "string.prototype.trimend": "^1.0.6", - "string.prototype.trimstart": "^1.0.6", - "unbox-primitive": "^1.0.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/es-module-lexer": { - "version": "0.9.3", - "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-0.9.3.tgz", - "integrity": "sha512-1HQ2M2sPtxwnvOvT1ZClHyQDiggdNjURWpY2we6aMKCQiUVxTmVs2UYPLIrD84sS+kMdUwfBSylbJPwNnBrnHQ==", - "dev": true - }, - "node_modules/es-shim-unscopables": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/es-shim-unscopables/-/es-shim-unscopables-1.0.0.tgz", - "integrity": "sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==", - "dev": true, - "dependencies": { - "has": "^1.0.3" - } - }, - "node_modules/es-to-primitive": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", - "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", - "dev": true, - "dependencies": { - "is-callable": "^1.1.4", - "is-date-object": "^1.0.1", - "is-symbol": "^1.0.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", - "engines": { - "node": ">=6" - } - }, - "node_modules/escape-html": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", - "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" - }, - "node_modules/escape-string-regexp": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz", - "integrity": "sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==", - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/escodegen": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-2.0.0.tgz", - "integrity": "sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw==", - "dev": true, - "dependencies": { - "esprima": "^4.0.1", - "estraverse": "^5.2.0", - "esutils": "^2.0.2", - "optionator": "^0.8.1" - }, - "bin": { - "escodegen": "bin/escodegen.js", - "esgenerate": "bin/esgenerate.js" - }, - "engines": { - "node": ">=6.0" - }, - "optionalDependencies": { - "source-map": "~0.6.1" - } - }, - "node_modules/escodegen/node_modules/levn": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", - "integrity": "sha512-0OO4y2iOHix2W6ujICbKIaEQXvFQHue65vUG3pb5EUomzPI90z9hsA1VsO/dbIIpC53J8gxM9Q4Oho0jrCM/yA==", - "dev": true, - "dependencies": { - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/escodegen/node_modules/optionator": { - "version": "0.8.3", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", - "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", - "dev": true, - "dependencies": { - "deep-is": "~0.1.3", - "fast-levenshtein": "~2.0.6", - "levn": "~0.3.0", - "prelude-ls": "~1.1.2", - "type-check": "~0.3.2", - "word-wrap": "~1.2.3" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/escodegen/node_modules/prelude-ls": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", - "integrity": "sha512-ESF23V4SKG6lVSGZgYNpbsiaAkdab6ZgOxe52p7+Kid3W3u3bxR4Vfd/o21dmN7jSt0IwgZ4v5MUd26FEtXE9w==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/escodegen/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "optional": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/escodegen/node_modules/type-check": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", - "integrity": "sha512-ZCmOJdvOWDBYJlzAoFkC+Q0+bUyEOS1ltgp1MGU03fqHG+dbi9tBFU2Rd9QKiDZFAYrhPh2JUf7rZRIuHRKtOg==", - "dev": true, - "dependencies": { - "prelude-ls": "~1.1.2" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/eslint": { - "version": "8.29.0", - "resolved": "https://registry.npmjs.org/eslint/-/eslint-8.29.0.tgz", - "integrity": "sha512-isQ4EEiyUjZFbEKvEGJKKGBwXtvXX+zJbkVKCgTuB9t/+jUBcy8avhkEwWJecI15BkRkOYmvIM5ynbhRjEkoeg==", - "dev": true, - "dependencies": { - "@eslint/eslintrc": "^1.3.3", - "@humanwhocodes/config-array": "^0.11.6", - "@humanwhocodes/module-importer": "^1.0.1", - "@nodelib/fs.walk": "^1.2.8", - "ajv": "^6.10.0", - "chalk": "^4.0.0", - "cross-spawn": "^7.0.2", - "debug": "^4.3.2", - "doctrine": "^3.0.0", - "escape-string-regexp": "^4.0.0", - "eslint-scope": "^7.1.1", - "eslint-utils": "^3.0.0", - "eslint-visitor-keys": "^3.3.0", - "espree": "^9.4.0", - "esquery": "^1.4.0", - "esutils": "^2.0.2", - "fast-deep-equal": "^3.1.3", - "file-entry-cache": "^6.0.1", - "find-up": "^5.0.0", - "glob-parent": "^6.0.2", - "globals": "^13.15.0", - "grapheme-splitter": "^1.0.4", - "ignore": "^5.2.0", - "import-fresh": "^3.0.0", - "imurmurhash": "^0.1.4", - "is-glob": "^4.0.0", - "is-path-inside": "^3.0.3", - "js-sdsl": "^4.1.4", - "js-yaml": "^4.1.0", - "json-stable-stringify-without-jsonify": "^1.0.1", - "levn": "^0.4.1", - "lodash.merge": "^4.6.2", - "minimatch": "^3.1.2", - "natural-compare": "^1.4.0", - "optionator": "^0.9.1", - "regexpp": "^3.2.0", - "strip-ansi": "^6.0.1", - "strip-json-comments": "^3.1.0", - "text-table": "^0.2.0" - }, - "bin": { - "eslint": "bin/eslint.js" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "url": "https://opencollective.com/eslint" - } - }, - "node_modules/eslint-config-prettier": { - "version": "8.5.0", - "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.5.0.tgz", - "integrity": "sha512-obmWKLUNCnhtQRKc+tmnYuQl0pFU1ibYJQ5BGhTVB08bHe9wC8qUeG7c08dj9XX+AuPj1YSGSQIHl1pnDHZR0Q==", - "dev": true, - "bin": { - "eslint-config-prettier": "bin/cli.js" - }, - "peerDependencies": { - "eslint": ">=7.0.0" - } - }, - "node_modules/eslint-import-resolver-node": { - "version": "0.3.6", - "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.6.tgz", - "integrity": "sha512-0En0w03NRVMn9Uiyn8YRPDKvWjxCWkslUEhGNTdGx15RvPJYQ+lbOlqrlNI2vEAs4pDYK4f/HN2TbDmk5TP0iw==", - "dev": true, - "dependencies": { - "debug": "^3.2.7", - "resolve": "^1.20.0" - } - }, - "node_modules/eslint-import-resolver-node/node_modules/debug": { - "version": "3.2.7", - "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", - "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", - "dev": true, - "dependencies": { - "ms": "^2.1.1" - } - }, - "node_modules/eslint-module-utils": { - "version": "2.7.4", - "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.7.4.tgz", - "integrity": "sha512-j4GT+rqzCoRKHwURX7pddtIPGySnX9Si/cgMI5ztrcqOPtk5dDEeZ34CQVPphnqkJytlc97Vuk05Um2mJ3gEQA==", - "dev": true, - "dependencies": { - "debug": "^3.2.7" - }, - "engines": { - "node": ">=4" - }, - "peerDependenciesMeta": { - "eslint": { - "optional": true - } - } - }, - "node_modules/eslint-module-utils/node_modules/debug": { - "version": "3.2.7", - "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", - "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", - "dev": true, - "dependencies": { - "ms": "^2.1.1" - } - }, - "node_modules/eslint-plugin-import": { - "version": "2.26.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.26.0.tgz", - "integrity": "sha512-hYfi3FXaM8WPLf4S1cikh/r4IxnO6zrhZbEGz2b660EJRbuxgpDS5gkCuYgGWg2xxh2rBuIr4Pvhve/7c31koA==", - "dev": true, - "dependencies": { - "array-includes": "^3.1.4", - "array.prototype.flat": "^1.2.5", - "debug": "^2.6.9", - "doctrine": "^2.1.0", - "eslint-import-resolver-node": "^0.3.6", - "eslint-module-utils": "^2.7.3", - "has": "^1.0.3", - "is-core-module": "^2.8.1", - "is-glob": "^4.0.3", - "minimatch": "^3.1.2", - "object.values": "^1.1.5", - "resolve": "^1.22.0", - "tsconfig-paths": "^3.14.1" - }, - "engines": { - "node": ">=4" - }, - "peerDependencies": { - "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" - } - }, - "node_modules/eslint-plugin-import/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/eslint-plugin-import/node_modules/doctrine": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", - "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", - "dev": true, - "dependencies": { - "esutils": "^2.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/eslint-plugin-import/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true - }, - "node_modules/eslint-plugin-jest": { - "version": "25.7.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-25.7.0.tgz", - "integrity": "sha512-PWLUEXeeF7C9QGKqvdSbzLOiLTx+bno7/HC9eefePfEb257QFHg7ye3dh80AZVkaa/RQsBB1Q/ORQvg2X7F0NQ==", - "dev": true, - "dependencies": { - "@typescript-eslint/experimental-utils": "^5.0.0" - }, - "engines": { - "node": "^12.13.0 || ^14.15.0 || >=16.0.0" - }, - "peerDependencies": { - "@typescript-eslint/eslint-plugin": "^4.0.0 || ^5.0.0", - "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" - }, - "peerDependenciesMeta": { - "@typescript-eslint/eslint-plugin": { - "optional": true - }, - "jest": { - "optional": true - } - } - }, - "node_modules/eslint-plugin-jsdoc": { - "version": "37.9.7", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-37.9.7.tgz", - "integrity": "sha512-8alON8yYcStY94o0HycU2zkLKQdcS+qhhOUNQpfONHHwvI99afbmfpYuPqf6PbLz5pLZldG3Te5I0RbAiTN42g==", - "dev": true, - "dependencies": { - "@es-joy/jsdoccomment": "~0.20.1", - "comment-parser": "1.3.0", - "debug": "^4.3.3", - "escape-string-regexp": "^4.0.0", - "esquery": "^1.4.0", - "regextras": "^0.8.0", - "semver": "^7.3.5", - "spdx-expression-parse": "^3.0.1" - }, - "engines": { - "node": "^12 || ^14 || ^16 || ^17" - }, - "peerDependencies": { - "eslint": "^7.0.0 || ^8.0.0" - } - }, - "node_modules/eslint-plugin-jsdoc/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/eslint-plugin-jsdoc/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/eslint-plugin-jsdoc/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/eslint-plugin-jsx-a11y": { - "version": "6.6.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.6.1.tgz", - "integrity": "sha512-sXgFVNHiWffBq23uiS/JaP6eVR622DqwB4yTzKvGZGcPq6/yZ3WmOZfuBks/vHWo9GaFOqC2ZK4i6+C35knx7Q==", - "dev": true, - "dependencies": { - "@babel/runtime": "^7.18.9", - "aria-query": "^4.2.2", - "array-includes": "^3.1.5", - "ast-types-flow": "^0.0.7", - "axe-core": "^4.4.3", - "axobject-query": "^2.2.0", - "damerau-levenshtein": "^1.0.8", - "emoji-regex": "^9.2.2", - "has": "^1.0.3", - "jsx-ast-utils": "^3.3.2", - "language-tags": "^1.0.5", - "minimatch": "^3.1.2", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=4.0" - }, - "peerDependencies": { - "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" - } - }, - "node_modules/eslint-plugin-prettier": { - "version": "3.4.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-prettier/-/eslint-plugin-prettier-3.4.1.tgz", - "integrity": "sha512-htg25EUYUeIhKHXjOinK4BgCcDwtLHjqaxCDsMy5nbnUMkKFvIhMVCp+5GFUXQ4Nr8lBsPqtGAqBenbpFqAA2g==", - "dev": true, - "dependencies": { - "prettier-linter-helpers": "^1.0.0" - }, - "engines": { - "node": ">=6.0.0" - }, - "peerDependencies": { - "eslint": ">=5.0.0", - "prettier": ">=1.13.0" - }, - "peerDependenciesMeta": { - "eslint-config-prettier": { - "optional": true - } - } - }, - "node_modules/eslint-plugin-react": { - "version": "7.31.11", - "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.31.11.tgz", - "integrity": "sha512-TTvq5JsT5v56wPa9OYHzsrOlHzKZKjV+aLgS+55NJP/cuzdiQPC7PfYoUjMoxlffKtvijpk7vA/jmuqRb9nohw==", - "dev": true, - "dependencies": { - "array-includes": "^3.1.6", - "array.prototype.flatmap": "^1.3.1", - "array.prototype.tosorted": "^1.1.1", - "doctrine": "^2.1.0", - "estraverse": "^5.3.0", - "jsx-ast-utils": "^2.4.1 || ^3.0.0", - "minimatch": "^3.1.2", - "object.entries": "^1.1.6", - "object.fromentries": "^2.0.6", - "object.hasown": "^1.1.2", - "object.values": "^1.1.6", - "prop-types": "^15.8.1", - "resolve": "^2.0.0-next.3", - "semver": "^6.3.0", - "string.prototype.matchall": "^4.0.8" - }, - "engines": { - "node": ">=4" - }, - "peerDependencies": { - "eslint": "^3 || ^4 || ^5 || ^6 || ^7 || ^8" - } - }, - "node_modules/eslint-plugin-react-hooks": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", - "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", - "dev": true, - "engines": { - "node": ">=10" - }, - "peerDependencies": { - "eslint": "^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0" - } - }, - "node_modules/eslint-plugin-react/node_modules/doctrine": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", - "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", - "dev": true, - "dependencies": { - "esutils": "^2.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/eslint-plugin-react/node_modules/resolve": { - "version": "2.0.0-next.4", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-2.0.0-next.4.tgz", - "integrity": "sha512-iMDbmAWtfU+MHpxt/I5iWI7cY6YVEZUQ3MBgPQ++XD1PELuJHIl82xBmObyP2KyQmkNB2dsqF7seoQQiAn5yDQ==", - "dev": true, - "dependencies": { - "is-core-module": "^2.9.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - }, - "bin": { - "resolve": "bin/resolve" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/eslint-scope": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", - "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", - "dev": true, - "dependencies": { - "esrecurse": "^4.3.0", - "estraverse": "^4.1.1" - }, - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/eslint-scope/node_modules/estraverse": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", - "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", - "dev": true, - "engines": { - "node": ">=4.0" - } - }, - "node_modules/eslint-utils": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-3.0.0.tgz", - "integrity": "sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==", - "dev": true, - "dependencies": { - "eslint-visitor-keys": "^2.0.0" - }, - "engines": { - "node": "^10.0.0 || ^12.0.0 || >= 14.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/mysticatea" - }, - "peerDependencies": { - "eslint": ">=5" - } - }, - "node_modules/eslint-visitor-keys": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz", - "integrity": "sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/eslint/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/eslint/node_modules/argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true - }, - "node_modules/eslint/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/eslint/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/eslint/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/eslint/node_modules/cross-spawn": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", - "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", - "dev": true, - "dependencies": { - "path-key": "^3.1.0", - "shebang-command": "^2.0.0", - "which": "^2.0.1" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/eslint/node_modules/eslint-scope": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.1.1.tgz", - "integrity": "sha512-QKQM/UXpIiHcLqJ5AOyIW7XZmzjkzQXYE54n1++wb0u9V/abW3l9uQnxX8Z5Xd18xyKIMTUAyQ0k1e8pz6LUrw==", - "dev": true, - "dependencies": { - "esrecurse": "^4.3.0", - "estraverse": "^5.2.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - } - }, - "node_modules/eslint/node_modules/eslint-visitor-keys": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", - "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", - "dev": true, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - } - }, - "node_modules/eslint/node_modules/globals": { - "version": "13.19.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-13.19.0.tgz", - "integrity": "sha512-dkQ957uSRWHw7CFXLUtUHQI3g3aWApYhfNR2O6jn/907riyTYKVBmxYVROkBcY614FSSeSJh7Xm7SrUWCxvJMQ==", - "dev": true, - "dependencies": { - "type-fest": "^0.20.2" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/eslint/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/eslint/node_modules/js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", - "dev": true, - "dependencies": { - "argparse": "^2.0.1" - }, - "bin": { - "js-yaml": "bin/js-yaml.js" - } - }, - "node_modules/eslint/node_modules/shebang-command": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", - "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", - "dev": true, - "dependencies": { - "shebang-regex": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/eslint/node_modules/shebang-regex": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", - "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/eslint/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/eslint/node_modules/type-fest": { - "version": "0.20.2", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.20.2.tgz", - "integrity": "sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/eslint/node_modules/which": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", - "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", - "dev": true, - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "node-which": "bin/node-which" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/espree": { - "version": "9.4.1", - "resolved": "https://registry.npmjs.org/espree/-/espree-9.4.1.tgz", - "integrity": "sha512-XwctdmTO6SIvCzd9810yyNzIrOrqNYV9Koizx4C/mRhf9uq0o4yHoCEU/670pOxOL/MSraektvSAji79kX90Vg==", - "dev": true, - "dependencies": { - "acorn": "^8.8.0", - "acorn-jsx": "^5.3.2", - "eslint-visitor-keys": "^3.3.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "url": "https://opencollective.com/eslint" - } - }, - "node_modules/espree/node_modules/eslint-visitor-keys": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.3.0.tgz", - "integrity": "sha512-mQ+suqKJVyeuwGYHAdjMFqjCyfl8+Ldnxuyp3ldiMBFKkvytrXUZWaiPCEav8qDHKty44bD+qV1IP4T+w+xXRA==", - "dev": true, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - } - }, - "node_modules/esprima": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", - "dev": true, - "bin": { - "esparse": "bin/esparse.js", - "esvalidate": "bin/esvalidate.js" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/esquery": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.4.0.tgz", - "integrity": "sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w==", - "dev": true, - "dependencies": { - "estraverse": "^5.1.0" - }, - "engines": { - "node": ">=0.10" - } - }, - "node_modules/esrecurse": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", - "integrity": "sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag==", - "dev": true, - "dependencies": { - "estraverse": "^5.2.0" - }, - "engines": { - "node": ">=4.0" - } - }, - "node_modules/estraverse": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", - "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", - "dev": true, - "engines": { - "node": ">=4.0" - } - }, - "node_modules/esutils": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", - "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/etag": { - "version": "1.8.1", - "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", - "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/eventemitter3": { - "version": "4.0.7", - "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", - "integrity": "sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==", - "dev": true - }, - "node_modules/events": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", - "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", - "dev": true, - "engines": { - "node": ">=0.8.x" - } - }, - "node_modules/execa": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/execa/-/execa-5.1.1.tgz", - "integrity": "sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==", - "dev": true, - "dependencies": { - "cross-spawn": "^7.0.3", - "get-stream": "^6.0.0", - "human-signals": "^2.1.0", - "is-stream": "^2.0.0", - "merge-stream": "^2.0.0", - "npm-run-path": "^4.0.1", - "onetime": "^5.1.2", - "signal-exit": "^3.0.3", - "strip-final-newline": "^2.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sindresorhus/execa?sponsor=1" - } - }, - "node_modules/execa/node_modules/cross-spawn": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", - "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", - "dev": true, - "dependencies": { - "path-key": "^3.1.0", - "shebang-command": "^2.0.0", - "which": "^2.0.1" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/execa/node_modules/shebang-command": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", - "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", - "dev": true, - "dependencies": { - "shebang-regex": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/execa/node_modules/shebang-regex": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", - "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/execa/node_modules/which": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", - "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", - "dev": true, - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "node-which": "bin/node-which" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/exit": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", - "integrity": "sha512-Zk/eNKV2zbjpKzrsQ+n1G6poVbErQxJ0LBOJXaKZ1EViLzH+hrLu9cdXI4zw9dBQJslwBEpbQ2P1oS7nDxs6jQ==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/expand-tilde": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-1.2.2.tgz", - "integrity": "sha512-rtmc+cjLZqnu9dSYosX9EWmSJhTwpACgJQTfj4hgg2JjOD/6SIQalZrt4a3aQeh++oNxkazcaxrhPUj6+g5G/Q==", - "dev": true, - "dependencies": { - "os-homedir": "^1.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/expect": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/expect/-/expect-27.5.1.tgz", - "integrity": "sha512-E1q5hSUG2AmYQwQJ041nvgpkODHQvB+RKlB4IYdru6uJsyFTRyZAP463M+1lINorwbqAmUggi6+WwkD8lCS/Dw==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "jest-get-type": "^27.5.1", - "jest-matcher-utils": "^27.5.1", - "jest-message-util": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/expect-puppeteer": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/expect-puppeteer/-/expect-puppeteer-4.4.0.tgz", - "integrity": "sha512-6Ey4Xy2xvmuQu7z7YQtMsaMV0EHJRpVxIDOd5GRrm04/I3nkTKIutELfECsLp6le+b3SSa3cXhPiw6PgqzxYWA==", - "dev": true - }, - "node_modules/express": { - "version": "4.18.2", - "resolved": "https://registry.npmjs.org/express/-/express-4.18.2.tgz", - "integrity": "sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==", - "dev": true, - "dependencies": { - "accepts": "~1.3.8", - "array-flatten": "1.1.1", - "body-parser": "1.20.1", - "content-disposition": "0.5.4", - "content-type": "~1.0.4", - "cookie": "0.5.0", - "cookie-signature": "1.0.6", - "debug": "2.6.9", - "depd": "2.0.0", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "etag": "~1.8.1", - "finalhandler": "1.2.0", - "fresh": "0.5.2", - "http-errors": "2.0.0", - "merge-descriptors": "1.0.1", - "methods": "~1.1.2", - "on-finished": "2.4.1", - "parseurl": "~1.3.3", - "path-to-regexp": "0.1.7", - "proxy-addr": "~2.0.7", - "qs": "6.11.0", - "range-parser": "~1.2.1", - "safe-buffer": "5.2.1", - "send": "0.18.0", - "serve-static": "1.15.0", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "type-is": "~1.6.18", - "utils-merge": "1.0.1", - "vary": "~1.1.2" - }, - "engines": { - "node": ">= 0.10.0" - } - }, - "node_modules/express/node_modules/array-flatten": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", - "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==", - "dev": true - }, - "node_modules/express/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/express/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true - }, - "node_modules/extract-zip": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extract-zip/-/extract-zip-2.0.1.tgz", - "integrity": "sha512-GDhU9ntwuKyGXdZBUgTIe+vXnWj0fppUEtMDL0+idd5Sta8TGpHssn/eusA9mrPr9qNDym6SxAYZjNvCn/9RBg==", - "dev": true, - "dependencies": { - "debug": "^4.1.1", - "get-stream": "^5.1.0", - "yauzl": "^2.10.0" - }, - "bin": { - "extract-zip": "cli.js" - }, - "engines": { - "node": ">= 10.17.0" - }, - "optionalDependencies": { - "@types/yauzl": "^2.9.1" - } - }, - "node_modules/extract-zip/node_modules/get-stream": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz", - "integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==", - "dev": true, - "dependencies": { - "pump": "^3.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/fast-average-color": { - "version": "9.3.0", - "resolved": "https://registry.npmjs.org/fast-average-color/-/fast-average-color-9.3.0.tgz", - "integrity": "sha512-FlPROSqDMOnoBgkFhWMHJODPvpS0Od0WDpedcKq4U/t0JVapGAkblNwxOr75qT+ZNd0dQM4qlgqrtnXbCJ8cNg==", - "engines": { - "node": ">= 12" - } - }, - "node_modules/fast-deep-equal": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", - "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==" - }, - "node_modules/fast-diff": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/fast-diff/-/fast-diff-1.2.0.tgz", - "integrity": "sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==", - "dev": true - }, - "node_modules/fast-glob": { - "version": "3.2.12", - "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-3.2.12.tgz", - "integrity": "sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==", - "dev": true, - "dependencies": { - "@nodelib/fs.stat": "^2.0.2", - "@nodelib/fs.walk": "^1.2.3", - "glob-parent": "^5.1.2", - "merge2": "^1.3.0", - "micromatch": "^4.0.4" - }, - "engines": { - "node": ">=8.6.0" - } - }, - "node_modules/fast-glob/node_modules/glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dev": true, - "dependencies": { - "is-glob": "^4.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/fast-json-stable-stringify": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", - "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==", - "dev": true - }, - "node_modules/fast-levenshtein": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", - "integrity": "sha512-DCXu6Ifhqcks7TZKY3Hxp3y6qphY5SJZmrWMDrKcERSOXWQdMhU9Ig/PYrzyw/ul9jOIyh0N4M0tbC5hodg8dw==", - "dev": true - }, - "node_modules/fastest-levenshtein": { - "version": "1.0.16", - "resolved": "https://registry.npmjs.org/fastest-levenshtein/-/fastest-levenshtein-1.0.16.tgz", - "integrity": "sha512-eRnCtTTtGZFpQCwhJiUOuxPQWRXVKYDn0b2PeHfXL6/Zi53SLAzAHfVhVWK2AryC/WH05kGfxhFIPvTF0SXQzg==", - "dev": true, - "engines": { - "node": ">= 4.9.1" - } - }, - "node_modules/fastq": { - "version": "1.14.0", - "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.14.0.tgz", - "integrity": "sha512-eR2D+V9/ExcbF9ls441yIuN6TI2ED1Y2ZcA5BmMtJsOkWOFRJQ0Jt0g1UwqXJJVAb+V+umH5Dfr8oh4EVP7VVg==", - "dev": true, - "dependencies": { - "reusify": "^1.0.4" - } - }, - "node_modules/faye-websocket": { - "version": "0.11.4", - "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.4.tgz", - "integrity": "sha512-CzbClwlXAuiRQAlUyfqPgvPoNKTckTPGfwZV4ZdAhVcP2lh9KUxJg2b5GkE7XbjKQ3YJnQ9z6D9ntLAlB+tP8g==", - "dev": true, - "dependencies": { - "websocket-driver": ">=0.5.1" - }, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/fb-watchman": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.2.tgz", - "integrity": "sha512-p5161BqbuCaSnB8jIbzQHOlpgsPmK5rJVDfDKO91Axs5NC1uu3HRQm6wt9cd9/+GtQQIO53JdGXXoyDpTAsgYA==", - "dev": true, - "dependencies": { - "bser": "2.1.1" - } - }, - "node_modules/fd-slicer": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/fd-slicer/-/fd-slicer-1.1.0.tgz", - "integrity": "sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==", - "dev": true, - "dependencies": { - "pend": "~1.2.0" - } - }, - "node_modules/file-entry-cache": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", - "integrity": "sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==", - "dev": true, - "dependencies": { - "flat-cache": "^3.0.4" - }, - "engines": { - "node": "^10.12.0 || >=12.0.0" - } - }, - "node_modules/filename-reserved-regex": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/filename-reserved-regex/-/filename-reserved-regex-2.0.0.tgz", - "integrity": "sha512-lc1bnsSr4L4Bdif8Xb/qrtokGbq5zlsms/CYH8PP+WtCkGNF65DPiQY8vG3SakEdRn8Dlnm+gW/qWKKjS5sZzQ==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/filenamify": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/filenamify/-/filenamify-4.3.0.tgz", - "integrity": "sha512-hcFKyUG57yWGAzu1CMt/dPzYZuv+jAJUT85bL8mrXvNe6hWj6yEHEc4EdcgiA6Z3oi1/9wXJdZPXF2dZNgwgOg==", - "dev": true, - "dependencies": { - "filename-reserved-regex": "^2.0.0", - "strip-outer": "^1.0.1", - "trim-repeated": "^1.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/fill-range": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", - "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", - "dev": true, - "dependencies": { - "to-regex-range": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/finalhandler": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", - "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", - "dev": true, - "dependencies": { - "debug": "2.6.9", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "on-finished": "2.4.1", - "parseurl": "~1.3.3", - "statuses": "2.0.1", - "unpipe": "~1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/finalhandler/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/finalhandler/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true - }, - "node_modules/find-cache-dir": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz", - "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==", - "dev": true, - "dependencies": { - "commondir": "^1.0.1", - "make-dir": "^3.0.2", - "pkg-dir": "^4.1.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/avajs/find-cache-dir?sponsor=1" - } - }, - "node_modules/find-file-up": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/find-file-up/-/find-file-up-0.1.3.tgz", - "integrity": "sha512-mBxmNbVyjg1LQIIpgO8hN+ybWBgDQK8qjht+EbrTCGmmPV/sc7RF1i9stPTD6bpvXZywBdrwRYxhSdJv867L6A==", - "dev": true, - "dependencies": { - "fs-exists-sync": "^0.1.0", - "resolve-dir": "^0.1.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/find-parent-dir": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/find-parent-dir/-/find-parent-dir-0.3.1.tgz", - "integrity": "sha512-o4UcykWV/XN9wm+jMEtWLPlV8RXCZnMhQI6F6OdHeSez7iiJWePw8ijOlskJZMsaQoGR/b7dH6lO02HhaTN7+A==", - "dev": true - }, - "node_modules/find-pkg": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/find-pkg/-/find-pkg-0.1.2.tgz", - "integrity": "sha512-0rnQWcFwZr7eO0513HahrWafsc3CTFioEB7DRiEYCUM/70QXSY8f3mCST17HXLcPvEhzH/Ty/Bxd72ZZsr/yvw==", - "dev": true, - "dependencies": { - "find-file-up": "^0.1.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/find-process": { - "version": "1.4.7", - "resolved": "https://registry.npmjs.org/find-process/-/find-process-1.4.7.tgz", - "integrity": "sha512-/U4CYp1214Xrp3u3Fqr9yNynUrr5Le4y0SsJh2lMDDSbpwYSz3M2SMWQC+wqcx79cN8PQtHQIL8KnuY9M66fdg==", - "dev": true, - "dependencies": { - "chalk": "^4.0.0", - "commander": "^5.1.0", - "debug": "^4.1.1" - }, - "bin": { - "find-process": "bin/find-process.js" - } - }, - "node_modules/find-process/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/find-process/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/find-process/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/find-process/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/find-process/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/find-process/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/find-root": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/find-root/-/find-root-1.1.0.tgz", - "integrity": "sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==" - }, - "node_modules/find-up": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", - "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", - "dev": true, - "dependencies": { - "locate-path": "^6.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/flat-cache": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-3.0.4.tgz", - "integrity": "sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==", - "dev": true, - "dependencies": { - "flatted": "^3.1.0", - "rimraf": "^3.0.2" - }, - "engines": { - "node": "^10.12.0 || >=12.0.0" - } - }, - "node_modules/flat-cache/node_modules/rimraf": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", - "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", - "dev": true, - "dependencies": { - "glob": "^7.1.3" - }, - "bin": { - "rimraf": "bin.js" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/flatted": { - "version": "3.2.7", - "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.7.tgz", - "integrity": "sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==", - "dev": true - }, - "node_modules/follow-redirects": { - "version": "1.15.2", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.2.tgz", - "integrity": "sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==", - "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://github.com/sponsors/RubenVerborgh" - } - ], - "engines": { - "node": ">=4.0" - }, - "peerDependenciesMeta": { - "debug": { - "optional": true - } - } - }, - "node_modules/for-in": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", - "integrity": "sha512-7EwmXrOjyL+ChxMhmG5lnW9MPt1aIeZEwKhQzoBUdTV0N3zuwWDZYVJatDvZ2OyzPUvdIAZDsCetk3coyMfcnQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/for-own": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", - "integrity": "sha512-SKmowqGTJoPzLO1T0BBJpkfp3EMacCMOuH40hOUbrbzElVktk4DioXVM99QkLCyKoiuOmyjgcWMpVz2xjE7LZw==", - "dev": true, - "dependencies": { - "for-in": "^1.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/form-data": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-3.0.1.tgz", - "integrity": "sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==", - "dev": true, - "dependencies": { - "asynckit": "^0.4.0", - "combined-stream": "^1.0.8", - "mime-types": "^2.1.12" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/forwarded": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", - "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/fraction.js": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/fraction.js/-/fraction.js-4.2.0.tgz", - "integrity": "sha512-MhLuK+2gUcnZe8ZHlaaINnQLl0xRIGRfcGk2yl8xoQAfHrSsL3rYu6FCmBdkdbhc9EPlwyGHewaRsvwRMJtAlA==", - "dev": true, - "engines": { - "node": "*" - }, - "funding": { - "type": "patreon", - "url": "https://www.patreon.com/infusion" - } - }, - "node_modules/framer-motion": { - "version": "7.10.0", - "resolved": "https://registry.npmjs.org/framer-motion/-/framer-motion-7.10.0.tgz", - "integrity": "sha512-HZUl5hFIO23XuhxhGaWSVXaElYv0Wlk3iYXeqNmp1WF1JvD1vQMvuH3OE7Q5PsFX+a5+FrWRam7a4S7xDigEag==", - "dependencies": { - "@motionone/dom": "^10.15.3", - "hey-listen": "^1.0.8", - "tslib": "2.4.0" - }, - "optionalDependencies": { - "@emotion/is-prop-valid": "^0.8.2" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, - "node_modules/framer-motion/node_modules/@emotion/is-prop-valid": { - "version": "0.8.8", - "resolved": "https://registry.npmjs.org/@emotion/is-prop-valid/-/is-prop-valid-0.8.8.tgz", - "integrity": "sha512-u5WtneEAr5IDG2Wv65yhunPSMLIpuKsbuOktRojfrEiEvRyC85LgPMZI63cr7NUqT8ZIGdSVg8ZKGxIug4lXcA==", - "optional": true, - "dependencies": { - "@emotion/memoize": "0.7.4" - } - }, - "node_modules/framer-motion/node_modules/@emotion/memoize": { - "version": "0.7.4", - "resolved": "https://registry.npmjs.org/@emotion/memoize/-/memoize-0.7.4.tgz", - "integrity": "sha512-Ja/Vfqe3HpuzRsG1oBtWTHk2PGZ7GR+2Vz5iYGelAw8dx32K0y7PjVuxK6z1nMpZOqAFsRUPCkK1YjJ56qJlgw==", - "optional": true - }, - "node_modules/framer-motion/node_modules/tslib": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.0.tgz", - "integrity": "sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==" - }, - "node_modules/fresh": { - "version": "0.5.2", - "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", - "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/fs-constants": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs-constants/-/fs-constants-1.0.0.tgz", - "integrity": "sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==", - "dev": true - }, - "node_modules/fs-exists-sync": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/fs-exists-sync/-/fs-exists-sync-0.1.0.tgz", - "integrity": "sha512-cR/vflFyPZtrN6b38ZyWxpWdhlXrzZEBawlpBQMq7033xVY7/kg0GDMBK5jg8lDYQckdJ5x/YC88lM3C7VMsLg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/fs-monkey": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/fs-monkey/-/fs-monkey-1.0.3.tgz", - "integrity": "sha512-cybjIfiiE+pTWicSCLFHSrXZ6EilF30oh91FDP9S2B051prEa7QWfrVTQm10/dDpswBDXZugPa1Ogu8Yh+HV0Q==", - "dev": true - }, - "node_modules/fs.realpath": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", - "integrity": "sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==", - "dev": true - }, - "node_modules/fsevents": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.2.tgz", - "integrity": "sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==", - "dev": true, - "hasInstallScript": true, - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": "^8.16.0 || ^10.6.0 || >=11.0.0" - } - }, - "node_modules/function-bind": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", - "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" - }, - "node_modules/function.prototype.name": { - "version": "1.1.5", - "resolved": "https://registry.npmjs.org/function.prototype.name/-/function.prototype.name-1.1.5.tgz", - "integrity": "sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.3", - "es-abstract": "^1.19.0", - "functions-have-names": "^1.2.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/functions-have-names": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/functions-have-names/-/functions-have-names-1.2.3.tgz", - "integrity": "sha512-xckBUXyTIqT97tq2x2AMb+g163b5JFysYk0x4qxNFwbfQkmNZoiRHb6sPzI9/QV33WeuvVYBUIiD4NzNIyqaRQ==", - "dev": true, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/gensync": { - "version": "1.0.0-beta.2", - "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", - "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", - "engines": { - "node": ">=6.9.0" - } - }, - "node_modules/get-caller-file": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", - "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", - "engines": { - "node": "6.* || 8.* || >= 10.*" - } - }, - "node_modules/get-intrinsic": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.1.3.tgz", - "integrity": "sha512-QJVz1Tj7MS099PevUG5jvnt9tSkXN8K14dxQlikJuPt4uD9hHAHjLyLBiLR5zELelBdD9QNRAXZzsJx0WaDL9A==", - "dev": true, - "dependencies": { - "function-bind": "^1.1.1", - "has": "^1.0.3", - "has-symbols": "^1.0.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/get-package-type": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/get-package-type/-/get-package-type-0.1.0.tgz", - "integrity": "sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==", - "dev": true, - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/get-stdin": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-9.0.0.tgz", - "integrity": "sha512-dVKBjfWisLAicarI2Sf+JuBE/DghV4UzNAVe9yhEJuzeREd3JhOTE9cUaJTeSa77fsbQUK3pcOpJfM59+VKZaA==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/get-stream": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-6.0.1.tgz", - "integrity": "sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/get-symbol-description": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", - "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "get-intrinsic": "^1.1.1" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/gettext-parser": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/gettext-parser/-/gettext-parser-1.4.0.tgz", - "integrity": "sha512-sedZYLHlHeBop/gZ1jdg59hlUEcpcZJofLq2JFwJT1zTqAU3l2wFv6IsuwFHGqbiT9DWzMUW4/em2+hspnmMMA==", - "dependencies": { - "encoding": "^0.1.12", - "safe-buffer": "^5.1.1" - } - }, - "node_modules/glob": { - "version": "7.2.3", - "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", - "integrity": "sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==", - "dev": true, - "dependencies": { - "fs.realpath": "^1.0.0", - "inflight": "^1.0.4", - "inherits": "2", - "minimatch": "^3.1.1", - "once": "^1.3.0", - "path-is-absolute": "^1.0.0" - }, - "engines": { - "node": "*" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/glob-parent": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-6.0.2.tgz", - "integrity": "sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==", - "dev": true, - "dependencies": { - "is-glob": "^4.0.3" - }, - "engines": { - "node": ">=10.13.0" - } - }, - "node_modules/glob-to-regexp": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", - "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", - "dev": true - }, - "node_modules/global-modules": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-0.2.3.tgz", - "integrity": "sha512-JeXuCbvYzYXcwE6acL9V2bAOeSIGl4dD+iwLY9iUx2VBJJ80R18HCn+JCwHM9Oegdfya3lEkGCdaRkSyc10hDA==", - "dev": true, - "dependencies": { - "global-prefix": "^0.1.4", - "is-windows": "^0.2.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/global-prefix": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-0.1.5.tgz", - "integrity": "sha512-gOPiyxcD9dJGCEArAhF4Hd0BAqvAe/JzERP7tYumE4yIkmIedPUVXcJFWbV3/p/ovIIvKjkrTk+f1UVkq7vvbw==", - "dev": true, - "dependencies": { - "homedir-polyfill": "^1.0.0", - "ini": "^1.3.4", - "is-windows": "^0.2.0", - "which": "^1.2.12" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/globals": { - "version": "11.12.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", - "engines": { - "node": ">=4" - } - }, - "node_modules/globby": { - "version": "11.1.0", - "resolved": "https://registry.npmjs.org/globby/-/globby-11.1.0.tgz", - "integrity": "sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==", - "dev": true, - "dependencies": { - "array-union": "^2.1.0", - "dir-glob": "^3.0.1", - "fast-glob": "^3.2.9", - "ignore": "^5.2.0", - "merge2": "^1.4.1", - "slash": "^3.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/globjoin": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/globjoin/-/globjoin-0.1.4.tgz", - "integrity": "sha512-xYfnw62CKG8nLkZBfWbhWwDw02CHty86jfPcc2cr3ZfeuK9ysoVPPEUxf21bAD/rWAgk52SuBrLJlefNy8mvFg==", - "dev": true - }, - "node_modules/good-listener": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/good-listener/-/good-listener-1.2.2.tgz", - "integrity": "sha512-goW1b+d9q/HIwbVYZzZ6SsTr4IgE+WA44A0GmPIQstuOrgsFcT7VEJ48nmr9GaRtNu0XTKacFLGnBPAM6Afouw==", - "dependencies": { - "delegate": "^3.1.2" - } - }, - "node_modules/gopd": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", - "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", - "dev": true, - "dependencies": { - "get-intrinsic": "^1.1.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/graceful-fs": { - "version": "4.2.10", - "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.10.tgz", - "integrity": "sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==", - "dev": true - }, - "node_modules/gradient-parser": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/gradient-parser/-/gradient-parser-0.1.5.tgz", - "integrity": "sha512-+uPlcVbjrKOnTzvz0MjTj7BfACj8OmxIa1moIjJV7btvhUMSJk0D47RfDCgDrZE3dYMz9Cf5xKJwnrKLjUq0KQ==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/grapheme-splitter": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/grapheme-splitter/-/grapheme-splitter-1.0.4.tgz", - "integrity": "sha512-bzh50DW9kTPM00T8y4o8vQg89Di9oLJVLW/KaOGIXJWP/iqCN6WKYkbNOF04vFLJhwcpYUh9ydh/+5vpOqV4YQ==", - "dev": true - }, - "node_modules/gzip-size": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/gzip-size/-/gzip-size-6.0.0.tgz", - "integrity": "sha512-ax7ZYomf6jqPTQ4+XCpUGyXKHk5WweS+e05MBO4/y3WJ5RkmPXNKvX+bx1behVILVwr6JSQvZAku021CHPXG3Q==", - "dev": true, - "dependencies": { - "duplexer": "^0.1.2" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/handle-thing": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.1.tgz", - "integrity": "sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==", - "dev": true - }, - "node_modules/hard-rejection": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/hard-rejection/-/hard-rejection-2.1.0.tgz", - "integrity": "sha512-VIZB+ibDhx7ObhAe7OVtoEbuP4h/MuOTHJ+J8h/eBXotJYl0fBgR72xDFCKgIh22OJZIOVNxBMWuhAr10r8HdA==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/has": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", - "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", - "dependencies": { - "function-bind": "^1.1.1" - }, - "engines": { - "node": ">= 0.4.0" - } - }, - "node_modules/has-bigints": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/has-bigints/-/has-bigints-1.0.2.tgz", - "integrity": "sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==", - "dev": true, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "engines": { - "node": ">=4" - } - }, - "node_modules/has-property-descriptors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.0.tgz", - "integrity": "sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==", - "dev": true, - "dependencies": { - "get-intrinsic": "^1.1.1" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/has-symbols": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", - "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", - "dev": true, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/has-tostringtag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", - "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", - "dev": true, - "dependencies": { - "has-symbols": "^1.0.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/header-case": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/header-case/-/header-case-2.0.4.tgz", - "integrity": "sha512-H/vuk5TEEVZwrR0lp2zed9OCo1uAILMlx0JEMgC26rzyJJ3N1v6XkwHHXJQdR2doSjcGPM6OKPYoJgf0plJ11Q==", - "dependencies": { - "capital-case": "^1.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/hey-listen": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/hey-listen/-/hey-listen-1.0.8.tgz", - "integrity": "sha512-COpmrF2NOg4TBWUJ5UVyaCU2A88wEMkUPK4hNqyCkqHbxT92BbvfjoSozkAIIm6XhicGlJHhFdullInrdhwU8Q==" - }, - "node_modules/highlight-words-core": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/highlight-words-core/-/highlight-words-core-1.2.2.tgz", - "integrity": "sha512-BXUKIkUuh6cmmxzi5OIbUJxrG8OAk2MqoL1DtO3Wo9D2faJg2ph5ntyuQeLqaHJmzER6H5tllCDA9ZnNe9BVGg==" - }, - "node_modules/hogan.js": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/hogan.js/-/hogan.js-3.0.2.tgz", - "integrity": "sha512-RqGs4wavGYJWE07t35JQccByczmNUXQT0E12ZYV1VKYu5UiAU9lsos/yBAcf840+zrUQQxgVduCR5/B8nNtibg==", - "dependencies": { - "mkdirp": "0.3.0", - "nopt": "1.0.10" - }, - "bin": { - "hulk": "bin/hulk" - } - }, - "node_modules/hoist-non-react-statics": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz", - "integrity": "sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw==", - "dependencies": { - "react-is": "^16.7.0" - } - }, - "node_modules/hoist-non-react-statics/node_modules/react-is": { - "version": "16.13.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", - "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==" - }, - "node_modules/homedir-polyfill": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz", - "integrity": "sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA==", - "dev": true, - "dependencies": { - "parse-passwd": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/hosted-git-info": { - "version": "2.8.9", - "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.9.tgz", - "integrity": "sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==", - "dev": true - }, - "node_modules/hpack.js": { - "version": "2.1.6", - "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz", - "integrity": "sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ==", - "dev": true, - "dependencies": { - "inherits": "^2.0.1", - "obuf": "^1.0.0", - "readable-stream": "^2.0.1", - "wbuf": "^1.1.0" - } - }, - "node_modules/hpack.js/node_modules/readable-stream": { - "version": "2.3.7", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", - "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", - "dev": true, - "dependencies": { - "core-util-is": "~1.0.0", - "inherits": "~2.0.3", - "isarray": "~1.0.0", - "process-nextick-args": "~2.0.0", - "safe-buffer": "~5.1.1", - "string_decoder": "~1.1.1", - "util-deprecate": "~1.0.1" - } - }, - "node_modules/hpack.js/node_modules/safe-buffer": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", - "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", - "dev": true - }, - "node_modules/hpack.js/node_modules/string_decoder": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", - "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", - "dev": true, - "dependencies": { - "safe-buffer": "~5.1.0" - } - }, - "node_modules/hpq": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/hpq/-/hpq-1.3.0.tgz", - "integrity": "sha512-fvYTvdCFOWQupGxqkahrkA+ERBuMdzkxwtUdKrxR6rmMd4Pfl+iZ1QiQYoaZ0B/v0y59MOMnz3XFUWbT50/NWA==" - }, - "node_modules/htm": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/htm/-/htm-3.1.1.tgz", - "integrity": "sha512-983Vyg8NwUE7JkZ6NmOqpCZ+sh1bKv2iYTlUkzlWmA5JD2acKoxd4KVxbMmxX/85mtfdnDmTFoNKcg5DGAvxNQ==" - }, - "node_modules/html-encoding-sniffer": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz", - "integrity": "sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ==", - "dev": true, - "dependencies": { - "whatwg-encoding": "^1.0.5" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/html-entities": { - "version": "2.3.3", - "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-2.3.3.tgz", - "integrity": "sha512-DV5Ln36z34NNTDgnz0EWGBLZENelNAtkiFA4kyNOG2tDI6Mz1uSWiq1wAKdyjnJwyDiDO7Fa2SO1CTxPXL8VxA==", - "dev": true - }, - "node_modules/html-escaper": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.2.tgz", - "integrity": "sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==", - "dev": true - }, - "node_modules/html-tags": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/html-tags/-/html-tags-3.2.0.tgz", - "integrity": "sha512-vy7ClnArOZwCnqZgvv+ddgHgJiAFXe3Ge9ML5/mBctVJoUoYPCdxVucOywjDARn6CVoh3dRSFdPHy2sX80L0Wg==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/http-deceiver": { - "version": "1.2.7", - "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz", - "integrity": "sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw==", - "dev": true - }, - "node_modules/http-errors": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", - "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", - "dev": true, - "dependencies": { - "depd": "2.0.0", - "inherits": "2.0.4", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "toidentifier": "1.0.1" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/http-parser-js": { - "version": "0.5.8", - "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.5.8.tgz", - "integrity": "sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==", - "dev": true - }, - "node_modules/http-proxy": { - "version": "1.18.1", - "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.1.tgz", - "integrity": "sha512-7mz/721AbnJwIVbnaSv1Cz3Am0ZLT/UBwkC92VlxhXv/k/BBQfM2fXElQNC27BVGr0uwUpplYPQM9LnaBMR5NQ==", - "dev": true, - "dependencies": { - "eventemitter3": "^4.0.0", - "follow-redirects": "^1.0.0", - "requires-port": "^1.0.0" - }, - "engines": { - "node": ">=8.0.0" - } - }, - "node_modules/http-proxy-agent": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz", - "integrity": "sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==", - "dev": true, - "dependencies": { - "@tootallnate/once": "1", - "agent-base": "6", - "debug": "4" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/http-proxy-middleware": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-2.0.6.tgz", - "integrity": "sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw==", - "dev": true, - "dependencies": { - "@types/http-proxy": "^1.17.8", - "http-proxy": "^1.18.1", - "is-glob": "^4.0.1", - "is-plain-obj": "^3.0.0", - "micromatch": "^4.0.2" - }, - "engines": { - "node": ">=12.0.0" - }, - "peerDependencies": { - "@types/express": "^4.17.13" - }, - "peerDependenciesMeta": { - "@types/express": { - "optional": true - } - } - }, - "node_modules/https-proxy-agent": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/https-proxy-agent/-/https-proxy-agent-5.0.1.tgz", - "integrity": "sha512-dFcAjpTQFgoLMzC2VwU+C/CbS7uRL0lWmxDITmqm7C+7F0Odmj6s9l6alZc6AELXhrnggM2CeWSXHGOdX2YtwA==", - "dev": true, - "dependencies": { - "agent-base": "6", - "debug": "4" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/human-signals": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/human-signals/-/human-signals-2.1.0.tgz", - "integrity": "sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==", - "dev": true, - "engines": { - "node": ">=10.17.0" - } - }, - "node_modules/iconv-lite": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.6.3.tgz", - "integrity": "sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==", - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/icss-utils": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz", - "integrity": "sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >= 14" - }, - "peerDependencies": { - "postcss": "^8.1.0" - } - }, - "node_modules/ieee754": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.2.1.tgz", - "integrity": "sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/ignore": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.1.tgz", - "integrity": "sha512-d2qQLzTJ9WxQftPAuEQpSPmKqzxePjzVbpAVv62AQ64NTL+wR4JkrVqR/LqFsFEUsHDAiId52mJteHDFuDkElA==", - "dev": true, - "engines": { - "node": ">= 4" - } - }, - "node_modules/ignore-walk": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-4.0.1.tgz", - "integrity": "sha512-rzDQLaW4jQbh2YrOFlJdCtX8qgJTehFRYiUB2r1osqTeDzV/3+Jh8fz1oAPzUThf3iku8Ds4IDqawI5d8mUiQw==", - "dev": true, - "dependencies": { - "minimatch": "^3.0.4" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/immutable": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/immutable/-/immutable-4.1.0.tgz", - "integrity": "sha512-oNkuqVTA8jqG1Q6c+UglTOD1xhC1BtjKI7XkCXRkZHrN5m18/XsnUp8Q89GkQO/z+0WjonSvl0FLhDYftp46nQ==", - "dev": true - }, - "node_modules/import-fresh": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.3.0.tgz", - "integrity": "sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==", - "dependencies": { - "parent-module": "^1.0.0", - "resolve-from": "^4.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/import-lazy": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/import-lazy/-/import-lazy-4.0.0.tgz", - "integrity": "sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/import-local": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/import-local/-/import-local-3.1.0.tgz", - "integrity": "sha512-ASB07uLtnDs1o6EHjKpX34BKYDSqnFerfTOJL2HvMqF70LnxpjkzDB8J44oT9pu4AMPkQwf8jl6szgvNd2tRIg==", - "dev": true, - "dependencies": { - "pkg-dir": "^4.2.0", - "resolve-cwd": "^3.0.0" - }, - "bin": { - "import-local-fixture": "fixtures/cli.js" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/imurmurhash": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", - "integrity": "sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==", - "dev": true, - "engines": { - "node": ">=0.8.19" - } - }, - "node_modules/indent-string": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", - "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/inflight": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", - "integrity": "sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==", - "dev": true, - "dependencies": { - "once": "^1.3.0", - "wrappy": "1" - } - }, - "node_modules/inherits": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" - }, - "node_modules/ini": { - "version": "1.3.8", - "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.8.tgz", - "integrity": "sha512-JV/yugV2uzW5iMRSiZAyDtQd+nxtUnjeLt0acNdw98kKLrvuRVyB80tsREOE7yvGVgalhZ6RNXCmEHkUKBKxew==", - "dev": true - }, - "node_modules/instantsearch.js": { - "version": "4.55.0", - "resolved": "https://registry.npmjs.org/instantsearch.js/-/instantsearch.js-4.55.0.tgz", - "integrity": "sha512-jsxhPRgzL4C4cRjhkLm/AE9BO83o7bkL8GSHncSXu1sICBhy/6xxkv0x/bXI5PxYHhb9/PsEz5jblYn1lRwOLw==", - "dependencies": { - "@algolia/events": "^4.0.1", - "@algolia/ui-components-highlight-vdom": "^1.2.1", - "@algolia/ui-components-shared": "^1.2.1", - "@types/dom-speech-recognition": "^0.0.1", - "@types/google.maps": "^3.45.3", - "@types/hogan.js": "^3.0.0", - "@types/qs": "^6.5.3", - "algoliasearch-helper": "^3.11.3", - "hogan.js": "^3.0.2", - "htm": "^3.0.0", - "preact": "^10.10.0", - "qs": "^6.5.1 < 6.10", - "search-insights": "^2.6.0" - }, - "peerDependencies": { - "algoliasearch": ">= 3.1 < 6" - } - }, - "node_modules/instantsearch.js/node_modules/qs": { - "version": "6.9.7", - "resolved": "https://registry.npmjs.org/qs/-/qs-6.9.7.tgz", - "integrity": "sha512-IhMFgUmuNpyRfxA90umL7ByLlgRXu6tIfKPpF5TmcfRLlLCckfP/g3IQmju6jjpu+Hh8rA+2p6A27ZSPOOHdKw==", - "engines": { - "node": ">=0.6" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/internal-slot": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.4.tgz", - "integrity": "sha512-tA8URYccNzMo94s5MQZgH8NB/XTa6HsOo0MLfXTKKEnHVVdegzaQoFZ7Jp44bdvLvY2waT5dc+j5ICEswhi7UQ==", - "dev": true, - "dependencies": { - "get-intrinsic": "^1.1.3", - "has": "^1.0.3", - "side-channel": "^1.0.4" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/interpret": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/interpret/-/interpret-2.2.0.tgz", - "integrity": "sha512-Ju0Bz/cEia55xDwUWEa8+olFpCiQoypjnQySseKtmjNrnps3P+xfpUmGr90T7yjlVJmOtybRvPXhKMbHr+fWnw==", - "dev": true, - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/ipaddr.js": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-2.0.1.tgz", - "integrity": "sha512-1qTgH9NG+IIJ4yfKs2e6Pp1bZg8wbDbKHT21HrLIeYBTRLgMYKnMTPAuI3Lcs61nfx5h1xlXnbJtH1kX5/d/ng==", - "dev": true, - "engines": { - "node": ">= 10" - } - }, - "node_modules/irregular-plurals": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/irregular-plurals/-/irregular-plurals-3.3.0.tgz", - "integrity": "sha512-MVBLKUTangM3EfRPFROhmWQQKRDsrgI83J8GS3jXy+OwYqiR2/aoWndYQ5416jLE3uaGgLH7ncme3X9y09gZ3g==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-arrayish": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", - "integrity": "sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==" - }, - "node_modules/is-bigint": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/is-bigint/-/is-bigint-1.0.4.tgz", - "integrity": "sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==", - "dev": true, - "dependencies": { - "has-bigints": "^1.0.1" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-binary-path": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", - "dev": true, - "dependencies": { - "binary-extensions": "^2.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-boolean-object": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/is-boolean-object/-/is-boolean-object-1.1.2.tgz", - "integrity": "sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "has-tostringtag": "^1.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-buffer": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", - "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", - "dev": true - }, - "node_modules/is-callable": { - "version": "1.2.7", - "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", - "integrity": "sha512-1BC0BVFhS/p0qtw6enp8e+8OD0UrK0oFLztSjNzhcKA3WDuJxxAPXzPuPtKkjEY9UUoEWlX/8fgKeu2S8i9JTA==", - "dev": true, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-core-module": { - "version": "2.11.0", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz", - "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==", - "dependencies": { - "has": "^1.0.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-date-object": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", - "integrity": "sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==", - "dev": true, - "dependencies": { - "has-tostringtag": "^1.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-docker": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.2.1.tgz", - "integrity": "sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==", - "dev": true, - "bin": { - "is-docker": "cli.js" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/is-extendable": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", - "integrity": "sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-extglob": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-fullwidth-code-point": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", - "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-generator-fn": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", - "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dev": true, - "dependencies": { - "is-extglob": "^2.1.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-negative-zero": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", - "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", - "dev": true, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-number": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", - "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "dev": true, - "engines": { - "node": ">=0.12.0" - } - }, - "node_modules/is-number-object": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/is-number-object/-/is-number-object-1.0.7.tgz", - "integrity": "sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==", - "dev": true, - "dependencies": { - "has-tostringtag": "^1.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-path-cwd": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-2.2.0.tgz", - "integrity": "sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/is-path-in-cwd": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz", - "integrity": "sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ==", - "dev": true, - "dependencies": { - "is-path-inside": "^2.1.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/is-path-in-cwd/node_modules/is-path-inside": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-2.1.0.tgz", - "integrity": "sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg==", - "dev": true, - "dependencies": { - "path-is-inside": "^1.0.2" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/is-path-inside": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-3.0.3.tgz", - "integrity": "sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-plain-obj": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-3.0.0.tgz", - "integrity": "sha512-gwsOE28k+23GP1B6vFl1oVh/WOzmawBrKwo5Ev6wMKzPkaXaCDIQKzLnvsA42DRlbVTWorkgTKIviAKCWkfUwA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/is-plain-object": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-5.0.0.tgz", - "integrity": "sha512-VRSzKkbMm5jMDoKLbltAkFQ5Qr7VDiTFGXxYFXXowVj387GeGNOCsOH6Msy00SGZ3Fp84b1Naa1psqgcCIEP5Q==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-potential-custom-element-name": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz", - "integrity": "sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==", - "dev": true - }, - "node_modules/is-promise": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-4.0.0.tgz", - "integrity": "sha512-hvpoI6korhJMnej285dSg6nu1+e6uxs7zG3BYAm5byqDsgJNWwxzM6z6iZiAgQR4TJ30JmBTOwqZUw3WlyH3AQ==" - }, - "node_modules/is-regex": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.1.4.tgz", - "integrity": "sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "has-tostringtag": "^1.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-shared-array-buffer": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", - "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-stream": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-2.0.1.tgz", - "integrity": "sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/is-string": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.7.tgz", - "integrity": "sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==", - "dev": true, - "dependencies": { - "has-tostringtag": "^1.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-symbol": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.4.tgz", - "integrity": "sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==", - "dev": true, - "dependencies": { - "has-symbols": "^1.0.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-typedarray": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", - "integrity": "sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==", - "dev": true - }, - "node_modules/is-unicode-supported": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/is-unicode-supported/-/is-unicode-supported-0.1.0.tgz", - "integrity": "sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/is-weakref": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-weakref/-/is-weakref-1.0.2.tgz", - "integrity": "sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/is-windows": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-0.2.0.tgz", - "integrity": "sha512-n67eJYmXbniZB7RF4I/FTjK1s6RPOCTxhYrVYLRaCt3lF0mpWZPKr3T2LSZAqyjQsxR2qMmGYXXzK0YWwcPM1Q==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-wsl": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.2.0.tgz", - "integrity": "sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==", - "dev": true, - "dependencies": { - "is-docker": "^2.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/isarray": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", - "integrity": "sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==", - "dev": true - }, - "node_modules/isexe": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", - "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", - "dev": true - }, - "node_modules/isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/istanbul-lib-coverage": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz", - "integrity": "sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-instrument": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-5.2.1.tgz", - "integrity": "sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==", - "dev": true, - "dependencies": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", - "istanbul-lib-coverage": "^3.2.0", - "semver": "^6.3.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-report": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", - "integrity": "sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==", - "dev": true, - "dependencies": { - "istanbul-lib-coverage": "^3.0.0", - "make-dir": "^3.0.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-report/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-report/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/istanbul-lib-source-maps": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz", - "integrity": "sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw==", - "dev": true, - "dependencies": { - "debug": "^4.1.1", - "istanbul-lib-coverage": "^3.0.0", - "source-map": "^0.6.1" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/istanbul-lib-source-maps/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/istanbul-reports": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.5.tgz", - "integrity": "sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==", - "dev": true, - "dependencies": { - "html-escaper": "^2.0.0", - "istanbul-lib-report": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest/-/jest-27.5.1.tgz", - "integrity": "sha512-Yn0mADZB89zTtjkPJEXwrac3LHudkQMR+Paqa8uxJHCBr9agxztUifWCyiYrjhMPBoUVBjyny0I7XH6ozDr7QQ==", - "dev": true, - "dependencies": { - "@jest/core": "^27.5.1", - "import-local": "^3.0.2", - "jest-cli": "^27.5.1" - }, - "bin": { - "jest": "bin/jest.js" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/jest-changed-files": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-27.5.1.tgz", - "integrity": "sha512-buBLMiByfWGCoMsLLzGUUSpAmIAGnbR2KJoMN10ziLhOLvP4e0SlypHnAel8iqQXTrcbmfEY9sSqae5sgUsTvw==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "execa": "^5.0.0", - "throat": "^6.0.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-circus": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-circus/-/jest-circus-27.5.1.tgz", - "integrity": "sha512-D95R7x5UtlMA5iBYsOHFFbMD/GVA4R/Kdq15f7xYWUfWHBto9NYRsOvnSauTgdF+ogCpJ4tyKOXhUifxS65gdw==", - "dev": true, - "dependencies": { - "@jest/environment": "^27.5.1", - "@jest/test-result": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "chalk": "^4.0.0", - "co": "^4.6.0", - "dedent": "^0.7.0", - "expect": "^27.5.1", - "is-generator-fn": "^2.0.0", - "jest-each": "^27.5.1", - "jest-matcher-utils": "^27.5.1", - "jest-message-util": "^27.5.1", - "jest-runtime": "^27.5.1", - "jest-snapshot": "^27.5.1", - "jest-util": "^27.5.1", - "pretty-format": "^27.5.1", - "slash": "^3.0.0", - "stack-utils": "^2.0.3", - "throat": "^6.0.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-circus/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-circus/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-circus/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-circus/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-circus/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-circus/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-cli": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-27.5.1.tgz", - "integrity": "sha512-Hc6HOOwYq4/74/c62dEE3r5elx8wjYqxY0r0G/nFrLDPMFRu6RA/u8qINOIkvhxG7mMQ5EJsOGfRpI8L6eFUVw==", - "dev": true, - "dependencies": { - "@jest/core": "^27.5.1", - "@jest/test-result": "^27.5.1", - "@jest/types": "^27.5.1", - "chalk": "^4.0.0", - "exit": "^0.1.2", - "graceful-fs": "^4.2.9", - "import-local": "^3.0.2", - "jest-config": "^27.5.1", - "jest-util": "^27.5.1", - "jest-validate": "^27.5.1", - "prompts": "^2.0.1", - "yargs": "^16.2.0" - }, - "bin": { - "jest": "bin/jest.js" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "peerDependencies": { - "node-notifier": "^8.0.1 || ^9.0.0 || ^10.0.0" - }, - "peerDependenciesMeta": { - "node-notifier": { - "optional": true - } - } - }, - "node_modules/jest-cli/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-cli/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-cli/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-cli/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-cli/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-cli/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-config": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-27.5.1.tgz", - "integrity": "sha512-5sAsjm6tGdsVbW9ahcChPAFCk4IlkQUknH5AvKjuLTSlcO/wCZKyFdn7Rg0EkC+OGgWODEy2hDpWB1PgzH0JNA==", - "dev": true, - "dependencies": { - "@babel/core": "^7.8.0", - "@jest/test-sequencer": "^27.5.1", - "@jest/types": "^27.5.1", - "babel-jest": "^27.5.1", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "deepmerge": "^4.2.2", - "glob": "^7.1.1", - "graceful-fs": "^4.2.9", - "jest-circus": "^27.5.1", - "jest-environment-jsdom": "^27.5.1", - "jest-environment-node": "^27.5.1", - "jest-get-type": "^27.5.1", - "jest-jasmine2": "^27.5.1", - "jest-regex-util": "^27.5.1", - "jest-resolve": "^27.5.1", - "jest-runner": "^27.5.1", - "jest-util": "^27.5.1", - "jest-validate": "^27.5.1", - "micromatch": "^4.0.4", - "parse-json": "^5.2.0", - "pretty-format": "^27.5.1", - "slash": "^3.0.0", - "strip-json-comments": "^3.1.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "peerDependencies": { - "ts-node": ">=9.0.0" - }, - "peerDependenciesMeta": { - "ts-node": { - "optional": true - } - } - }, - "node_modules/jest-config/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-config/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-config/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-config/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-config/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-config/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-dev-server": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/jest-dev-server/-/jest-dev-server-6.2.0.tgz", - "integrity": "sha512-ZWh8CuvxwjhYfvw4tGeftziqIvw/26R6AG3OTgNTQeXul8aZz48RQjDpnlDwnWX53jxJJl9fcigqIdSU5lYZuw==", - "dev": true, - "dependencies": { - "chalk": "^4.1.2", - "cwd": "^0.10.0", - "find-process": "^1.4.7", - "prompts": "^2.4.2", - "spawnd": "^6.2.0", - "tree-kill": "^1.2.2", - "wait-on": "^6.0.1" - } - }, - "node_modules/jest-dev-server/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-dev-server/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-dev-server/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-dev-server/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-dev-server/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-dev-server/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-diff": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-27.5.1.tgz", - "integrity": "sha512-m0NvkX55LDt9T4mctTEgnZk3fmEg3NRYutvMPWM/0iPnkFj2wIeF45O1718cMSOFO1vINkqmxqD8vE37uTEbqw==", - "dev": true, - "dependencies": { - "chalk": "^4.0.0", - "diff-sequences": "^27.5.1", - "jest-get-type": "^27.5.1", - "pretty-format": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-diff/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-diff/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-diff/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-diff/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-diff/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-diff/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-docblock": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-27.5.1.tgz", - "integrity": "sha512-rl7hlABeTsRYxKiUfpHrQrG4e2obOiTQWfMEH3PxPjOtdsfLQO4ReWSZaQ7DETm4xu07rl4q/h4zcKXyU0/OzQ==", - "dev": true, - "dependencies": { - "detect-newline": "^3.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-each": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-27.5.1.tgz", - "integrity": "sha512-1Ff6p+FbhT/bXQnEouYy00bkNSY7OUpfIcmdl8vZ31A1UUaurOLPA8a8BbJOF2RDUElwJhmeaV7LnagI+5UwNQ==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "chalk": "^4.0.0", - "jest-get-type": "^27.5.1", - "jest-util": "^27.5.1", - "pretty-format": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-each/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-each/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-each/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-each/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-each/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-each/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-environment-jsdom": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-27.5.1.tgz", - "integrity": "sha512-TFBvkTC1Hnnnrka/fUb56atfDtJ9VMZ94JkjTbggl1PEpwrYtUBKMezB3inLmWqQsXYLcMwNoDQwoBTAvFfsfw==", - "dev": true, - "dependencies": { - "@jest/environment": "^27.5.1", - "@jest/fake-timers": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "jest-mock": "^27.5.1", - "jest-util": "^27.5.1", - "jsdom": "^16.6.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-environment-node": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-27.5.1.tgz", - "integrity": "sha512-Jt4ZUnxdOsTGwSRAfKEnE6BcwsSPNOijjwifq5sDFSA2kesnXTvNqKHYgM0hDq3549Uf/KzdXNYn4wMZJPlFLw==", - "dev": true, - "dependencies": { - "@jest/environment": "^27.5.1", - "@jest/fake-timers": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "jest-mock": "^27.5.1", - "jest-util": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-get-type": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-27.5.1.tgz", - "integrity": "sha512-2KY95ksYSaK7DMBWQn6dQz3kqAf3BB64y2udeG+hv4KfSOb9qwcYQstTJc1KCbsix+wLZWZYN8t7nwX3GOBLRw==", - "dev": true, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-haste-map": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-27.5.1.tgz", - "integrity": "sha512-7GgkZ4Fw4NFbMSDSpZwXeBiIbx+t/46nJ2QitkOjvwPYyZmqttu2TDSimMHP1EkPOi4xUZAN1doE5Vd25H4Jng==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "@types/graceful-fs": "^4.1.2", - "@types/node": "*", - "anymatch": "^3.0.3", - "fb-watchman": "^2.0.0", - "graceful-fs": "^4.2.9", - "jest-regex-util": "^27.5.1", - "jest-serializer": "^27.5.1", - "jest-util": "^27.5.1", - "jest-worker": "^27.5.1", - "micromatch": "^4.0.4", - "walker": "^1.0.7" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - }, - "optionalDependencies": { - "fsevents": "^2.3.2" - } - }, - "node_modules/jest-jasmine2": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-27.5.1.tgz", - "integrity": "sha512-jtq7VVyG8SqAorDpApwiJJImd0V2wv1xzdheGHRGyuT7gZm6gG47QEskOlzsN1PG/6WNaCo5pmwMHDf3AkG2pQ==", - "dev": true, - "dependencies": { - "@jest/environment": "^27.5.1", - "@jest/source-map": "^27.5.1", - "@jest/test-result": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "chalk": "^4.0.0", - "co": "^4.6.0", - "expect": "^27.5.1", - "is-generator-fn": "^2.0.0", - "jest-each": "^27.5.1", - "jest-matcher-utils": "^27.5.1", - "jest-message-util": "^27.5.1", - "jest-runtime": "^27.5.1", - "jest-snapshot": "^27.5.1", - "jest-util": "^27.5.1", - "pretty-format": "^27.5.1", - "throat": "^6.0.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-jasmine2/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-jasmine2/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-jasmine2/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-jasmine2/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-jasmine2/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-jasmine2/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-leak-detector": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-27.5.1.tgz", - "integrity": "sha512-POXfWAMvfU6WMUXftV4HolnJfnPOGEu10fscNCA76KBpRRhcMN2c8d3iT2pxQS3HLbA+5X4sOUPzYO2NUyIlHQ==", - "dev": true, - "dependencies": { - "jest-get-type": "^27.5.1", - "pretty-format": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-matcher-utils": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-27.5.1.tgz", - "integrity": "sha512-z2uTx/T6LBaCoNWNFWwChLBKYxTMcGBRjAt+2SbP929/Fflb9aa5LGma654Rz8z9HLxsrUaYzxE9T/EFIL/PAw==", - "dev": true, - "dependencies": { - "chalk": "^4.0.0", - "jest-diff": "^27.5.1", - "jest-get-type": "^27.5.1", - "pretty-format": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-matcher-utils/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-matcher-utils/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-matcher-utils/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-matcher-utils/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-matcher-utils/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-matcher-utils/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-message-util": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-27.5.1.tgz", - "integrity": "sha512-rMyFe1+jnyAAf+NHwTclDz0eAaLkVDdKVHHBFWsBWHnnh5YeJMNWWsv7AbFYXfK3oTqvL7VTWkhNLu1jX24D+g==", - "dev": true, - "dependencies": { - "@babel/code-frame": "^7.12.13", - "@jest/types": "^27.5.1", - "@types/stack-utils": "^2.0.0", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "micromatch": "^4.0.4", - "pretty-format": "^27.5.1", - "slash": "^3.0.0", - "stack-utils": "^2.0.3" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-message-util/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-message-util/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-message-util/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-message-util/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-message-util/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-message-util/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-mock": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-27.5.1.tgz", - "integrity": "sha512-K4jKbY1d4ENhbrG2zuPWaQBvDly+iZ2yAW+T1fATN78hc0sInwn7wZB8XtlNnvHug5RMwV897Xm4LqmPM4e2Og==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "@types/node": "*" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-pnp-resolver": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", - "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", - "dev": true, - "engines": { - "node": ">=6" - }, - "peerDependencies": { - "jest-resolve": "*" - }, - "peerDependenciesMeta": { - "jest-resolve": { - "optional": true - } - } - }, - "node_modules/jest-regex-util": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-27.5.1.tgz", - "integrity": "sha512-4bfKq2zie+x16okqDXjXn9ql2B0dScQu+vcwe4TvFVhkVyuWLqpZrZtXxLLWoXYgn0E87I6r6GRYHF7wFZBUvg==", - "dev": true, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-resolve": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-27.5.1.tgz", - "integrity": "sha512-FFDy8/9E6CV83IMbDpcjOhumAQPDyETnU2KZ1O98DwTnz8AOBsW/Xv3GySr1mOZdItLR+zDZ7I/UdTFbgSOVCw==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "chalk": "^4.0.0", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^27.5.1", - "jest-pnp-resolver": "^1.2.2", - "jest-util": "^27.5.1", - "jest-validate": "^27.5.1", - "resolve": "^1.20.0", - "resolve.exports": "^1.1.0", - "slash": "^3.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-resolve-dependencies": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-27.5.1.tgz", - "integrity": "sha512-QQOOdY4PE39iawDn5rzbIePNigfe5B9Z91GDD1ae/xNDlu9kaat8QQ5EKnNmVWPV54hUdxCVwwj6YMgR2O7IOg==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "jest-regex-util": "^27.5.1", - "jest-snapshot": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-resolve/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-resolve/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-resolve/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-resolve/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-resolve/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-resolve/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-runner": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-27.5.1.tgz", - "integrity": "sha512-g4NPsM4mFCOwFKXO4p/H/kWGdJp9V8kURY2lX8Me2drgXqG7rrZAx5kv+5H7wtt/cdFIjhqYx1HrlqWHaOvDaQ==", - "dev": true, - "dependencies": { - "@jest/console": "^27.5.1", - "@jest/environment": "^27.5.1", - "@jest/test-result": "^27.5.1", - "@jest/transform": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "chalk": "^4.0.0", - "emittery": "^0.8.1", - "graceful-fs": "^4.2.9", - "jest-docblock": "^27.5.1", - "jest-environment-jsdom": "^27.5.1", - "jest-environment-node": "^27.5.1", - "jest-haste-map": "^27.5.1", - "jest-leak-detector": "^27.5.1", - "jest-message-util": "^27.5.1", - "jest-resolve": "^27.5.1", - "jest-runtime": "^27.5.1", - "jest-util": "^27.5.1", - "jest-worker": "^27.5.1", - "source-map-support": "^0.5.6", - "throat": "^6.0.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-runner/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-runner/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-runner/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-runner/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-runner/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-runner/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-runtime": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-27.5.1.tgz", - "integrity": "sha512-o7gxw3Gf+H2IGt8fv0RiyE1+r83FJBRruoA+FXrlHw6xEyBsU8ugA6IPfTdVyA0w8HClpbK+DGJxH59UrNMx8A==", - "dev": true, - "dependencies": { - "@jest/environment": "^27.5.1", - "@jest/fake-timers": "^27.5.1", - "@jest/globals": "^27.5.1", - "@jest/source-map": "^27.5.1", - "@jest/test-result": "^27.5.1", - "@jest/transform": "^27.5.1", - "@jest/types": "^27.5.1", - "chalk": "^4.0.0", - "cjs-module-lexer": "^1.0.0", - "collect-v8-coverage": "^1.0.0", - "execa": "^5.0.0", - "glob": "^7.1.3", - "graceful-fs": "^4.2.9", - "jest-haste-map": "^27.5.1", - "jest-message-util": "^27.5.1", - "jest-mock": "^27.5.1", - "jest-regex-util": "^27.5.1", - "jest-resolve": "^27.5.1", - "jest-snapshot": "^27.5.1", - "jest-util": "^27.5.1", - "slash": "^3.0.0", - "strip-bom": "^4.0.0" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-runtime/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-runtime/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-runtime/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-runtime/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-runtime/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-runtime/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-serializer": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-27.5.1.tgz", - "integrity": "sha512-jZCyo6iIxO1aqUxpuBlwTDMkzOAJS4a3eYz3YzgxxVQFwLeSA7Jfq5cbqCY+JLvTDrWirgusI/0KwxKMgrdf7w==", - "dev": true, - "dependencies": { - "@types/node": "*", - "graceful-fs": "^4.2.9" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-snapshot": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-27.5.1.tgz", - "integrity": "sha512-yYykXI5a0I31xX67mgeLw1DZ0bJB+gpq5IpSuCAoyDi0+BhgU/RIrL+RTzDmkNTchvDFWKP8lp+w/42Z3us5sA==", - "dev": true, - "dependencies": { - "@babel/core": "^7.7.2", - "@babel/generator": "^7.7.2", - "@babel/plugin-syntax-typescript": "^7.7.2", - "@babel/traverse": "^7.7.2", - "@babel/types": "^7.0.0", - "@jest/transform": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/babel__traverse": "^7.0.4", - "@types/prettier": "^2.1.5", - "babel-preset-current-node-syntax": "^1.0.0", - "chalk": "^4.0.0", - "expect": "^27.5.1", - "graceful-fs": "^4.2.9", - "jest-diff": "^27.5.1", - "jest-get-type": "^27.5.1", - "jest-haste-map": "^27.5.1", - "jest-matcher-utils": "^27.5.1", - "jest-message-util": "^27.5.1", - "jest-util": "^27.5.1", - "natural-compare": "^1.4.0", - "pretty-format": "^27.5.1", - "semver": "^7.3.2" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-snapshot/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-snapshot/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-snapshot/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-snapshot/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-snapshot/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-snapshot/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/jest-snapshot/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/jest-snapshot/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-snapshot/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/jest-util": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-27.5.1.tgz", - "integrity": "sha512-Kv2o/8jNvX1MQ0KGtw480E/w4fBCDOnH6+6DmeKi6LZUIlKA5kwY0YNdlzaWTiVgxqAqik11QyxDOKk543aKXw==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "@types/node": "*", - "chalk": "^4.0.0", - "ci-info": "^3.2.0", - "graceful-fs": "^4.2.9", - "picomatch": "^2.2.3" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-util/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-util/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-util/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-util/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-util/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-util/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-validate": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-27.5.1.tgz", - "integrity": "sha512-thkNli0LYTmOI1tDB3FI1S1RTp/Bqyd9pTarJwL87OIBFuqEb5Apv5EaApEudYg4g86e3CT6kM0RowkhtEnCBQ==", - "dev": true, - "dependencies": { - "@jest/types": "^27.5.1", - "camelcase": "^6.2.0", - "chalk": "^4.0.0", - "jest-get-type": "^27.5.1", - "leven": "^3.1.0", - "pretty-format": "^27.5.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-validate/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-validate/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-validate/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-validate/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-validate/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-validate/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-watcher": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-27.5.1.tgz", - "integrity": "sha512-z676SuD6Z8o8qbmEGhoEUFOM1+jfEiL3DXHK/xgEiG2EyNYfFG60jluWcupY6dATjfEsKQuibReS1djInQnoVw==", - "dev": true, - "dependencies": { - "@jest/test-result": "^27.5.1", - "@jest/types": "^27.5.1", - "@types/node": "*", - "ansi-escapes": "^4.2.1", - "chalk": "^4.0.0", - "jest-util": "^27.5.1", - "string-length": "^4.0.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/jest-watcher/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/jest-watcher/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/jest-watcher/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/jest-watcher/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/jest-watcher/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-watcher/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-worker": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-27.5.1.tgz", - "integrity": "sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==", - "dev": true, - "dependencies": { - "@types/node": "*", - "merge-stream": "^2.0.0", - "supports-color": "^8.0.0" - }, - "engines": { - "node": ">= 10.13.0" - } - }, - "node_modules/jest-worker/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/jest-worker/node_modules/supports-color": { - "version": "8.1.1", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-8.1.1.tgz", - "integrity": "sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/supports-color?sponsor=1" - } - }, - "node_modules/joi": { - "version": "17.7.0", - "resolved": "https://registry.npmjs.org/joi/-/joi-17.7.0.tgz", - "integrity": "sha512-1/ugc8djfn93rTE3WRKdCzGGt/EtiYKxITMO4Wiv6q5JL1gl9ePt4kBsl1S499nbosspfctIQTpYIhSmHA3WAg==", - "dev": true, - "dependencies": { - "@hapi/hoek": "^9.0.0", - "@hapi/topo": "^5.0.0", - "@sideway/address": "^4.1.3", - "@sideway/formula": "^3.0.0", - "@sideway/pinpoint": "^2.0.0" - } - }, - "node_modules/js-sdsl": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/js-sdsl/-/js-sdsl-4.2.0.tgz", - "integrity": "sha512-dyBIzQBDkCqCu+0upx25Y2jGdbTGxE9fshMsCdK0ViOongpV+n5tXRcZY9v7CaVQ79AGS9KA1KHtojxiM7aXSQ==", - "dev": true, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/js-sdsl" - } - }, - "node_modules/js-tokens": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" - }, - "node_modules/js-yaml": { - "version": "3.14.1", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.14.1.tgz", - "integrity": "sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==", - "dev": true, - "dependencies": { - "argparse": "^1.0.7", - "esprima": "^4.0.0" - }, - "bin": { - "js-yaml": "bin/js-yaml.js" - } - }, - "node_modules/jsdoc-type-pratt-parser": { - "version": "2.2.5", - "resolved": "https://registry.npmjs.org/jsdoc-type-pratt-parser/-/jsdoc-type-pratt-parser-2.2.5.tgz", - "integrity": "sha512-2a6eRxSxp1BW040hFvaJxhsCMI9lT8QB8t14t+NY5tC5rckIR0U9cr2tjOeaFirmEOy6MHvmJnY7zTBHq431Lw==", - "dev": true, - "engines": { - "node": ">=12.0.0" - } - }, - "node_modules/jsdom": { - "version": "16.7.0", - "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-16.7.0.tgz", - "integrity": "sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw==", - "dev": true, - "dependencies": { - "abab": "^2.0.5", - "acorn": "^8.2.4", - "acorn-globals": "^6.0.0", - "cssom": "^0.4.4", - "cssstyle": "^2.3.0", - "data-urls": "^2.0.0", - "decimal.js": "^10.2.1", - "domexception": "^2.0.1", - "escodegen": "^2.0.0", - "form-data": "^3.0.0", - "html-encoding-sniffer": "^2.0.1", - "http-proxy-agent": "^4.0.1", - "https-proxy-agent": "^5.0.0", - "is-potential-custom-element-name": "^1.0.1", - "nwsapi": "^2.2.0", - "parse5": "6.0.1", - "saxes": "^5.0.1", - "symbol-tree": "^3.2.4", - "tough-cookie": "^4.0.0", - "w3c-hr-time": "^1.0.2", - "w3c-xmlserializer": "^2.0.0", - "webidl-conversions": "^6.1.0", - "whatwg-encoding": "^1.0.5", - "whatwg-mimetype": "^2.3.0", - "whatwg-url": "^8.5.0", - "ws": "^7.4.6", - "xml-name-validator": "^3.0.0" - }, - "engines": { - "node": ">=10" - }, - "peerDependencies": { - "canvas": "^2.5.0" - }, - "peerDependenciesMeta": { - "canvas": { - "optional": true - } - } - }, - "node_modules/jsesc": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", - "bin": { - "jsesc": "bin/jsesc" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/json-parse-even-better-errors": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz", - "integrity": "sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==" - }, - "node_modules/json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, - "node_modules/json-stable-stringify-without-jsonify": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", - "integrity": "sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==", - "dev": true - }, - "node_modules/json2php": { - "version": "0.0.5", - "resolved": "https://registry.npmjs.org/json2php/-/json2php-0.0.5.tgz", - "integrity": "sha512-jWpsGAYlQDKOjJcyq3rYaxcZ+5YMhZIKHKTjdIKJPI9zLSX+yRWHSSwtV8hvIg7YMhbKkgPO669Ve2ZgFK5C7w==", - "dev": true - }, - "node_modules/json5": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz", - "integrity": "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==", - "bin": { - "json5": "lib/cli.js" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/jsonc-parser": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.0.0.tgz", - "integrity": "sha512-fQzRfAbIBnR0IQvftw9FJveWiHp72Fg20giDrHz6TdfB12UH/uue0D3hm57UB5KgAVuniLMCaS8P1IMj9NR7cA==", - "dev": true - }, - "node_modules/jsx-ast-utils": { - "version": "3.3.3", - "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-3.3.3.tgz", - "integrity": "sha512-fYQHZTZ8jSfmWZ0iyzfwiU4WDX4HpHbMCZ3gPlWYiCl3BoeOTsqKBqnTVfH2rYT7eP5c3sVbeSPHnnJOaTrWiw==", - "dev": true, - "dependencies": { - "array-includes": "^3.1.5", - "object.assign": "^4.1.3" - }, - "engines": { - "node": ">=4.0" - } - }, - "node_modules/kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha512-NOW9QQXMoZGg/oqnVNoNTTIFEIid1627WCffUBJEdMxYApq7mNE7CpzucIPc+ZQg25Phej7IJSmX3hO+oblOtQ==", - "dev": true, - "dependencies": { - "is-buffer": "^1.1.5" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/kleur": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", - "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/klona": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/klona/-/klona-2.0.5.tgz", - "integrity": "sha512-pJiBpiXMbt7dkzXe8Ghj/u4FfXOOa98fPW+bihOJ4SjnoijweJrNThJfd3ifXpXhREjpoF2mZVH1GfS9LV3kHQ==", - "dev": true, - "engines": { - "node": ">= 8" - } - }, - "node_modules/known-css-properties": { - "version": "0.26.0", - "resolved": "https://registry.npmjs.org/known-css-properties/-/known-css-properties-0.26.0.tgz", - "integrity": "sha512-5FZRzrZzNTBruuurWpvZnvP9pum+fe0HcK8z/ooo+U+Hmp4vtbyp1/QDsqmufirXy4egGzbaH/y2uCZf+6W5Kg==", - "dev": true - }, - "node_modules/language-subtag-registry": { - "version": "0.3.22", - "resolved": "https://registry.npmjs.org/language-subtag-registry/-/language-subtag-registry-0.3.22.tgz", - "integrity": "sha512-tN0MCzyWnoz/4nHS6uxdlFWoUZT7ABptwKPQ52Ea7URk6vll88bWBVhodtnlfEuCcKWNGoc+uGbw1cwa9IKh/w==", - "dev": true - }, - "node_modules/language-tags": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/language-tags/-/language-tags-1.0.7.tgz", - "integrity": "sha512-bSytju1/657hFjgUzPAPqszxH62ouE8nQFoFaVlIQfne4wO/wXC9A4+m8jYve7YBBvi59eq0SUpcshvG8h5Usw==", - "dev": true, - "dependencies": { - "language-subtag-registry": "^0.3.20" - } - }, - "node_modules/lazy-cache": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", - "integrity": "sha512-RE2g0b5VGZsOCFOCgP7omTRYFqydmZkBwl5oNnQ1lDYC57uyO9KqNnNVxT7COSHTxrRCWVcAVOcbjk+tvh/rgQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/leven": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", - "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/levn": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/levn/-/levn-0.4.1.tgz", - "integrity": "sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ==", - "dev": true, - "dependencies": { - "prelude-ls": "^1.2.1", - "type-check": "~0.4.0" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/lilconfig": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-2.0.6.tgz", - "integrity": "sha512-9JROoBW7pobfsx+Sq2JsASvCo6Pfo6WWoUW79HuB1BCoBXD4PLWJPqDF6fNj67pqBYTbAHkE57M1kS/+L1neOg==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/line-height": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/line-height/-/line-height-0.3.1.tgz", - "integrity": "sha512-YExecgqPwnp5gplD2+Y8e8A5+jKpr25+DzMbFdI1/1UAr0FJrTFv4VkHLf8/6B590i1wUPJWMKKldkd/bdQ//w==", - "dependencies": { - "computed-style": "~0.1.3" - }, - "engines": { - "node": ">= 4.0.0" - } - }, - "node_modules/lines-and-columns": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.2.4.tgz", - "integrity": "sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==" - }, - "node_modules/linkify-it": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-3.0.3.tgz", - "integrity": "sha512-ynTsyrFSdE5oZ/O9GEf00kPngmOfVwazR5GKDq6EYfhlpFug3J2zybX56a2PRRpc9P+FuSoGNAwjlbDs9jJBPQ==", - "dev": true, - "dependencies": { - "uc.micro": "^1.0.1" - } - }, - "node_modules/loader-runner": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz", - "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==", - "dev": true, - "engines": { - "node": ">=6.11.5" - } - }, - "node_modules/loader-utils": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz", - "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==", - "dev": true, - "dependencies": { - "big.js": "^5.2.2", - "emojis-list": "^3.0.0", - "json5": "^2.1.2" - }, - "engines": { - "node": ">=8.9.0" - } - }, - "node_modules/locate-path": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", - "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", - "dev": true, - "dependencies": { - "p-locate": "^5.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/lodash": { - "version": "4.17.21", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.21.tgz", - "integrity": "sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==" - }, - "node_modules/lodash.debounce": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", - "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==" - }, - "node_modules/lodash.memoize": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", - "integrity": "sha512-t7j+NzmgnQzTAYXcsHYLgimltOV1MXHtlOWf6GjL9Kj8GK5FInw5JotxvbOs+IvV1/Dzo04/fCGfLVs7aXb4Ag==", - "dev": true - }, - "node_modules/lodash.merge": { - "version": "4.6.2", - "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz", - "integrity": "sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ==", - "dev": true - }, - "node_modules/lodash.truncate": { - "version": "4.4.2", - "resolved": "https://registry.npmjs.org/lodash.truncate/-/lodash.truncate-4.4.2.tgz", - "integrity": "sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw==", - "dev": true - }, - "node_modules/lodash.uniq": { - "version": "4.5.0", - "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz", - "integrity": "sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ==", - "dev": true - }, - "node_modules/log-symbols": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/log-symbols/-/log-symbols-4.1.0.tgz", - "integrity": "sha512-8XPvpAA8uyhfteu8pIvQxpJZ7SYYdpUivZpGy6sFsBuKRY/7rQGavedeB8aK+Zkyq6upMFVL/9AW6vOYzfRyLg==", - "dev": true, - "dependencies": { - "chalk": "^4.1.0", - "is-unicode-supported": "^0.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/log-symbols/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/log-symbols/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/log-symbols/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/log-symbols/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/log-symbols/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/log-symbols/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/loose-envify": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", - "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", - "dependencies": { - "js-tokens": "^3.0.0 || ^4.0.0" - }, - "bin": { - "loose-envify": "cli.js" - } - }, - "node_modules/lower-case": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.2.tgz", - "integrity": "sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==", - "dependencies": { - "tslib": "^2.0.3" - } - }, - "node_modules/lru-cache": { - "version": "4.1.5", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", - "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", - "dev": true, - "dependencies": { - "pseudomap": "^1.0.2", - "yallist": "^2.1.2" - } - }, - "node_modules/make-dir": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", - "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", - "dev": true, - "dependencies": { - "semver": "^6.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/makeerror": { - "version": "1.0.12", - "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.12.tgz", - "integrity": "sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg==", - "dev": true, - "dependencies": { - "tmpl": "1.0.5" - } - }, - "node_modules/map-obj": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/map-obj/-/map-obj-4.3.0.tgz", - "integrity": "sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/map-values": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/map-values/-/map-values-1.0.1.tgz", - "integrity": "sha512-BbShUnr5OartXJe1GeccAWtfro11hhgNJg6G9/UtWKjVGvV5U4C09cg5nk8JUevhXODaXY+hQ3xxMUKSs62ONQ==", - "dev": true - }, - "node_modules/markdown-it": { - "version": "12.3.2", - "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-12.3.2.tgz", - "integrity": "sha512-TchMembfxfNVpHkbtriWltGWc+m3xszaRD0CZup7GFFhzIgQqxIfn3eGj1yZpfuflzPvfkt611B2Q/Bsk1YnGg==", - "dev": true, - "dependencies": { - "argparse": "^2.0.1", - "entities": "~2.1.0", - "linkify-it": "^3.0.1", - "mdurl": "^1.0.1", - "uc.micro": "^1.0.5" - }, - "bin": { - "markdown-it": "bin/markdown-it.js" - } - }, - "node_modules/markdown-it/node_modules/argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true - }, - "node_modules/markdown-it/node_modules/entities": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/entities/-/entities-2.1.0.tgz", - "integrity": "sha512-hCx1oky9PFrJ611mf0ifBLBRW8lUUVRlFolb5gWRfIELabBlbp9xZvrqZLZAs+NxFnbfQoeGd8wDkygjg7U85w==", - "dev": true, - "funding": { - "url": "https://github.com/fb55/entities?sponsor=1" - } - }, - "node_modules/markdownlint": { - "version": "0.25.1", - "resolved": "https://registry.npmjs.org/markdownlint/-/markdownlint-0.25.1.tgz", - "integrity": "sha512-AG7UkLzNa1fxiOv5B+owPsPhtM4D6DoODhsJgiaNg1xowXovrYgOnLqAgOOFQpWOlHFVQUzjMY5ypNNTeov92g==", - "dev": true, - "dependencies": { - "markdown-it": "12.3.2" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/markdownlint-cli": { - "version": "0.31.1", - "resolved": "https://registry.npmjs.org/markdownlint-cli/-/markdownlint-cli-0.31.1.tgz", - "integrity": "sha512-keIOMwQn+Ch7MoBwA+TdkyVMuxAeZFEGmIIlvwgV0Z1TGS5MxPnRr29XCLhkNzCHU+uNKGjU+VEjLX+Z9kli6g==", - "dev": true, - "dependencies": { - "commander": "~9.0.0", - "get-stdin": "~9.0.0", - "glob": "~7.2.0", - "ignore": "~5.2.0", - "js-yaml": "^4.1.0", - "jsonc-parser": "~3.0.0", - "markdownlint": "~0.25.1", - "markdownlint-rule-helpers": "~0.16.0", - "minimatch": "~3.0.5", - "run-con": "~1.2.10" - }, - "bin": { - "markdownlint": "markdownlint.js" - }, - "engines": { - "node": ">=12" - } - }, - "node_modules/markdownlint-cli/node_modules/argparse": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", - "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true - }, - "node_modules/markdownlint-cli/node_modules/commander": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-9.0.0.tgz", - "integrity": "sha512-JJfP2saEKbQqvW+FI93OYUB4ByV5cizMpFMiiJI8xDbBvQvSkIk0VvQdn1CZ8mqAO8Loq2h0gYTYtDFUZUeERw==", - "dev": true, - "engines": { - "node": "^12.20.0 || >=14" - } - }, - "node_modules/markdownlint-cli/node_modules/js-yaml": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", - "integrity": "sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==", - "dev": true, - "dependencies": { - "argparse": "^2.0.1" - }, - "bin": { - "js-yaml": "bin/js-yaml.js" - } - }, - "node_modules/markdownlint-cli/node_modules/minimatch": { - "version": "3.0.8", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.8.tgz", - "integrity": "sha512-6FsRAQsxQ61mw+qP1ZzbL9Bc78x2p5OqNgNpnoAFLTrX8n5Kxph0CsnhmKKNXTWjXqU5L0pGPR7hYk+XWZr60Q==", - "dev": true, - "dependencies": { - "brace-expansion": "^1.1.7" - }, - "engines": { - "node": "*" - } - }, - "node_modules/markdownlint-rule-helpers": { - "version": "0.16.0", - "resolved": "https://registry.npmjs.org/markdownlint-rule-helpers/-/markdownlint-rule-helpers-0.16.0.tgz", - "integrity": "sha512-oEacRUVeTJ5D5hW1UYd2qExYI0oELdYK72k1TKGvIeYJIbqQWAz476NAc7LNixSySUhcNl++d02DvX0ccDk9/w==", - "dev": true - }, - "node_modules/mathml-tag-names": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/mathml-tag-names/-/mathml-tag-names-2.1.3.tgz", - "integrity": "sha512-APMBEanjybaPzUrfqU0IMU5I0AswKMH7k8OTLs0vvV4KZpExkTkY87nR/zpbuTPj+gARop7aGUbl11pnDfW6xg==", - "dev": true, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/wooorm" - } - }, - "node_modules/mdn-data": { - "version": "2.0.14", - "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.14.tgz", - "integrity": "sha512-dn6wd0uw5GsdswPFfsgMp5NSB0/aDe6fK94YJV/AJDYXL6HVLWBsxeq7js7Ad+mU2K9LAlwpk6kN2D5mwCPVow==", - "dev": true - }, - "node_modules/mdurl": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-1.0.1.tgz", - "integrity": "sha512-/sKlQJCBYVY9Ers9hqzKou4H6V5UWc/M59TH2dvkt+84itfnq7uFOMLpOiOS4ujvHP4etln18fmIxA5R5fll0g==", - "dev": true - }, - "node_modules/media-typer": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", - "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/memfs": { - "version": "3.4.12", - "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.4.12.tgz", - "integrity": "sha512-BcjuQn6vfqP+k100e0E9m61Hyqa//Brp+I3f0OBmN0ATHlFA8vx3Lt8z57R3u2bPqe3WGDBC+nF72fTH7isyEw==", - "dev": true, - "dependencies": { - "fs-monkey": "^1.0.3" - }, - "engines": { - "node": ">= 4.0.0" - } - }, - "node_modules/memize": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/memize/-/memize-1.1.0.tgz", - "integrity": "sha512-K4FcPETOMTwe7KL2LK0orMhpOmWD2wRGwWWpbZy0fyArwsyIKR8YJVz8+efBAh3BO4zPqlSICu4vsLTRRqtFAg==" - }, - "node_modules/meow": { - "version": "6.1.1", - "resolved": "https://registry.npmjs.org/meow/-/meow-6.1.1.tgz", - "integrity": "sha512-3YffViIt2QWgTy6Pale5QpopX/IvU3LPL03jOTqp6pGj3VjesdO/U8CuHMKpnQr4shCNCM5fd5XFFvIIl6JBHg==", - "dev": true, - "dependencies": { - "@types/minimist": "^1.2.0", - "camelcase-keys": "^6.2.2", - "decamelize-keys": "^1.1.0", - "hard-rejection": "^2.1.0", - "minimist-options": "^4.0.2", - "normalize-package-data": "^2.5.0", - "read-pkg-up": "^7.0.1", - "redent": "^3.0.0", - "trim-newlines": "^3.0.0", - "type-fest": "^0.13.1", - "yargs-parser": "^18.1.3" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/meow/node_modules/type-fest": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.13.1.tgz", - "integrity": "sha512-34R7HTnG0XIJcBSn5XhDd7nNFPRcXYRZrBB2O2jdKqYODldSzBAqzsWoZYYvduky73toYS/ESqxPvkDf/F0XMg==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/merge-deep": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/merge-deep/-/merge-deep-3.0.3.tgz", - "integrity": "sha512-qtmzAS6t6grwEkNrunqTBdn0qKwFgNWvlxUbAV8es9M7Ot1EbyApytCnvE0jALPa46ZpKDUo527kKiaWplmlFA==", - "dev": true, - "dependencies": { - "arr-union": "^3.1.0", - "clone-deep": "^0.2.4", - "kind-of": "^3.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/merge-descriptors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", - "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==", - "dev": true - }, - "node_modules/merge-stream": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", - "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==", - "dev": true - }, - "node_modules/merge2": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.4.1.tgz", - "integrity": "sha512-8q7VEgMJW4J8tcfVPy8g09NcQwZdbwFEqhe/WZkoIzjn/3TGDwtOCYtXGxA3O8tPzpczCCDgv+P2P5y00ZJOOg==", - "dev": true, - "engines": { - "node": ">= 8" - } - }, - "node_modules/methods": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", - "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/micromatch": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-4.0.5.tgz", - "integrity": "sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==", - "dev": true, - "dependencies": { - "braces": "^3.0.2", - "picomatch": "^2.3.1" - }, - "engines": { - "node": ">=8.6" - } - }, - "node_modules/micromodal": { - "version": "0.4.10", - "resolved": "https://registry.npmjs.org/micromodal/-/micromodal-0.4.10.tgz", - "integrity": "sha512-BUrEnzMPFBwK8nOE4xUDYHLrlGlLULQVjpja99tpJQPSUEWgw3kTLp1n1qv0HmKU29AiHE7Y7sMLiRziDK4ghQ==", - "engines": { - "node": ">=10" - } - }, - "node_modules/mime": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", - "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", - "dev": true, - "bin": { - "mime": "cli.js" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/mime-db": { - "version": "1.52.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", - "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/mime-types": { - "version": "2.1.35", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", - "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", - "dev": true, - "dependencies": { - "mime-db": "1.52.0" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/mimic-fn": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", - "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/min-indent": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.1.tgz", - "integrity": "sha512-I9jwMn07Sy/IwOj3zVkVik2JTvgpaykDZEigL6Rx6N9LbMywwUSMtxET+7lVoDLLd3O3IXwJwvuuns8UB/HeAg==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/mini-css-extract-plugin": { - "version": "2.7.2", - "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.7.2.tgz", - "integrity": "sha512-EdlUizq13o0Pd+uCp+WO/JpkLvHRVGt97RqfeGhXqAcorYo1ypJSpkV+WDT0vY/kmh/p7wRdJNJtuyK540PXDw==", - "dev": true, - "dependencies": { - "schema-utils": "^4.0.0" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "^5.0.0" - } - }, - "node_modules/mini-css-extract-plugin/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.1", - "json-schema-traverse": "^1.0.0", - "require-from-string": "^2.0.2", - "uri-js": "^4.2.2" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/epoberezkin" - } - }, - "node_modules/mini-css-extract-plugin/node_modules/ajv-keywords": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz", - "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.3" - }, - "peerDependencies": { - "ajv": "^8.8.2" - } - }, - "node_modules/mini-css-extract-plugin/node_modules/json-schema-traverse": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", - "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", - "dev": true - }, - "node_modules/mini-css-extract-plugin/node_modules/schema-utils": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz", - "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==", - "dev": true, - "dependencies": { - "@types/json-schema": "^7.0.9", - "ajv": "^8.8.0", - "ajv-formats": "^2.1.1", - "ajv-keywords": "^5.0.0" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - } - }, - "node_modules/minimalistic-assert": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", - "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==", - "dev": true - }, - "node_modules/minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", - "dev": true, - "dependencies": { - "brace-expansion": "^1.1.7" - }, - "engines": { - "node": "*" - } - }, - "node_modules/minimist": { - "version": "1.2.7", - "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.7.tgz", - "integrity": "sha512-bzfL1YUZsP41gmu/qjrEk0Q6i2ix/cVeAhbCbqH9u3zYutS1cLg00qhrD0M2MVdCcx4Sc0UpP2eBWo9rotpq6g==", - "dev": true, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/minimist-options": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/minimist-options/-/minimist-options-4.1.0.tgz", - "integrity": "sha512-Q4r8ghd80yhO/0j1O3B2BjweX3fiHg9cdOwjJd2J76Q135c+NDxGCqdYKQ1SKBuFfgWbAUzBfvYjPUEeNgqN1A==", - "dev": true, - "dependencies": { - "arrify": "^1.0.1", - "is-plain-obj": "^1.1.0", - "kind-of": "^6.0.3" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/minimist-options/node_modules/is-plain-obj": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", - "integrity": "sha512-yvkRyxmFKEOQ4pNXCmJG5AEQNlXJS5LaONXo5/cLdTZdWvsZ1ioJEonLGAosKlMWE8lwUy/bJzMjcw8az73+Fg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/minimist-options/node_modules/kind-of": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", - "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/mixin-object": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/mixin-object/-/mixin-object-2.0.1.tgz", - "integrity": "sha512-ALGF1Jt9ouehcaXaHhn6t1yGWRqGaHkPFndtFVHfZXOvkIZ/yoGaSi0AHVTafb3ZBGg4dr/bDwnaEKqCXzchMA==", - "dev": true, - "dependencies": { - "for-in": "^0.1.3", - "is-extendable": "^0.1.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/mixin-object/node_modules/for-in": { - "version": "0.1.8", - "resolved": "https://registry.npmjs.org/for-in/-/for-in-0.1.8.tgz", - "integrity": "sha512-F0to7vbBSHP8E3l6dCjxNOLuSFAACIxFy3UehTUlG7svlXi37HHsDkyVcHo0Pq8QwrE+pXvWSVX3ZT1T9wAZ9g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/mkdirp": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.3.0.tgz", - "integrity": "sha512-OHsdUcVAQ6pOtg5JYWpCBo9W/GySVuwvP9hueRMW7UqshC0tbfzLv8wjySTPm3tfUZ/21CE9E1pJagOA91Pxew==", - "deprecated": "Legacy versions of mkdirp are no longer supported. Please update to mkdirp 1.x. (Note that the API surface has changed to use Promises in 1.x.)", - "engines": { - "node": "*" - } - }, - "node_modules/mkdirp-classic": { - "version": "0.5.3", - "resolved": "https://registry.npmjs.org/mkdirp-classic/-/mkdirp-classic-0.5.3.tgz", - "integrity": "sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==", - "dev": true - }, - "node_modules/moment": { - "version": "2.29.4", - "resolved": "https://registry.npmjs.org/moment/-/moment-2.29.4.tgz", - "integrity": "sha512-5LC9SOxjSc2HF6vO2CyuTDNivEdoz2IvyJJGj6X8DJ0eFyfszE0QiEd+iXmBvUP3WHxSjFH/vIsA0EN00cgr8w==", - "engines": { - "node": "*" - } - }, - "node_modules/moment-timezone": { - "version": "0.5.40", - "resolved": "https://registry.npmjs.org/moment-timezone/-/moment-timezone-0.5.40.tgz", - "integrity": "sha512-tWfmNkRYmBkPJz5mr9GVDn9vRlVZOTe6yqY92rFxiOdWXbjaR0+9LwQnZGGuNR63X456NqmEkbskte8tWL5ePg==", - "dependencies": { - "moment": ">= 2.9.0" - }, - "engines": { - "node": "*" - } - }, - "node_modules/mousetrap": { - "version": "1.6.5", - "resolved": "https://registry.npmjs.org/mousetrap/-/mousetrap-1.6.5.tgz", - "integrity": "sha512-QNo4kEepaIBwiT8CDhP98umTetp+JNfQYBWvC1pc6/OAibuXtRcxZ58Qz8skvEHYvURne/7R8T5VoOI7rDsEUA==" - }, - "node_modules/mrmime": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/mrmime/-/mrmime-1.0.1.tgz", - "integrity": "sha512-hzzEagAgDyoU1Q6yg5uI+AorQgdvMCur3FcKf7NhMKWsaYg+RnbTyHRa/9IlLF9rf455MOCtcqqrQQ83pPP7Uw==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/ms": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" - }, - "node_modules/multicast-dns": { - "version": "7.2.5", - "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-7.2.5.tgz", - "integrity": "sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg==", - "dev": true, - "dependencies": { - "dns-packet": "^5.2.2", - "thunky": "^1.0.2" - }, - "bin": { - "multicast-dns": "cli.js" - } - }, - "node_modules/nanoid": { - "version": "3.3.4", - "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz", - "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==", - "dev": true, - "bin": { - "nanoid": "bin/nanoid.cjs" - }, - "engines": { - "node": "^10 || ^12 || ^13.7 || ^14 || >=15.0.1" - } - }, - "node_modules/natural-compare": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", - "integrity": "sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==", - "dev": true - }, - "node_modules/natural-compare-lite": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/natural-compare-lite/-/natural-compare-lite-1.4.0.tgz", - "integrity": "sha512-Tj+HTDSJJKaZnfiuw+iaF9skdPpTo2GtEly5JHnWV/hfv2Qj/9RKsGISQtLh2ox3l5EAGw487hnBee0sIJ6v2g==", - "dev": true - }, - "node_modules/negotiator": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", - "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/neo-async": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.2.tgz", - "integrity": "sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==", - "dev": true - }, - "node_modules/no-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.4.tgz", - "integrity": "sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==", - "dependencies": { - "lower-case": "^2.0.2", - "tslib": "^2.0.3" - } - }, - "node_modules/node-fetch": { - "version": "2.6.7", - "resolved": "https://registry.npmjs.org/node-fetch/-/node-fetch-2.6.7.tgz", - "integrity": "sha512-ZjMPFEfVx5j+y2yF35Kzx5sF7kDzxuDj6ziH4FFbOp87zKDZNx8yExJIb05OGF4Nlt9IHFIMBkRl41VdvcNdbQ==", - "dev": true, - "dependencies": { - "whatwg-url": "^5.0.0" - }, - "engines": { - "node": "4.x || >=6.0.0" - }, - "peerDependencies": { - "encoding": "^0.1.0" - }, - "peerDependenciesMeta": { - "encoding": { - "optional": true - } - } - }, - "node_modules/node-fetch/node_modules/tr46": { - "version": "0.0.3", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-0.0.3.tgz", - "integrity": "sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==", - "dev": true - }, - "node_modules/node-fetch/node_modules/webidl-conversions": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-3.0.1.tgz", - "integrity": "sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==", - "dev": true - }, - "node_modules/node-fetch/node_modules/whatwg-url": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-5.0.0.tgz", - "integrity": "sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==", - "dev": true, - "dependencies": { - "tr46": "~0.0.3", - "webidl-conversions": "^3.0.0" - } - }, - "node_modules/node-forge": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-1.3.1.tgz", - "integrity": "sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==", - "dev": true, - "engines": { - "node": ">= 6.13.0" - } - }, - "node_modules/node-int64": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", - "integrity": "sha512-O5lz91xSOeoXP6DulyHfllpq+Eg00MWitZIbtPfoSEvqIHdl5gfcY6hYzDWnj0qD5tz52PI08u9qUvSVeUBeHw==", - "dev": true - }, - "node_modules/node-releases": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.7.tgz", - "integrity": "sha512-EJ3rzxL9pTWPjk5arA0s0dgXpnyiAbJDE6wHT62g7VsgrgQgmmZ+Ru++M1BFofncWja+Pnn3rEr3fieRySAdKQ==" - }, - "node_modules/nopt": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/nopt/-/nopt-1.0.10.tgz", - "integrity": "sha512-NWmpvLSqUrgrAC9HCuxEvb+PSloHpqVu+FqcO4eeF2h5qYRhA7ev6KvelyQAKtegUbC6RypJnlEOhd8vloNKYg==", - "dependencies": { - "abbrev": "1" - }, - "bin": { - "nopt": "bin/nopt.js" - }, - "engines": { - "node": "*" - } - }, - "node_modules/normalize-package-data": { - "version": "2.5.0", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", - "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", - "dev": true, - "dependencies": { - "hosted-git-info": "^2.1.4", - "resolve": "^1.10.0", - "semver": "2 || 3 || 4 || 5", - "validate-npm-package-license": "^3.0.1" - } - }, - "node_modules/normalize-package-data/node_modules/semver": { - "version": "5.7.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", - "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==", - "dev": true, - "bin": { - "semver": "bin/semver" - } - }, - "node_modules/normalize-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/normalize-range": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", - "integrity": "sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/normalize-url": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-6.1.0.tgz", - "integrity": "sha512-DlL+XwOy3NxAQ8xuC0okPgK46iuVNAK01YN7RueYBqqFeGsBjV9XmCAzAdgt+667bCl5kPh9EqKKDwnaPG1I7A==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/normalize-wheel": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/normalize-wheel/-/normalize-wheel-1.0.1.tgz", - "integrity": "sha512-1OnlAPZ3zgrk8B91HyRj+eVv+kS5u+Z0SCsak6Xil/kmgEia50ga7zfkumayonZrImffAxPU/5WcyGhzetHNPA==" - }, - "node_modules/npm-bundled": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.2.tgz", - "integrity": "sha512-x5DHup0SuyQcmL3s7Rx/YQ8sbw/Hzg0rj48eN0dV7hf5cmQq5PXIeioroH3raV1QC1yh3uTYuMThvEQF3iKgGQ==", - "dev": true, - "dependencies": { - "npm-normalize-package-bin": "^1.0.1" - } - }, - "node_modules/npm-normalize-package-bin": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", - "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==", - "dev": true - }, - "node_modules/npm-package-json-lint": { - "version": "5.4.2", - "resolved": "https://registry.npmjs.org/npm-package-json-lint/-/npm-package-json-lint-5.4.2.tgz", - "integrity": "sha512-DH1MSvYvm+cuQFXcPehIIu/WiYzMYs7BOxlhOOFHaH2SNrA+P2uDtTEe5LOG90Ci7PTwgF/dCmSKM2HWTgWXNA==", - "dev": true, - "dependencies": { - "ajv": "^6.12.6", - "ajv-errors": "^1.0.1", - "chalk": "^4.1.2", - "cosmiconfig": "^7.0.1", - "debug": "^4.3.2", - "globby": "^11.0.4", - "ignore": "^5.1.9", - "is-plain-obj": "^3.0.0", - "jsonc-parser": "^3.0.0", - "log-symbols": "^4.1.0", - "meow": "^6.1.1", - "plur": "^4.0.0", - "semver": "^7.3.5", - "slash": "^3.0.0", - "strip-json-comments": "^3.1.1" - }, - "bin": { - "npmPkgJsonLint": "src/cli.js" - }, - "engines": { - "node": ">=10.0.0", - "npm": ">=6.0.0" - } - }, - "node_modules/npm-package-json-lint/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/npm-package-json-lint/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/npm-package-json-lint/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/npm-package-json-lint/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/npm-package-json-lint/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/npm-package-json-lint/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/npm-package-json-lint/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/npm-package-json-lint/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/npm-package-json-lint/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/npm-packlist": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-3.0.0.tgz", - "integrity": "sha512-L/cbzmutAwII5glUcf2DBRNY/d0TFd4e/FnaZigJV6JD85RHZXJFGwCndjMWiiViiWSsWt3tiOLpI3ByTnIdFQ==", - "dev": true, - "dependencies": { - "glob": "^7.1.6", - "ignore-walk": "^4.0.1", - "npm-bundled": "^1.1.1", - "npm-normalize-package-bin": "^1.0.1" - }, - "bin": { - "npm-packlist": "bin/index.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/npm-run-path": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-4.0.1.tgz", - "integrity": "sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==", - "dev": true, - "dependencies": { - "path-key": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/nth-check": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-2.1.1.tgz", - "integrity": "sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==", - "dev": true, - "dependencies": { - "boolbase": "^1.0.0" - }, - "funding": { - "url": "https://github.com/fb55/nth-check?sponsor=1" - } - }, - "node_modules/nwsapi": { - "version": "2.2.2", - "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.2.tgz", - "integrity": "sha512-90yv+6538zuvUMnN+zCr8LuV6bPFdq50304114vJYJ8RDyK8D5O9Phpbd6SZWgI7PwzmmfN1upeOJlvybDSgCw==", - "dev": true - }, - "node_modules/object-assign": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/object-filter": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/object-filter/-/object-filter-1.0.2.tgz", - "integrity": "sha512-NahvP2vZcy1ZiiYah30CEPw0FpDcSkSePJBMpzl5EQgCmISijiGuJm3SPYp7U+Lf2TljyaIw3E5EgkEx/TNEVA==", - "dev": true - }, - "node_modules/object-inspect": { - "version": "1.12.2", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.12.2.tgz", - "integrity": "sha512-z+cPxW0QGUp0mcqcsgQyLVRDoXFQbXOwBaqyF7VIgI4TWNQsDHrBpUQslRmIfAoYWdYzs6UlKJtB2XJpTaNSpQ==", - "dev": true, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/object-keys": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", - "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==", - "dev": true, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/object.assign": { - "version": "4.1.4", - "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.4.tgz", - "integrity": "sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "has-symbols": "^1.0.3", - "object-keys": "^1.1.1" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/object.entries": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.6.tgz", - "integrity": "sha512-leTPzo4Zvg3pmbQ3rDK69Rl8GQvIqMWubrkxONG9/ojtFE2rD9fjMKfSI5BxW3osRH1m6VdzmqK8oAY9aT4x5w==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/object.fromentries": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.6.tgz", - "integrity": "sha512-VciD13dswC4j1Xt5394WR4MzmAQmlgN72phd/riNp9vtD7tp4QQWJ0R4wvclXcafgcYK8veHRed2W6XeGBvcfg==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/object.hasown": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/object.hasown/-/object.hasown-1.1.2.tgz", - "integrity": "sha512-B5UIT3J1W+WuWIU55h0mjlwaqxiE5vYENJXIXZ4VFe05pNYrkKuK0U/6aFcb0pKywYJh7IhfoqUfKVmrJJHZHw==", - "dev": true, - "dependencies": { - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/object.values": { - "version": "1.1.6", - "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.6.tgz", - "integrity": "sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/obuf": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz", - "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==", - "dev": true - }, - "node_modules/on-finished": { - "version": "2.4.1", - "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", - "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", - "dev": true, - "dependencies": { - "ee-first": "1.1.1" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/on-headers": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", - "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/once": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", - "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", - "dev": true, - "dependencies": { - "wrappy": "1" - } - }, - "node_modules/onetime": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.2.tgz", - "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", - "dev": true, - "dependencies": { - "mimic-fn": "^2.1.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/open": { - "version": "8.4.0", - "resolved": "https://registry.npmjs.org/open/-/open-8.4.0.tgz", - "integrity": "sha512-XgFPPM+B28FtCCgSb9I+s9szOC1vZRSwgWsRUA5ylIxRTgKozqjOCrVOqGsYABPYK5qnfqClxZTFBa8PKt2v6Q==", - "dev": true, - "dependencies": { - "define-lazy-prop": "^2.0.0", - "is-docker": "^2.1.1", - "is-wsl": "^2.2.0" - }, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/opener": { - "version": "1.5.2", - "resolved": "https://registry.npmjs.org/opener/-/opener-1.5.2.tgz", - "integrity": "sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A==", - "dev": true, - "bin": { - "opener": "bin/opener-bin.js" - } - }, - "node_modules/optionator": { - "version": "0.9.1", - "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.9.1.tgz", - "integrity": "sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw==", - "dev": true, - "dependencies": { - "deep-is": "^0.1.3", - "fast-levenshtein": "^2.0.6", - "levn": "^0.4.1", - "prelude-ls": "^1.2.1", - "type-check": "^0.4.0", - "word-wrap": "^1.2.3" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/os-homedir": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", - "integrity": "sha512-B5JU3cabzk8c67mRRd3ECmROafjYMXbuzlwtqdM8IbS8ktlTix8aFGb2bAGKrSRIlnfKwovGUUr72JUPyOb6kQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/p-limit": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", - "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", - "dev": true, - "dependencies": { - "yocto-queue": "^0.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/p-locate": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", - "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", - "dev": true, - "dependencies": { - "p-limit": "^3.0.2" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/p-map": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/p-map/-/p-map-2.1.0.tgz", - "integrity": "sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/p-retry": { - "version": "4.6.2", - "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-4.6.2.tgz", - "integrity": "sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==", - "dev": true, - "dependencies": { - "@types/retry": "0.12.0", - "retry": "^0.13.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/p-try": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", - "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", - "engines": { - "node": ">=6" - } - }, - "node_modules/param-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.4.tgz", - "integrity": "sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A==", - "dependencies": { - "dot-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/parent-module": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", - "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", - "dependencies": { - "callsites": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/parse-json": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.2.0.tgz", - "integrity": "sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==", - "dependencies": { - "@babel/code-frame": "^7.0.0", - "error-ex": "^1.3.1", - "json-parse-even-better-errors": "^2.3.0", - "lines-and-columns": "^1.1.6" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/parse-passwd": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", - "integrity": "sha512-1Y1A//QUXEZK7YKz+rD9WydcE1+EuPr6ZBgKecAB8tmoW6UFv0NREVJe1p+jRxtThkcbbKkfwIbWJe/IeE6m2Q==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/parse5": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/parse5/-/parse5-6.0.1.tgz", - "integrity": "sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==", - "dev": true - }, - "node_modules/parseurl": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", - "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/pascal-case": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.2.tgz", - "integrity": "sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/path-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/path-case/-/path-case-3.0.4.tgz", - "integrity": "sha512-qO4qCFjXqVTrcbPt/hQfhTQ+VhFsqNKOPtytgNKkKxSoEp3XPUQ8ObFuePylOIok5gjn69ry8XiULxCwot3Wfg==", - "dependencies": { - "dot-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/path-exists": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", - "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/path-is-absolute": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", - "integrity": "sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/path-is-inside": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", - "integrity": "sha512-DUWJr3+ULp4zXmol/SZkFf3JGsS9/SIv+Y3Rt93/UjPpDpklB5f1er4O3POIbUuUJ3FXgqte2Q7SrU6zAqwk8w==", - "dev": true - }, - "node_modules/path-key": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", - "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/path-parse": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.7.tgz", - "integrity": "sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==" - }, - "node_modules/path-to-regexp": { - "version": "0.1.7", - "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", - "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==", - "dev": true - }, - "node_modules/path-type": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", - "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==", - "engines": { - "node": ">=8" - } - }, - "node_modules/pend": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/pend/-/pend-1.2.0.tgz", - "integrity": "sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==", - "dev": true - }, - "node_modules/picocolors": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", - "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" - }, - "node_modules/picomatch": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", - "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "dev": true, - "engines": { - "node": ">=8.6" - }, - "funding": { - "url": "https://github.com/sponsors/jonschlinkert" - } - }, - "node_modules/pify": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", - "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/pinkie": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", - "integrity": "sha512-MnUuEycAemtSaeFSjXKW/aroV7akBbY+Sv+RkyqFjgAe73F+MR0TBWKBRDkmfWq/HiFmdavfZ1G7h4SPZXaCSg==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/pinkie-promise": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", - "integrity": "sha512-0Gni6D4UcLTbv9c57DfxDGdr41XfgUjqWZu492f0cIGr16zDU06BWP/RAEvOuo7CQ0CNjHaLlM59YJJFm3NWlw==", - "dev": true, - "dependencies": { - "pinkie": "^2.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/pirates": { - "version": "4.0.5", - "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.5.tgz", - "integrity": "sha512-8V9+HQPupnaXMA23c5hvl69zXvTwTzyAYasnkb0Tts4XvO4CliqONMOnvlq26rkhLC3nWDFBJf73LU1e1VZLaQ==", - "dev": true, - "engines": { - "node": ">= 6" - } - }, - "node_modules/pkg-dir": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", - "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", - "dev": true, - "dependencies": { - "find-up": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/pkg-dir/node_modules/find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dev": true, - "dependencies": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/pkg-dir/node_modules/locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dev": true, - "dependencies": { - "p-locate": "^4.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/pkg-dir/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dev": true, - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/pkg-dir/node_modules/p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dev": true, - "dependencies": { - "p-limit": "^2.2.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/plur": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/plur/-/plur-4.0.0.tgz", - "integrity": "sha512-4UGewrYgqDFw9vV6zNV+ADmPAUAfJPKtGvb/VdpQAx25X5f3xXdGdyOEVFwkl8Hl/tl7+xbeHqSEM+D5/TirUg==", - "dev": true, - "dependencies": { - "irregular-plurals": "^3.2.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/postcss": { - "version": "8.4.20", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.20.tgz", - "integrity": "sha512-6Q04AXR1212bXr5fh03u8aAwbLxAQNGQ/Q1LNa0VfOI06ZAlhPHtQvE4OIdpj4kLThXilalPnmDSOD65DcHt+g==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss" - } - ], - "dependencies": { - "nanoid": "^3.3.4", - "picocolors": "^1.0.0", - "source-map-js": "^1.0.2" - }, - "engines": { - "node": "^10 || ^12 || >=14" - } - }, - "node_modules/postcss-calc": { - "version": "8.2.4", - "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-8.2.4.tgz", - "integrity": "sha512-SmWMSJmB8MRnnULldx0lQIyhSNvuDl9HfrZkaqqE/WHAhToYsAvDq+yAsA/kIyINDszOp3Rh0GFoNuH5Ypsm3Q==", - "dev": true, - "dependencies": { - "postcss-selector-parser": "^6.0.9", - "postcss-value-parser": "^4.2.0" - }, - "peerDependencies": { - "postcss": "^8.2.2" - } - }, - "node_modules/postcss-colormin": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-5.3.0.tgz", - "integrity": "sha512-WdDO4gOFG2Z8n4P8TWBpshnL3JpmNmJwdnfP2gbk2qBA8PWwOYcmjmI/t3CmMeL72a7Hkd+x/Mg9O2/0rD54Pg==", - "dev": true, - "dependencies": { - "browserslist": "^4.16.6", - "caniuse-api": "^3.0.0", - "colord": "^2.9.1", - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-convert-values": { - "version": "5.1.3", - "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-5.1.3.tgz", - "integrity": "sha512-82pC1xkJZtcJEfiLw6UXnXVXScgtBrjlO5CBmuDQc+dlb88ZYheFsjTn40+zBVi3DkfF7iezO0nJUPLcJK3pvA==", - "dev": true, - "dependencies": { - "browserslist": "^4.21.4", - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-discard-comments": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-5.1.2.tgz", - "integrity": "sha512-+L8208OVbHVF2UQf1iDmRcbdjJkuBF6IS29yBDSiWUIzpYaAhtNl6JYnYm12FnkeCwQqF5LeklOu6rAqgfBZqQ==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-discard-duplicates": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-5.1.0.tgz", - "integrity": "sha512-zmX3IoSI2aoenxHV6C7plngHWWhUOV3sP1T8y2ifzxzbtnuhk1EdPwm0S1bIUNaJ2eNbWeGLEwzw8huPD67aQw==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-discard-empty": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-5.1.1.tgz", - "integrity": "sha512-zPz4WljiSuLWsI0ir4Mcnr4qQQ5e1Ukc3i7UfE2XcrwKK2LIPIqE5jxMRxO6GbI3cv//ztXDsXwEWT3BHOGh3A==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-discard-overridden": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-5.1.0.tgz", - "integrity": "sha512-21nOL7RqWR1kasIVdKs8HNqQJhFxLsyRfAnUDm4Fe4t4mCWL9OJiHvlHPjcd8zc5Myu89b/7wZDnOSjFgeWRtw==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-loader": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-6.2.1.tgz", - "integrity": "sha512-WbbYpmAaKcux/P66bZ40bpWsBucjx/TTgVVzRZ9yUO8yQfVBlameJ0ZGVaPfH64hNSBh63a+ICP5nqOpBA0w+Q==", - "dev": true, - "dependencies": { - "cosmiconfig": "^7.0.0", - "klona": "^2.0.5", - "semver": "^7.3.5" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "postcss": "^7.0.0 || ^8.0.1", - "webpack": "^5.0.0" - } - }, - "node_modules/postcss-loader/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/postcss-loader/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/postcss-loader/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/postcss-media-query-parser": { - "version": "0.2.3", - "resolved": "https://registry.npmjs.org/postcss-media-query-parser/-/postcss-media-query-parser-0.2.3.tgz", - "integrity": "sha512-3sOlxmbKcSHMjlUXQZKQ06jOswE7oVkXPxmZdoB1r5l0q6gTFTQSHxNxOrCccElbW7dxNytifNEo8qidX2Vsig==", - "dev": true - }, - "node_modules/postcss-merge-longhand": { - "version": "5.1.7", - "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-5.1.7.tgz", - "integrity": "sha512-YCI9gZB+PLNskrK0BB3/2OzPnGhPkBEwmwhfYk1ilBHYVAZB7/tkTHFBAnCrvBBOmeYyMYw3DMjT55SyxMBzjQ==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0", - "stylehacks": "^5.1.1" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-merge-rules": { - "version": "5.1.3", - "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-5.1.3.tgz", - "integrity": "sha512-LbLd7uFC00vpOuMvyZop8+vvhnfRGpp2S+IMQKeuOZZapPRY4SMq5ErjQeHbHsjCUgJkRNrlU+LmxsKIqPKQlA==", - "dev": true, - "dependencies": { - "browserslist": "^4.21.4", - "caniuse-api": "^3.0.0", - "cssnano-utils": "^3.1.0", - "postcss-selector-parser": "^6.0.5" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-minify-font-values": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-5.1.0.tgz", - "integrity": "sha512-el3mYTgx13ZAPPirSVsHqFzl+BBBDrXvbySvPGFnQcTI4iNslrPaFq4muTkLZmKlGk4gyFAYUBMH30+HurREyA==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-minify-gradients": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-5.1.1.tgz", - "integrity": "sha512-VGvXMTpCEo4qHTNSa9A0a3D+dxGFZCYwR6Jokk+/3oB6flu2/PnPXAh2x7x52EkY5xlIHLm+Le8tJxe/7TNhzw==", - "dev": true, - "dependencies": { - "colord": "^2.9.1", - "cssnano-utils": "^3.1.0", - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-minify-params": { - "version": "5.1.4", - "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-5.1.4.tgz", - "integrity": "sha512-+mePA3MgdmVmv6g+30rn57USjOGSAyuxUmkfiWpzalZ8aiBkdPYjXWtHuwJGm1v5Ojy0Z0LaSYhHaLJQB0P8Jw==", - "dev": true, - "dependencies": { - "browserslist": "^4.21.4", - "cssnano-utils": "^3.1.0", - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-minify-selectors": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-5.2.1.tgz", - "integrity": "sha512-nPJu7OjZJTsVUmPdm2TcaiohIwxP+v8ha9NehQ2ye9szv4orirRU3SDdtUmKH+10nzn0bAyOXZ0UEr7OpvLehg==", - "dev": true, - "dependencies": { - "postcss-selector-parser": "^6.0.5" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-modules-extract-imports": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz", - "integrity": "sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >= 14" - }, - "peerDependencies": { - "postcss": "^8.1.0" - } - }, - "node_modules/postcss-modules-local-by-default": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-4.0.0.tgz", - "integrity": "sha512-sT7ihtmGSF9yhm6ggikHdV0hlziDTX7oFoXtuVWeDd3hHObNkcHRo9V3yg7vCAY7cONyxJC/XXCmmiHHcvX7bQ==", - "dev": true, - "dependencies": { - "icss-utils": "^5.0.0", - "postcss-selector-parser": "^6.0.2", - "postcss-value-parser": "^4.1.0" - }, - "engines": { - "node": "^10 || ^12 || >= 14" - }, - "peerDependencies": { - "postcss": "^8.1.0" - } - }, - "node_modules/postcss-modules-scope": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-3.0.0.tgz", - "integrity": "sha512-hncihwFA2yPath8oZ15PZqvWGkWf+XUfQgUGamS4LqoP1anQLOsOJw0vr7J7IwLpoY9fatA2qiGUGmuZL0Iqlg==", - "dev": true, - "dependencies": { - "postcss-selector-parser": "^6.0.4" - }, - "engines": { - "node": "^10 || ^12 || >= 14" - }, - "peerDependencies": { - "postcss": "^8.1.0" - } - }, - "node_modules/postcss-modules-values": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-4.0.0.tgz", - "integrity": "sha512-RDxHkAiEGI78gS2ofyvCsu7iycRv7oqw5xMWn9iMoR0N/7mf9D50ecQqUo5BZ9Zh2vH4bCUR/ktCqbB9m8vJjQ==", - "dev": true, - "dependencies": { - "icss-utils": "^5.0.0" - }, - "engines": { - "node": "^10 || ^12 || >= 14" - }, - "peerDependencies": { - "postcss": "^8.1.0" - } - }, - "node_modules/postcss-normalize-charset": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-5.1.0.tgz", - "integrity": "sha512-mSgUJ+pd/ldRGVx26p2wz9dNZ7ji6Pn8VWBajMXFf8jk7vUoSrZ2lt/wZR7DtlZYKesmZI680qjr2CeFF2fbUg==", - "dev": true, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-display-values": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-normalize-display-values/-/postcss-normalize-display-values-5.1.0.tgz", - "integrity": "sha512-WP4KIM4o2dazQXWmFaqMmcvsKmhdINFblgSeRgn8BJ6vxaMyaJkwAzpPpuvSIoG/rmX3M+IrRZEz2H0glrQNEA==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-positions": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-normalize-positions/-/postcss-normalize-positions-5.1.1.tgz", - "integrity": "sha512-6UpCb0G4eofTCQLFVuI3EVNZzBNPiIKcA1AKVka+31fTVySphr3VUgAIULBhxZkKgwLImhzMR2Bw1ORK+37INg==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-repeat-style": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-5.1.1.tgz", - "integrity": "sha512-mFpLspGWkQtBcWIRFLmewo8aC3ImN2i/J3v8YCFUwDnPu3Xz4rLohDO26lGjwNsQxB3YF0KKRwspGzE2JEuS0g==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-string": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-normalize-string/-/postcss-normalize-string-5.1.0.tgz", - "integrity": "sha512-oYiIJOf4T9T1N4i+abeIc7Vgm/xPCGih4bZz5Nm0/ARVJ7K6xrDlLwvwqOydvyL3RHNf8qZk6vo3aatiw/go3w==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-timing-functions": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-5.1.0.tgz", - "integrity": "sha512-DOEkzJ4SAXv5xkHl0Wa9cZLF3WCBhF3o1SKVxKQAa+0pYKlueTpCgvkFAHfk+Y64ezX9+nITGrDZeVGgITJXjg==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-unicode": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-normalize-unicode/-/postcss-normalize-unicode-5.1.1.tgz", - "integrity": "sha512-qnCL5jzkNUmKVhZoENp1mJiGNPcsJCs1aaRmURmeJGES23Z/ajaln+EPTD+rBeNkSryI+2WTdW+lwcVdOikrpA==", - "dev": true, - "dependencies": { - "browserslist": "^4.21.4", - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-url": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-5.1.0.tgz", - "integrity": "sha512-5upGeDO+PVthOxSmds43ZeMeZfKH+/DKgGRD7TElkkyS46JXAUhMzIKiCa7BabPeIy3AQcTkXwVVN7DbqsiCew==", - "dev": true, - "dependencies": { - "normalize-url": "^6.0.1", - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-normalize-whitespace": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-normalize-whitespace/-/postcss-normalize-whitespace-5.1.1.tgz", - "integrity": "sha512-83ZJ4t3NUDETIHTa3uEg6asWjSBYL5EdkVB0sDncx9ERzOKBVJIUeDO9RyA9Zwtig8El1d79HBp0JEi8wvGQnA==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-ordered-values": { - "version": "5.1.3", - "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-5.1.3.tgz", - "integrity": "sha512-9UO79VUhPwEkzbb3RNpqqghc6lcYej1aveQteWY+4POIwlqkYE21HKWaLDF6lWNuqCobEAyTovVhtI32Rbv2RQ==", - "dev": true, - "dependencies": { - "cssnano-utils": "^3.1.0", - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-reduce-initial": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-5.1.1.tgz", - "integrity": "sha512-//jeDqWcHPuXGZLoolFrUXBDyuEGbr9S2rMo19bkTIjBQ4PqkaO+oI8wua5BOUxpfi97i3PCoInsiFIEBfkm9w==", - "dev": true, - "dependencies": { - "browserslist": "^4.21.4", - "caniuse-api": "^3.0.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-reduce-transforms": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-5.1.0.tgz", - "integrity": "sha512-2fbdbmgir5AvpW9RLtdONx1QoYG2/EtqpNQbFASDlixBbAYuTcJ0dECwlqNqH7VbaUnEnh8SrxOe2sRIn24XyQ==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-resolve-nested-selector": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/postcss-resolve-nested-selector/-/postcss-resolve-nested-selector-0.1.1.tgz", - "integrity": "sha512-HvExULSwLqHLgUy1rl3ANIqCsvMS0WHss2UOsXhXnQaZ9VCc2oBvIpXrl00IUFT5ZDITME0o6oiXeiHr2SAIfw==", - "dev": true - }, - "node_modules/postcss-safe-parser": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/postcss-safe-parser/-/postcss-safe-parser-6.0.0.tgz", - "integrity": "sha512-FARHN8pwH+WiS2OPCxJI8FuRJpTVnn6ZNFiqAM2aeW2LwTHWWmWgIyKC6cUo0L8aeKiF/14MNvnpls6R2PBeMQ==", - "dev": true, - "engines": { - "node": ">=12.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - "peerDependencies": { - "postcss": "^8.3.3" - } - }, - "node_modules/postcss-scss": { - "version": "4.0.6", - "resolved": "https://registry.npmjs.org/postcss-scss/-/postcss-scss-4.0.6.tgz", - "integrity": "sha512-rLDPhJY4z/i4nVFZ27j9GqLxj1pwxE80eAzUNRMXtcpipFYIeowerzBgG3yJhMtObGEXidtIgbUpQ3eLDsf5OQ==", - "dev": true, - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/postcss/" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/postcss-scss" - } - ], - "engines": { - "node": ">=12.0" - }, - "peerDependencies": { - "postcss": "^8.4.19" - } - }, - "node_modules/postcss-selector-parser": { - "version": "6.0.11", - "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.11.tgz", - "integrity": "sha512-zbARubNdogI9j7WY4nQJBiNqQf3sLS3wCP4WfOidu+p28LofJqDH1tcXypGrcmMHhDk2t9wGhCsYe/+szLTy1g==", - "dev": true, - "dependencies": { - "cssesc": "^3.0.0", - "util-deprecate": "^1.0.2" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/postcss-svgo": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-5.1.0.tgz", - "integrity": "sha512-D75KsH1zm5ZrHyxPakAxJWtkyXew5qwS70v56exwvw542d9CRtTo78K0WeFxZB4G7JXKKMbEZtZayTGdIky/eA==", - "dev": true, - "dependencies": { - "postcss-value-parser": "^4.2.0", - "svgo": "^2.7.0" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-unique-selectors": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-5.1.1.tgz", - "integrity": "sha512-5JiODlELrz8L2HwxfPnhOWZYWDxVHWL83ufOv84NrcgipI7TaeRsatAhK4Tr2/ZiYldpK/wBvw5BD3qfaK96GA==", - "dev": true, - "dependencies": { - "postcss-selector-parser": "^6.0.5" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/postcss-value-parser": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz", - "integrity": "sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==", - "dev": true - }, - "node_modules/preact": { - "version": "10.13.2", - "resolved": "https://registry.npmjs.org/preact/-/preact-10.13.2.tgz", - "integrity": "sha512-q44QFLhOhty2Bd0Y46fnYW0gD/cbVM9dUVtNTDKPcdXSMA7jfY+Jpd6rk3GB0lcQss0z5s/6CmVP0Z/hV+g6pw==", - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/preact" - } - }, - "node_modules/prelude-ls": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", - "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", - "dev": true, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/prettier": { - "name": "wp-prettier", - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/wp-prettier/-/wp-prettier-2.6.2.tgz", - "integrity": "sha512-AV33EzqiFJ3fj+mPlKABN59YFPReLkDxQnj067Z3uEOeRQf3g05WprL0RDuqM7UBhSRo9W1rMSC2KvZmjE5UOA==", - "dev": true - }, - "node_modules/prettier-linter-helpers": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", - "integrity": "sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==", - "dev": true, - "dependencies": { - "fast-diff": "^1.1.2" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/pretty-format": { - "version": "27.5.1", - "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-27.5.1.tgz", - "integrity": "sha512-Qb1gy5OrP5+zDf2Bvnzdl3jsTf1qXVMazbvCoKhtKqVs4/YK4ozX4gKQJJVyNe+cajNPn0KoC0MC3FUmaHWEmQ==", - "dev": true, - "dependencies": { - "ansi-regex": "^5.0.1", - "ansi-styles": "^5.0.0", - "react-is": "^17.0.1" - }, - "engines": { - "node": "^10.13.0 || ^12.13.0 || ^14.15.0 || >=15.0.0" - } - }, - "node_modules/pretty-format/node_modules/ansi-styles": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-5.2.0.tgz", - "integrity": "sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/process-nextick-args": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", - "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==", - "dev": true - }, - "node_modules/progress": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", - "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==", - "dev": true, - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/prompts": { - "version": "2.4.2", - "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.4.2.tgz", - "integrity": "sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q==", - "dev": true, - "dependencies": { - "kleur": "^3.0.3", - "sisteransi": "^1.0.5" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/prop-types": { - "version": "15.8.1", - "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.8.1.tgz", - "integrity": "sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg==", - "dependencies": { - "loose-envify": "^1.4.0", - "object-assign": "^4.1.1", - "react-is": "^16.13.1" - } - }, - "node_modules/prop-types/node_modules/react-is": { - "version": "16.13.1", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.13.1.tgz", - "integrity": "sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==" - }, - "node_modules/proxy-addr": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", - "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", - "dev": true, - "dependencies": { - "forwarded": "0.2.0", - "ipaddr.js": "1.9.1" - }, - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/proxy-addr/node_modules/ipaddr.js": { - "version": "1.9.1", - "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", - "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", - "dev": true, - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/proxy-compare": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/proxy-compare/-/proxy-compare-2.3.0.tgz", - "integrity": "sha512-c3L2CcAi7f7pvlD0D7xsF+2CQIW8C3HaYx2Pfgq8eA4HAl3GAH6/dVYsyBbYF/0XJs2ziGLrzmz5fmzPm6A0pQ==" - }, - "node_modules/proxy-from-env": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/proxy-from-env/-/proxy-from-env-1.1.0.tgz", - "integrity": "sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==", - "dev": true - }, - "node_modules/pseudomap": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/pseudomap/-/pseudomap-1.0.2.tgz", - "integrity": "sha512-b/YwNhb8lk1Zz2+bXXpS/LK9OisiZZ1SNsSLxN1x2OXVEhW2Ckr/7mWE5vrC1ZTiJlD9g19jWszTmJsB+oEpFQ==", - "dev": true - }, - "node_modules/psl": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/psl/-/psl-1.9.0.tgz", - "integrity": "sha512-E/ZsdU4HLs/68gYzgGTkMicWTLPdAftJLfJFlLUAAKZGkStNU72sZjT66SnMDVOfOWY/YAoiD7Jxa9iHvngcag==", - "dev": true - }, - "node_modules/pump": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", - "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", - "dev": true, - "dependencies": { - "end-of-stream": "^1.1.0", - "once": "^1.3.1" - } - }, - "node_modules/punycode": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", - "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/puppeteer-core": { - "version": "13.7.0", - "resolved": "https://registry.npmjs.org/puppeteer-core/-/puppeteer-core-13.7.0.tgz", - "integrity": "sha512-rXja4vcnAzFAP1OVLq/5dWNfwBGuzcOARJ6qGV7oAZhnLmVRU8G5MsdeQEAOy332ZhkIOnn9jp15R89LKHyp2Q==", - "dev": true, - "dependencies": { - "cross-fetch": "3.1.5", - "debug": "4.3.4", - "devtools-protocol": "0.0.981744", - "extract-zip": "2.0.1", - "https-proxy-agent": "5.0.1", - "pkg-dir": "4.2.0", - "progress": "2.0.3", - "proxy-from-env": "1.1.0", - "rimraf": "3.0.2", - "tar-fs": "2.1.1", - "unbzip2-stream": "1.4.3", - "ws": "8.5.0" - }, - "engines": { - "node": ">=10.18.1" - } - }, - "node_modules/puppeteer-core/node_modules/rimraf": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", - "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", - "dev": true, - "dependencies": { - "glob": "^7.1.3" - }, - "bin": { - "rimraf": "bin.js" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/puppeteer-core/node_modules/ws": { - "version": "8.5.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.5.0.tgz", - "integrity": "sha512-BWX0SWVgLPzYwF8lTzEy1egjhS4S4OEAHfsO8o65WOVsrnSRGaSiUaa9e0ggGlkMTtBlmOpEXiie9RUcBO86qg==", - "dev": true, - "engines": { - "node": ">=10.0.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": "^5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - }, - "node_modules/qs": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", - "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", - "dev": true, - "dependencies": { - "side-channel": "^1.0.4" - }, - "engines": { - "node": ">=0.6" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/querystringify": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.2.0.tgz", - "integrity": "sha512-FIqgj2EUvTa7R50u0rGsyTftzjYmv/a3hO345bZNrqabNqjtgiDMgmo4mkUjd+nzU5oF3dClKqFIPUKybUyqoQ==", - "dev": true - }, - "node_modules/queue-microtask": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/queue-microtask/-/queue-microtask-1.2.3.tgz", - "integrity": "sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/quick-lru": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/quick-lru/-/quick-lru-4.0.1.tgz", - "integrity": "sha512-ARhCpm70fzdcvNQfPoy49IaanKkTlRWF2JMzqhcJbhSFRZv7nPTvZJdcY7301IPmvW+/p0RgIWnQDLJxifsQ7g==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/randombytes": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", - "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", - "dev": true, - "dependencies": { - "safe-buffer": "^5.1.0" - } - }, - "node_modules/range-parser": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", - "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/raw-body": { - "version": "2.5.1", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.1.tgz", - "integrity": "sha512-qqJBtEyVgS0ZmPGdCFPWJ3FreoqvG4MVQln/kCgF7Olq95IbOp0/BWyMwbdtn4VTvkM8Y7khCQ2Xgk/tcrCXig==", - "dev": true, - "dependencies": { - "bytes": "3.1.2", - "http-errors": "2.0.0", - "iconv-lite": "0.4.24", - "unpipe": "1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/raw-body/node_modules/bytes": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", - "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/raw-body/node_modules/iconv-lite": { - "version": "0.4.24", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", - "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dev": true, - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/re-resizable": { - "version": "6.9.9", - "resolved": "https://registry.npmjs.org/re-resizable/-/re-resizable-6.9.9.tgz", - "integrity": "sha512-l+MBlKZffv/SicxDySKEEh42hR6m5bAHfNu3Tvxks2c4Ah+ldnWjfnVRwxo/nxF27SsUsxDS0raAzFuJNKABXA==", - "peerDependencies": { - "react": "^16.13.1 || ^17.0.0 || ^18.0.0", - "react-dom": "^16.13.1 || ^17.0.0 || ^18.0.0" - } - }, - "node_modules/react": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react/-/react-18.2.0.tgz", - "integrity": "sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==", - "dependencies": { - "loose-envify": "^1.1.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/react-autosize-textarea": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/react-autosize-textarea/-/react-autosize-textarea-7.1.0.tgz", - "integrity": "sha512-BHpjCDkuOlllZn3nLazY2F8oYO1tS2jHnWhcjTWQdcKiiMU6gHLNt/fzmqMSyerR0eTdKtfSIqtSeTtghNwS+g==", - "dependencies": { - "autosize": "^4.0.2", - "line-height": "^0.3.1", - "prop-types": "^15.5.6" - }, - "peerDependencies": { - "react": "^0.14.0 || ^15.0.0 || ^16.0.0", - "react-dom": "^0.14.0 || ^15.0.0 || ^16.0.0" - } - }, - "node_modules/react-colorful": { - "version": "5.6.1", - "resolved": "https://registry.npmjs.org/react-colorful/-/react-colorful-5.6.1.tgz", - "integrity": "sha512-1exovf0uGTGyq5mXQT0zgQ80uvj2PCwvF8zY1RN9/vbJVSjSo3fsB/4L3ObbF7u70NduSiK4xu4Y6q1MHoUGEw==", - "peerDependencies": { - "react": ">=16.8.0", - "react-dom": ">=16.8.0" - } - }, - "node_modules/react-dom": { - "version": "18.2.0", - "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-18.2.0.tgz", - "integrity": "sha512-6IMTriUmvsjHUjNtEDudZfuDQUoWXVxKHhlEGSk81n4YFS+r/Kl99wXiwlVXtPBtJenozv2P+hxDsw9eA7Xo6g==", - "dependencies": { - "loose-envify": "^1.1.0", - "scheduler": "^0.23.0" - }, - "peerDependencies": { - "react": "^18.2.0" - } - }, - "node_modules/react-easy-crop": { - "version": "4.6.3", - "resolved": "https://registry.npmjs.org/react-easy-crop/-/react-easy-crop-4.6.3.tgz", - "integrity": "sha512-xeP5Cq56xDK2QkGs6RIrVXQs7cDan9B16yUt/3XqFN7siSjLgXkDfKNri8eC8CFSd3AFs0NX6IpIeIPBf4PCBA==", - "dependencies": { - "normalize-wheel": "^1.0.1", - "tslib": "2.0.1" - }, - "peerDependencies": { - "react": ">=16.4.0", - "react-dom": ">=16.4.0" - } - }, - "node_modules/react-easy-crop/node_modules/tslib": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.0.1.tgz", - "integrity": "sha512-SgIkNheinmEBgx1IUNirK0TUD4X9yjjBRTqqjggWCU3pUEqIk3/Uwl3yRixYKT6WjQuGiwDv4NomL3wqRCj+CQ==" - }, - "node_modules/react-instantsearch-hooks": { - "version": "6.43.0", - "resolved": "https://registry.npmjs.org/react-instantsearch-hooks/-/react-instantsearch-hooks-6.43.0.tgz", - "integrity": "sha512-C8RtM/XSYubs2d6yqSq5ouHnECTH21VsCreeJYSYFRhgZlBnajQ6kbBPc/CAIwhPCnaAKJzGVRIo3J+DP6RweQ==", - "dependencies": { - "@babel/runtime": "^7.1.2", - "algoliasearch-helper": "^3.11.3", - "instantsearch.js": "4.55.0", - "use-sync-external-store": "^1.0.0" - }, - "peerDependencies": { - "algoliasearch": ">= 3.1 < 5", - "react": ">= 16.8.0 < 19" - } - }, - "node_modules/react-instantsearch-hooks-web": { - "version": "6.43.0", - "resolved": "https://registry.npmjs.org/react-instantsearch-hooks-web/-/react-instantsearch-hooks-web-6.43.0.tgz", - "integrity": "sha512-B6QYzYn74JELtA0FB7u3k+WzB8ZQ5mMiN7j6E6z6s7TJpTcie4Gi94h/OXf7h+O+sr1/v5psnngvWSqVFVZ2zA==", - "dependencies": { - "@babel/runtime": "^7.1.2", - "instantsearch.js": "4.55.0", - "react-instantsearch-hooks": "6.43.0" - }, - "peerDependencies": { - "algoliasearch": ">= 3.1 < 5", - "react": ">= 16.8.0 < 19", - "react-dom": ">= 16.8.0 < 19" - } - }, - "node_modules/react-is": { - "version": "17.0.2", - "resolved": "https://registry.npmjs.org/react-is/-/react-is-17.0.2.tgz", - "integrity": "sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==" - }, - "node_modules/react-refresh": { - "version": "0.10.0", - "resolved": "https://registry.npmjs.org/react-refresh/-/react-refresh-0.10.0.tgz", - "integrity": "sha512-PgidR3wST3dDYKr6b4pJoqQFpPGNKDSCDx4cZoshjXipw3LzO7mG1My2pwEzz2JVkF+inx3xRpDeQLFQGH/hsQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/react-router": { - "version": "6.6.2", - "resolved": "https://registry.npmjs.org/react-router/-/react-router-6.6.2.tgz", - "integrity": "sha512-uJPG55Pek3orClbURDvfljhqFvMgJRo59Pktywkk8hUUkTY2aRfza8Yhl/vZQXs+TNQyr6tu+uqz/fLxPICOGQ==", - "dependencies": { - "@remix-run/router": "1.2.1" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "react": ">=16.8" - } - }, - "node_modules/react-router-dom": { - "version": "6.6.2", - "resolved": "https://registry.npmjs.org/react-router-dom/-/react-router-dom-6.6.2.tgz", - "integrity": "sha512-6SCDXxRQqW5af8ImOqKza7icmQ47/EMbz572uFjzvcArg3lZ+04PxSPp8qGs+p2Y+q+b+S/AjXv8m8dyLndIIA==", - "dependencies": { - "@remix-run/router": "1.2.1", - "react-router": "6.6.2" - }, - "engines": { - "node": ">=14" - }, - "peerDependencies": { - "react": ">=16.8", - "react-dom": ">=16.8" - } - }, - "node_modules/read-pkg": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-5.2.0.tgz", - "integrity": "sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==", - "dev": true, - "dependencies": { - "@types/normalize-package-data": "^2.4.0", - "normalize-package-data": "^2.5.0", - "parse-json": "^5.0.0", - "type-fest": "^0.6.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/read-pkg-up": { - "version": "7.0.1", - "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-7.0.1.tgz", - "integrity": "sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg==", - "dev": true, - "dependencies": { - "find-up": "^4.1.0", - "read-pkg": "^5.2.0", - "type-fest": "^0.8.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/read-pkg-up/node_modules/find-up": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", - "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", - "dev": true, - "dependencies": { - "locate-path": "^5.0.0", - "path-exists": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/read-pkg-up/node_modules/locate-path": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", - "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", - "dev": true, - "dependencies": { - "p-locate": "^4.1.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/read-pkg-up/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dev": true, - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/read-pkg-up/node_modules/p-locate": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", - "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", - "dev": true, - "dependencies": { - "p-limit": "^2.2.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/read-pkg-up/node_modules/type-fest": { - "version": "0.8.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", - "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/read-pkg/node_modules/type-fest": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.6.0.tgz", - "integrity": "sha512-q+MB8nYR1KDLrgr4G5yemftpMC7/QLqVndBmEEdqzmNj5dcFOO4Oo8qlwZE3ULT3+Zim1F8Kq4cBnikNhlCMlg==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/readable-stream": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", - "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", - "dev": true, - "dependencies": { - "inherits": "^2.0.3", - "string_decoder": "^1.1.1", - "util-deprecate": "^1.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/readdirp": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", - "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dev": true, - "dependencies": { - "picomatch": "^2.2.1" - }, - "engines": { - "node": ">=8.10.0" - } - }, - "node_modules/reakit": { - "version": "1.3.11", - "resolved": "https://registry.npmjs.org/reakit/-/reakit-1.3.11.tgz", - "integrity": "sha512-mYxw2z0fsJNOQKAEn5FJCPTU3rcrY33YZ/HzoWqZX0G7FwySp1wkCYW79WhuYMNIUFQ8s3Baob1RtsEywmZSig==", - "dependencies": { - "@popperjs/core": "^2.5.4", - "body-scroll-lock": "^3.1.5", - "reakit-system": "^0.15.2", - "reakit-utils": "^0.15.2", - "reakit-warning": "^0.6.2" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/ariakit" - }, - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0", - "react-dom": "^16.8.0 || ^17.0.0" - } - }, - "node_modules/reakit/node_modules/reakit-system": { - "version": "0.15.2", - "resolved": "https://registry.npmjs.org/reakit-system/-/reakit-system-0.15.2.tgz", - "integrity": "sha512-TvRthEz0DmD0rcJkGamMYx+bATwnGNWJpe/lc8UV2Js8nnPvkaxrHk5fX9cVASFrWbaIyegZHCWUBfxr30bmmA==", - "dependencies": { - "reakit-utils": "^0.15.2" - }, - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0", - "react-dom": "^16.8.0 || ^17.0.0" - } - }, - "node_modules/reakit/node_modules/reakit-utils": { - "version": "0.15.2", - "resolved": "https://registry.npmjs.org/reakit-utils/-/reakit-utils-0.15.2.tgz", - "integrity": "sha512-i/RYkq+W6hvfFmXw5QW7zvfJJT/K8a4qZ0hjA79T61JAFPGt23DsfxwyBbyK91GZrJ9HMrXFVXWMovsKBc1qEQ==", - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0", - "react-dom": "^16.8.0 || ^17.0.0" - } - }, - "node_modules/reakit/node_modules/reakit-warning": { - "version": "0.6.2", - "resolved": "https://registry.npmjs.org/reakit-warning/-/reakit-warning-0.6.2.tgz", - "integrity": "sha512-z/3fvuc46DJyD3nJAUOto6inz2EbSQTjvI/KBQDqxwB0y02HDyeP8IWOJxvkuAUGkWpeSx+H3QWQFSNiPcHtmw==", - "dependencies": { - "reakit-utils": "^0.15.2" - }, - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0" - } - }, - "node_modules/rechoir": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/rechoir/-/rechoir-0.7.1.tgz", - "integrity": "sha512-/njmZ8s1wVeR6pjTZ+0nCnv8SpZNRMT2D1RLOJQESlYFDBvwpTA4KWJpZ+sBJ4+vhjILRcK7JIFdGCdxEAAitg==", - "dev": true, - "dependencies": { - "resolve": "^1.9.0" - }, - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/redent": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/redent/-/redent-3.0.0.tgz", - "integrity": "sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg==", - "dev": true, - "dependencies": { - "indent-string": "^4.0.0", - "strip-indent": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/redux": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/redux/-/redux-4.2.1.tgz", - "integrity": "sha512-LAUYz4lc+Do8/g7aeRa8JkyDErK6ekstQaqWQrNRW//MY1TvCEpMtpTWvlQ+FPbWCx+Xixu/6SHt5N0HR+SB4w==", - "dependencies": { - "@babel/runtime": "^7.9.2" - } - }, - "node_modules/regenerate": { - "version": "1.4.2", - "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.2.tgz", - "integrity": "sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==", - "dev": true - }, - "node_modules/regenerate-unicode-properties": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-10.1.0.tgz", - "integrity": "sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==", - "dev": true, - "dependencies": { - "regenerate": "^1.4.2" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/regenerator-runtime": { - "version": "0.13.11", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.11.tgz", - "integrity": "sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==" - }, - "node_modules/regenerator-transform": { - "version": "0.15.1", - "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.15.1.tgz", - "integrity": "sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==", - "dev": true, - "dependencies": { - "@babel/runtime": "^7.8.4" - } - }, - "node_modules/regexp.prototype.flags": { - "version": "1.4.3", - "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.4.3.tgz", - "integrity": "sha512-fjggEOO3slI6Wvgjwflkc4NFRCTZAu5CnNfBd5qOMYhWdn67nJBBu34/TkD++eeFmd8C9r9jfXJ27+nSiRkSUA==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.3", - "functions-have-names": "^1.2.2" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/regexpp": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.2.0.tgz", - "integrity": "sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/mysticatea" - } - }, - "node_modules/regexpu-core": { - "version": "5.2.2", - "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-5.2.2.tgz", - "integrity": "sha512-T0+1Zp2wjF/juXMrMxHxidqGYn8U4R+zleSJhX9tQ1PUsS8a9UtYfbsF9LdiVgNX3kiX8RNaKM42nfSgvFJjmw==", - "dev": true, - "dependencies": { - "regenerate": "^1.4.2", - "regenerate-unicode-properties": "^10.1.0", - "regjsgen": "^0.7.1", - "regjsparser": "^0.9.1", - "unicode-match-property-ecmascript": "^2.0.0", - "unicode-match-property-value-ecmascript": "^2.1.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/regextras": { - "version": "0.8.0", - "resolved": "https://registry.npmjs.org/regextras/-/regextras-0.8.0.tgz", - "integrity": "sha512-k519uI04Z3SaY0fLX843MRXnDeG2+vHOFsyhiPZvNLe7r8rD2YNRjq4BQLZZ0oAr2NrtvZlICsXysGNFPGa3CQ==", - "dev": true, - "engines": { - "node": ">=0.1.14" - } - }, - "node_modules/regjsgen": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.7.1.tgz", - "integrity": "sha512-RAt+8H2ZEzHeYWxZ3H2z6tF18zyyOnlcdaafLrm21Bguj7uZy6ULibiAFdXEtKQY4Sy7wDTwDiOazasMLc4KPA==", - "dev": true - }, - "node_modules/regjsparser": { - "version": "0.9.1", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.9.1.tgz", - "integrity": "sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==", - "dev": true, - "dependencies": { - "jsesc": "~0.5.0" - }, - "bin": { - "regjsparser": "bin/parser" - } - }, - "node_modules/regjsparser/node_modules/jsesc": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", - "integrity": "sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==", - "dev": true, - "bin": { - "jsesc": "bin/jsesc" - } - }, - "node_modules/rememo": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/rememo/-/rememo-4.0.2.tgz", - "integrity": "sha512-NVfSP9NstE3QPNs/TnegQY0vnJnstKQSpcrsI2kBTB3dB2PkdfKdTa+abbjMIDqpc63fE5LfjLgfMst0ULMFxQ==" - }, - "node_modules/remove-accents": { - "version": "0.4.4", - "resolved": "https://registry.npmjs.org/remove-accents/-/remove-accents-0.4.4.tgz", - "integrity": "sha512-EpFcOa/ISetVHEXqu+VwI96KZBmq+a8LJnGkaeFw45epGlxIZz5dhEEnNZMsQXgORu3qaMoLX4qJCzOik6ytAg==" - }, - "node_modules/requestidlecallback": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/requestidlecallback/-/requestidlecallback-0.3.0.tgz", - "integrity": "sha512-TWHFkT7S9p7IxLC5A1hYmAYQx2Eb9w1skrXmQ+dS1URyvR8tenMLl4lHbqEOUnpEYxNKpkVMXUgknVpBZWXXfQ==" - }, - "node_modules/require-directory": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", - "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/require-from-string": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", - "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/require-main-filename": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", - "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==" - }, - "node_modules/requireindex": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/requireindex/-/requireindex-1.2.0.tgz", - "integrity": "sha512-L9jEkOi3ASd9PYit2cwRfyppc9NoABujTP8/5gFcbERmo5jUoAKovIC3fsF17pkTnGsrByysqX+Kxd2OTNI1ww==", - "dev": true, - "engines": { - "node": ">=0.10.5" - } - }, - "node_modules/requires-port": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", - "integrity": "sha512-KigOCHcocU3XODJxsu8i/j8T9tzT4adHiecwORRQ0ZZFcp7ahwXuRU1m+yuO90C5ZUyGeGfocHDI14M3L3yDAQ==", - "dev": true - }, - "node_modules/resolve": { - "version": "1.22.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz", - "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==", - "dependencies": { - "is-core-module": "^2.9.0", - "path-parse": "^1.0.7", - "supports-preserve-symlinks-flag": "^1.0.0" - }, - "bin": { - "resolve": "bin/resolve" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/resolve-bin": { - "version": "0.4.3", - "resolved": "https://registry.npmjs.org/resolve-bin/-/resolve-bin-0.4.3.tgz", - "integrity": "sha512-9u8TMpc+SEHXxQXblXHz5yRvRZERkCZimFN9oz85QI3uhkh7nqfjm6OGTLg+8vucpXGcY4jLK6WkylPmt7GSvw==", - "dev": true, - "dependencies": { - "find-parent-dir": "~0.3.0" - } - }, - "node_modules/resolve-cwd": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-3.0.0.tgz", - "integrity": "sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==", - "dev": true, - "dependencies": { - "resolve-from": "^5.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/resolve-cwd/node_modules/resolve-from": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", - "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/resolve-dir": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-0.1.1.tgz", - "integrity": "sha512-QxMPqI6le2u0dCLyiGzgy92kjkkL6zO0XyvHzjdTNH3zM6e5Hz3BwG6+aEyNgiQ5Xz6PwTwgQEj3U50dByPKIA==", - "dev": true, - "dependencies": { - "expand-tilde": "^1.2.2", - "global-modules": "^0.2.3" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/resolve-from": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", - "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==", - "engines": { - "node": ">=4" - } - }, - "node_modules/resolve.exports": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-1.1.0.tgz", - "integrity": "sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/retry": { - "version": "0.13.1", - "resolved": "https://registry.npmjs.org/retry/-/retry-0.13.1.tgz", - "integrity": "sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==", - "dev": true, - "engines": { - "node": ">= 4" - } - }, - "node_modules/reusify": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/reusify/-/reusify-1.0.4.tgz", - "integrity": "sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==", - "dev": true, - "engines": { - "iojs": ">=1.0.0", - "node": ">=0.10.0" - } - }, - "node_modules/rimraf": { - "version": "2.7.1", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", - "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", - "dev": true, - "dependencies": { - "glob": "^7.1.3" - }, - "bin": { - "rimraf": "bin.js" - } - }, - "node_modules/run-con": { - "version": "1.2.11", - "resolved": "https://registry.npmjs.org/run-con/-/run-con-1.2.11.tgz", - "integrity": "sha512-NEMGsUT+cglWkzEr4IFK21P4Jca45HqiAbIIZIBdX5+UZTB24Mb/21iNGgz9xZa8tL6vbW7CXmq7MFN42+VjNQ==", - "dev": true, - "dependencies": { - "deep-extend": "^0.6.0", - "ini": "~3.0.0", - "minimist": "^1.2.6", - "strip-json-comments": "~3.1.1" - }, - "bin": { - "run-con": "cli.js" - } - }, - "node_modules/run-con/node_modules/ini": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/ini/-/ini-3.0.1.tgz", - "integrity": "sha512-it4HyVAUTKBc6m8e1iXWvXSTdndF7HbdN713+kvLrymxTaU4AUBWrJ4vEooP+V7fexnVD3LKcBshjGGPefSMUQ==", - "dev": true, - "engines": { - "node": "^12.13.0 || ^14.15.0 || >=16.0.0" - } - }, - "node_modules/run-parallel": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", - "integrity": "sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==", - "dev": true, - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ], - "dependencies": { - "queue-microtask": "^1.2.2" - } - }, - "node_modules/rungen": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/rungen/-/rungen-0.3.2.tgz", - "integrity": "sha512-zWl10xu2D7zoR8zSC2U6bg5bYF6T/Wk7rxwp8IPaJH7f0Ge21G03kNHVgHR7tyVkSSfAOG0Rqf/Cl38JftSmtw==" - }, - "node_modules/rxjs": { - "version": "7.8.0", - "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.0.tgz", - "integrity": "sha512-F2+gxDshqmIub1KdvZkaEfGDwLNpPvk9Fs6LD/MyQxNgMds/WH9OdDDXOmxUZpME+iSK3rQCctkL0DYyytUqMg==", - "dev": true, - "dependencies": { - "tslib": "^2.1.0" - } - }, - "node_modules/safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/safe-regex-test": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", - "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "get-intrinsic": "^1.1.3", - "is-regex": "^1.1.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/safer-buffer": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" - }, - "node_modules/sass": { - "version": "1.56.2", - "resolved": "https://registry.npmjs.org/sass/-/sass-1.56.2.tgz", - "integrity": "sha512-ciEJhnyCRwzlBCB+h5cCPM6ie/6f8HrhZMQOf5vlU60Y1bI1rx5Zb0vlDZvaycHsg/MqFfF1Eq2eokAa32iw8w==", - "dev": true, - "dependencies": { - "chokidar": ">=3.0.0 <4.0.0", - "immutable": "^4.0.0", - "source-map-js": ">=0.6.2 <2.0.0" - }, - "bin": { - "sass": "sass.js" - }, - "engines": { - "node": ">=12.0.0" - } - }, - "node_modules/sass-loader": { - "version": "12.6.0", - "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-12.6.0.tgz", - "integrity": "sha512-oLTaH0YCtX4cfnJZxKSLAyglED0naiYfNG1iXfU5w1LNZ+ukoA5DtyDIN5zmKVZwYNJP4KRc5Y3hkWga+7tYfA==", - "dev": true, - "dependencies": { - "klona": "^2.0.4", - "neo-async": "^2.6.2" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "fibers": ">= 3.1.0", - "node-sass": "^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0", - "sass": "^1.3.0", - "sass-embedded": "*", - "webpack": "^5.0.0" - }, - "peerDependenciesMeta": { - "fibers": { - "optional": true - }, - "node-sass": { - "optional": true - }, - "sass": { - "optional": true - }, - "sass-embedded": { - "optional": true - } - } - }, - "node_modules/saxes": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/saxes/-/saxes-5.0.1.tgz", - "integrity": "sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==", - "dev": true, - "dependencies": { - "xmlchars": "^2.2.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/scheduler": { - "version": "0.23.0", - "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", - "integrity": "sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==", - "dependencies": { - "loose-envify": "^1.1.0" - } - }, - "node_modules/schema-utils": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.1.1.tgz", - "integrity": "sha512-Y5PQxS4ITlC+EahLuXaY86TXfR7Dc5lw294alXOq86JAHCihAIZfqv8nNCWvaEJvaC51uN9hbLGeV0cFBdH+Fw==", - "dev": true, - "dependencies": { - "@types/json-schema": "^7.0.8", - "ajv": "^6.12.5", - "ajv-keywords": "^3.5.2" - }, - "engines": { - "node": ">= 10.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - } - }, - "node_modules/search-insights": { - "version": "2.6.0", - "resolved": "https://registry.npmjs.org/search-insights/-/search-insights-2.6.0.tgz", - "integrity": "sha512-vU2/fJ+h/Mkm/DJOe+EaM5cafJv/1rRTZpGJTuFPf/Q5LjzgMDsqPdSaZsAe+GAWHHsfsu+rQSAn6c8IGtBEVw==", - "engines": { - "node": ">=8.16.0" - } - }, - "node_modules/select": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/select/-/select-1.1.2.tgz", - "integrity": "sha512-OwpTSOfy6xSs1+pwcNrv0RBMOzI39Lp3qQKUTPVVPRjCdNa5JH/oPRiqsesIskK8TVgmRiHwO4KXlV2Li9dANA==" - }, - "node_modules/select-hose": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", - "integrity": "sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg==", - "dev": true - }, - "node_modules/selfsigned": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-2.1.1.tgz", - "integrity": "sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==", - "dev": true, - "dependencies": { - "node-forge": "^1" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/semver": { - "version": "6.3.0", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", - "bin": { - "semver": "bin/semver.js" - } - }, - "node_modules/send": { - "version": "0.18.0", - "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", - "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", - "dev": true, - "dependencies": { - "debug": "2.6.9", - "depd": "2.0.0", - "destroy": "1.2.0", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "etag": "~1.8.1", - "fresh": "0.5.2", - "http-errors": "2.0.0", - "mime": "1.6.0", - "ms": "2.1.3", - "on-finished": "2.4.1", - "range-parser": "~1.2.1", - "statuses": "2.0.1" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/send/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/send/node_modules/debug/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true - }, - "node_modules/send/node_modules/ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", - "dev": true - }, - "node_modules/sentence-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/sentence-case/-/sentence-case-3.0.4.tgz", - "integrity": "sha512-8LS0JInaQMCRoQ7YUytAo/xUu5W2XnQxV2HI/6uM6U7CITS1RqPElr30V6uIqyMKM9lJGRVFy5/4CuzcixNYSg==", - "dependencies": { - "no-case": "^3.0.4", - "tslib": "^2.0.3", - "upper-case-first": "^2.0.2" - } - }, - "node_modules/serialize-javascript": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-6.0.0.tgz", - "integrity": "sha512-Qr3TosvguFt8ePWqsvRfrKyQXIiW+nGbYpy8XK24NQHE83caxWt+mIymTT19DGFbNWNLfEwsrkSmN64lVWB9ag==", - "dev": true, - "dependencies": { - "randombytes": "^2.1.0" - } - }, - "node_modules/serve-index": { - "version": "1.9.1", - "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz", - "integrity": "sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw==", - "dev": true, - "dependencies": { - "accepts": "~1.3.4", - "batch": "0.6.1", - "debug": "2.6.9", - "escape-html": "~1.0.3", - "http-errors": "~1.6.2", - "mime-types": "~2.1.17", - "parseurl": "~1.3.2" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/serve-index/node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/serve-index/node_modules/depd": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", - "integrity": "sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/serve-index/node_modules/http-errors": { - "version": "1.6.3", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", - "integrity": "sha512-lks+lVC8dgGyh97jxvxeYTWQFvh4uw4yC12gVl63Cg30sjPX4wuGcdkICVXDAESr6OJGjqGA8Iz5mkeN6zlD7A==", - "dev": true, - "dependencies": { - "depd": "~1.1.2", - "inherits": "2.0.3", - "setprototypeof": "1.1.0", - "statuses": ">= 1.4.0 < 2" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/serve-index/node_modules/inherits": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", - "integrity": "sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==", - "dev": true - }, - "node_modules/serve-index/node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==", - "dev": true - }, - "node_modules/serve-index/node_modules/setprototypeof": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", - "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==", - "dev": true - }, - "node_modules/serve-index/node_modules/statuses": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", - "integrity": "sha512-OpZ3zP+jT1PI7I8nemJX4AKmAX070ZkYPVWV/AaKTJl+tXCTGyVdC1a4SL8RUQYEwk/f34ZX8UTykN68FwrqAA==", - "dev": true, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/serve-static": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", - "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", - "dev": true, - "dependencies": { - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "parseurl": "~1.3.3", - "send": "0.18.0" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/set-blocking": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", - "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==" - }, - "node_modules/setprototypeof": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", - "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", - "dev": true - }, - "node_modules/shallow-clone": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-0.1.2.tgz", - "integrity": "sha512-J1zdXCky5GmNnuauESROVu31MQSnLoYvlyEn6j2Ztk6Q5EHFIhxkMhYcv6vuDzl2XEzoRr856QwzMgWM/TmZgw==", - "dev": true, - "dependencies": { - "is-extendable": "^0.1.1", - "kind-of": "^2.0.1", - "lazy-cache": "^0.2.3", - "mixin-object": "^2.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/shallow-clone/node_modules/kind-of": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-2.0.1.tgz", - "integrity": "sha512-0u8i1NZ/mg0b+W3MGGw5I7+6Eib2nx72S/QvXa0hYjEkjTknYmEYQJwGu3mLC0BrhtJjtQafTkyRUQ75Kx0LVg==", - "dev": true, - "dependencies": { - "is-buffer": "^1.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/shallow-clone/node_modules/lazy-cache": { - "version": "0.2.7", - "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-0.2.7.tgz", - "integrity": "sha512-gkX52wvU/R8DVMMt78ATVPFMJqfW8FPz1GZ1sVHBVQHmu/WvhIWE4cE1GBzhJNFicDeYhnwp6Rl35BcAIM3YOQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/shebang-command": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", - "integrity": "sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==", - "dev": true, - "dependencies": { - "shebang-regex": "^1.0.0" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/shebang-regex": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", - "integrity": "sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/showdown": { - "version": "1.9.1", - "resolved": "https://registry.npmjs.org/showdown/-/showdown-1.9.1.tgz", - "integrity": "sha512-9cGuS382HcvExtf5AHk7Cb4pAeQQ+h0eTr33V1mu+crYWV4KvWAw6el92bDrqGEk5d46Ai/fhbEUwqJ/mTCNEA==", - "dependencies": { - "yargs": "^14.2" - }, - "bin": { - "showdown": "bin/showdown.js" - } - }, - "node_modules/showdown/node_modules/ansi-regex": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.1.tgz", - "integrity": "sha512-ILlv4k/3f6vfQ4OoP2AGvirOktlQ98ZEL1k9FaQjxa3L1abBgbuTDAdPOpvbGncC0BTVQrl+OM8xZGK6tWXt7g==", - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/cliui": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", - "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", - "dependencies": { - "string-width": "^3.1.0", - "strip-ansi": "^5.2.0", - "wrap-ansi": "^5.1.0" - } - }, - "node_modules/showdown/node_modules/emoji-regex": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", - "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" - }, - "node_modules/showdown/node_modules/find-up": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", - "dependencies": { - "locate-path": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/is-fullwidth-code-point": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", - "integrity": "sha512-VHskAKYM8RfSFXwee5t5cbN5PZeq1Wrh6qd5bkyiXIf6UQcN6w/A0eXM9r6t8d+GYOh+o6ZhiEnb88LN/Y8m2w==", - "engines": { - "node": ">=4" - } - }, - "node_modules/showdown/node_modules/locate-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", - "dependencies": { - "p-locate": "^3.0.0", - "path-exists": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/p-limit": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.3.0.tgz", - "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", - "dependencies": { - "p-try": "^2.0.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/showdown/node_modules/p-locate": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", - "dependencies": { - "p-limit": "^2.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/path-exists": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", - "integrity": "sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==", - "engines": { - "node": ">=4" - } - }, - "node_modules/showdown/node_modules/string-width": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", - "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", - "dependencies": { - "emoji-regex": "^7.0.1", - "is-fullwidth-code-point": "^2.0.0", - "strip-ansi": "^5.1.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/strip-ansi": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", - "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", - "dependencies": { - "ansi-regex": "^4.1.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/wrap-ansi": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", - "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", - "dependencies": { - "ansi-styles": "^3.2.0", - "string-width": "^3.0.0", - "strip-ansi": "^5.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/showdown/node_modules/y18n": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.3.tgz", - "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==" - }, - "node_modules/showdown/node_modules/yargs": { - "version": "14.2.3", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-14.2.3.tgz", - "integrity": "sha512-ZbotRWhF+lkjijC/VhmOT9wSgyBQ7+zr13+YLkhfsSiTriYsMzkTUFP18pFhWwBeMa5gUc1MzbhrO6/VB7c9Xg==", - "dependencies": { - "cliui": "^5.0.0", - "decamelize": "^1.2.0", - "find-up": "^3.0.0", - "get-caller-file": "^2.0.1", - "require-directory": "^2.1.1", - "require-main-filename": "^2.0.0", - "set-blocking": "^2.0.0", - "string-width": "^3.0.0", - "which-module": "^2.0.0", - "y18n": "^4.0.0", - "yargs-parser": "^15.0.1" - } - }, - "node_modules/showdown/node_modules/yargs-parser": { - "version": "15.0.3", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-15.0.3.tgz", - "integrity": "sha512-/MVEVjTXy/cGAjdtQf8dW3V9b97bPN7rNn8ETj6BmAQL7ibC7O1Q9SPJbGjgh3SlwoBNXMzj/ZGIj8mBgl12YA==", - "dependencies": { - "camelcase": "^5.0.0", - "decamelize": "^1.2.0" - } - }, - "node_modules/side-channel": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", - "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.0", - "get-intrinsic": "^1.0.2", - "object-inspect": "^1.9.0" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/signal-exit": { - "version": "3.0.7", - "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.7.tgz", - "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", - "dev": true - }, - "node_modules/simple-html-tokenizer": { - "version": "0.5.11", - "resolved": "https://registry.npmjs.org/simple-html-tokenizer/-/simple-html-tokenizer-0.5.11.tgz", - "integrity": "sha512-C2WEK/Z3HoSFbYq8tI7ni3eOo/NneSPRoPpcM7WdLjFOArFuyXEjAoCdOC3DgMfRyziZQ1hCNR4mrNdWEvD0og==" - }, - "node_modules/sirv": { - "version": "1.0.19", - "resolved": "https://registry.npmjs.org/sirv/-/sirv-1.0.19.tgz", - "integrity": "sha512-JuLThK3TnZG1TAKDwNIqNq6QA2afLOCcm+iE8D1Kj3GA40pSPsxQjjJl0J8X3tsR7T+CP1GavpzLwYkgVLWrZQ==", - "dev": true, - "dependencies": { - "@polka/url": "^1.0.0-next.20", - "mrmime": "^1.0.0", - "totalist": "^1.0.0" - }, - "engines": { - "node": ">= 10" - } - }, - "node_modules/sisteransi": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.5.tgz", - "integrity": "sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==", - "dev": true - }, - "node_modules/slash": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", - "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/slice-ansi": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-4.0.0.tgz", - "integrity": "sha512-qMCMfhY040cVHT43K9BFygqYbUPFZKHOg7K73mtTWJRb8pyP3fzf4Ixd5SzdEJQ6MRUg/WBnOLxghZtKKurENQ==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.0.0", - "astral-regex": "^2.0.0", - "is-fullwidth-code-point": "^3.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/slice-ansi?sponsor=1" - } - }, - "node_modules/slice-ansi/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/slice-ansi/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/slice-ansi/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/snake-case": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/snake-case/-/snake-case-3.0.4.tgz", - "integrity": "sha512-LAOh4z89bGQvl9pFfNF8V146i7o7/CqFPbqzYgP+yYzDIDeS9HaNFtXABamRW+AQzEVODcvE79ljJ+8a9YSdMg==", - "dependencies": { - "dot-case": "^3.0.4", - "tslib": "^2.0.3" - } - }, - "node_modules/sockjs": { - "version": "0.3.24", - "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.24.tgz", - "integrity": "sha512-GJgLTZ7vYb/JtPSSZ10hsOYIvEYsjbNU+zPdIHcUaWVNUEPivzxku31865sSSud0Da0W4lEeOPlmw93zLQchuQ==", - "dev": true, - "dependencies": { - "faye-websocket": "^0.11.3", - "uuid": "^8.3.2", - "websocket-driver": "^0.7.4" - } - }, - "node_modules/source-map": { - "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/source-map-js": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", - "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/source-map-loader": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/source-map-loader/-/source-map-loader-3.0.2.tgz", - "integrity": "sha512-BokxPoLjyl3iOrgkWaakaxqnelAJSS+0V+De0kKIq6lyWrXuiPgYTGp6z3iHmqljKAaLXwZa+ctD8GccRJeVvg==", - "dev": true, - "dependencies": { - "abab": "^2.0.5", - "iconv-lite": "^0.6.3", - "source-map-js": "^1.0.1" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "^5.0.0" - } - }, - "node_modules/source-map-support": { - "version": "0.5.21", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.21.tgz", - "integrity": "sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==", - "dev": true, - "dependencies": { - "buffer-from": "^1.0.0", - "source-map": "^0.6.0" - } - }, - "node_modules/source-map-support/node_modules/source-map": { - "version": "0.6.1", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", - "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/spawnd": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/spawnd/-/spawnd-6.2.0.tgz", - "integrity": "sha512-qX/I4lQy4KgVEcNle0kuc4FxFWHISzBhZW1YemPfwmrmQjyZmfTK/OhBKkhrD2ooAaFZEm1maEBLE6/6enwt+g==", - "dev": true, - "dependencies": { - "exit": "^0.1.2", - "signal-exit": "^3.0.7", - "tree-kill": "^1.2.2" - } - }, - "node_modules/spdx-correct": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.1.tgz", - "integrity": "sha512-cOYcUWwhCuHCXi49RhFRCyJEK3iPj1Ziz9DpViV3tbZOwXD49QzIN3MpOLJNxh2qwq2lJJZaKMVw9qNi4jTC0w==", - "dev": true, - "dependencies": { - "spdx-expression-parse": "^3.0.0", - "spdx-license-ids": "^3.0.0" - } - }, - "node_modules/spdx-exceptions": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", - "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", - "dev": true - }, - "node_modules/spdx-expression-parse": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.1.tgz", - "integrity": "sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==", - "dev": true, - "dependencies": { - "spdx-exceptions": "^2.1.0", - "spdx-license-ids": "^3.0.0" - } - }, - "node_modules/spdx-license-ids": { - "version": "3.0.12", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.12.tgz", - "integrity": "sha512-rr+VVSXtRhO4OHbXUiAF7xW3Bo9DuuF6C5jH+q/x15j2jniycgKbxU09Hr0WqlSLUs4i4ltHGXqTe7VHclYWyA==", - "dev": true - }, - "node_modules/spdy": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.2.tgz", - "integrity": "sha512-r46gZQZQV+Kl9oItvl1JZZqJKGr+oEkB08A6BzkiR7593/7IbtuncXHd2YoYeTsG4157ZssMu9KYvUHLcjcDoA==", - "dev": true, - "dependencies": { - "debug": "^4.1.0", - "handle-thing": "^2.0.0", - "http-deceiver": "^1.2.7", - "select-hose": "^2.0.0", - "spdy-transport": "^3.0.0" - }, - "engines": { - "node": ">=6.0.0" - } - }, - "node_modules/spdy-transport": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz", - "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==", - "dev": true, - "dependencies": { - "debug": "^4.1.0", - "detect-node": "^2.0.4", - "hpack.js": "^2.1.6", - "obuf": "^1.1.2", - "readable-stream": "^3.0.6", - "wbuf": "^1.7.3" - } - }, - "node_modules/sprintf-js": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.1.2.tgz", - "integrity": "sha512-VE0SOVEHCk7Qc8ulkWw3ntAzXuqf7S2lvwQaDLRnUeIEaKNQJzV6BwmLKhOqT61aGhfUMrXeaBk+oDGCzvhcug==" - }, - "node_modules/stable": { - "version": "0.1.8", - "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz", - "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==", - "deprecated": "Modern JS already guarantees Array#sort() is a stable sort, so this library is deprecated. See the compatibility table on MDN: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort#browser_compatibility", - "dev": true - }, - "node_modules/stack-utils": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-2.0.6.tgz", - "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", - "dev": true, - "dependencies": { - "escape-string-regexp": "^2.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/stack-utils/node_modules/escape-string-regexp": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", - "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/stackframe": { - "version": "1.3.4", - "resolved": "https://registry.npmjs.org/stackframe/-/stackframe-1.3.4.tgz", - "integrity": "sha512-oeVtt7eWQS+Na6F//S4kJ2K2VbRlS9D43mAlMyVpVWovy9o+jfgH8O9agzANzaiLjclA0oYzUXEM4PurhSUChw==", - "dev": true - }, - "node_modules/statuses": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", - "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dev": true, - "dependencies": { - "safe-buffer": "~5.2.0" - } - }, - "node_modules/string-length": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", - "integrity": "sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==", - "dev": true, - "dependencies": { - "char-regex": "^1.0.2", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/string-width": { - "version": "4.2.3", - "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", - "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", - "dev": true, - "dependencies": { - "emoji-regex": "^8.0.0", - "is-fullwidth-code-point": "^3.0.0", - "strip-ansi": "^6.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/string-width/node_modules/emoji-regex": { - "version": "8.0.0", - "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", - "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", - "dev": true - }, - "node_modules/string.prototype.matchall": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/string.prototype.matchall/-/string.prototype.matchall-4.0.8.tgz", - "integrity": "sha512-6zOCOcJ+RJAQshcTvXPHoxoQGONa3e/Lqx90wUA+wEzX78sg5Bo+1tQo4N0pohS0erG9qtCqJDjNCQBjeWVxyg==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4", - "get-intrinsic": "^1.1.3", - "has-symbols": "^1.0.3", - "internal-slot": "^1.0.3", - "regexp.prototype.flags": "^1.4.3", - "side-channel": "^1.0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/string.prototype.trimend": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.6.tgz", - "integrity": "sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/string.prototype.trimstart": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.6.tgz", - "integrity": "sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.1.4", - "es-abstract": "^1.20.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/strip-ansi": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", - "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", - "dev": true, - "dependencies": { - "ansi-regex": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-bom": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-4.0.0.tgz", - "integrity": "sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-final-newline": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/strip-final-newline/-/strip-final-newline-2.0.0.tgz", - "integrity": "sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/strip-indent": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz", - "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==", - "dev": true, - "dependencies": { - "min-indent": "^1.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/strip-json-comments": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.1.1.tgz", - "integrity": "sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==", - "dev": true, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/strip-outer": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/strip-outer/-/strip-outer-1.0.1.tgz", - "integrity": "sha512-k55yxKHwaXnpYGsOzg4Vl8+tDrWylxDEpknGjhTiZB8dFRU5rTo9CAzeycivxV3s+zlTKwrs6WxMxR95n26kwg==", - "dev": true, - "dependencies": { - "escape-string-regexp": "^1.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/strip-outer/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/style-search": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/style-search/-/style-search-0.1.0.tgz", - "integrity": "sha512-Dj1Okke1C3uKKwQcetra4jSuk0DqbzbYtXipzFlFMZtowbF1x7BKJwB9AayVMyFARvU8EDrZdcax4At/452cAg==", - "dev": true - }, - "node_modules/stylehacks": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-5.1.1.tgz", - "integrity": "sha512-sBpcd5Hx7G6seo7b1LkpttvTz7ikD0LlH5RmdcBNb6fFR0Fl7LQwHDFr300q4cwUqi+IYrFGmsIHieMBfnN/Bw==", - "dev": true, - "dependencies": { - "browserslist": "^4.21.4", - "postcss-selector-parser": "^6.0.4" - }, - "engines": { - "node": "^10 || ^12 || >=14.0" - }, - "peerDependencies": { - "postcss": "^8.2.15" - } - }, - "node_modules/stylelint": { - "version": "14.16.0", - "resolved": "https://registry.npmjs.org/stylelint/-/stylelint-14.16.0.tgz", - "integrity": "sha512-X6uTi9DcxjzLV8ZUAjit1vsRtSwcls0nl07c9rqOPzvpA8IvTX/xWEkBRowS0ffevRrqkHa/ThDEu86u73FQDg==", - "dev": true, - "dependencies": { - "@csstools/selector-specificity": "^2.0.2", - "balanced-match": "^2.0.0", - "colord": "^2.9.3", - "cosmiconfig": "^7.1.0", - "css-functions-list": "^3.1.0", - "debug": "^4.3.4", - "fast-glob": "^3.2.12", - "fastest-levenshtein": "^1.0.16", - "file-entry-cache": "^6.0.1", - "global-modules": "^2.0.0", - "globby": "^11.1.0", - "globjoin": "^0.1.4", - "html-tags": "^3.2.0", - "ignore": "^5.2.1", - "import-lazy": "^4.0.0", - "imurmurhash": "^0.1.4", - "is-plain-object": "^5.0.0", - "known-css-properties": "^0.26.0", - "mathml-tag-names": "^2.1.3", - "meow": "^9.0.0", - "micromatch": "^4.0.5", - "normalize-path": "^3.0.0", - "picocolors": "^1.0.0", - "postcss": "^8.4.19", - "postcss-media-query-parser": "^0.2.3", - "postcss-resolve-nested-selector": "^0.1.1", - "postcss-safe-parser": "^6.0.0", - "postcss-selector-parser": "^6.0.11", - "postcss-value-parser": "^4.2.0", - "resolve-from": "^5.0.0", - "string-width": "^4.2.3", - "strip-ansi": "^6.0.1", - "style-search": "^0.1.0", - "supports-hyperlinks": "^2.3.0", - "svg-tags": "^1.0.0", - "table": "^6.8.1", - "v8-compile-cache": "^2.3.0", - "write-file-atomic": "^4.0.2" - }, - "bin": { - "stylelint": "bin/stylelint.js" - }, - "engines": { - "node": "^12.20.0 || ^14.13.1 || >=16.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/stylelint" - } - }, - "node_modules/stylelint-config-recommended": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/stylelint-config-recommended/-/stylelint-config-recommended-6.0.0.tgz", - "integrity": "sha512-ZorSSdyMcxWpROYUvLEMm0vSZud2uB7tX1hzBZwvVY9SV/uly4AvvJPPhCcymZL3fcQhEQG5AELmrxWqtmzacw==", - "dev": true, - "peerDependencies": { - "stylelint": "^14.0.0" - } - }, - "node_modules/stylelint-config-recommended-scss": { - "version": "5.0.2", - "resolved": "https://registry.npmjs.org/stylelint-config-recommended-scss/-/stylelint-config-recommended-scss-5.0.2.tgz", - "integrity": "sha512-b14BSZjcwW0hqbzm9b0S/ScN2+3CO3O4vcMNOw2KGf8lfVSwJ4p5TbNEXKwKl1+0FMtgRXZj6DqVUe/7nGnuBg==", - "dev": true, - "dependencies": { - "postcss-scss": "^4.0.2", - "stylelint-config-recommended": "^6.0.0", - "stylelint-scss": "^4.0.0" - }, - "peerDependencies": { - "stylelint": "^14.0.0" - } - }, - "node_modules/stylelint-scss": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/stylelint-scss/-/stylelint-scss-4.3.0.tgz", - "integrity": "sha512-GvSaKCA3tipzZHoz+nNO7S02ZqOsdBzMiCx9poSmLlb3tdJlGddEX/8QzCOD8O7GQan9bjsvLMsO5xiw6IhhIQ==", - "dev": true, - "dependencies": { - "lodash": "^4.17.21", - "postcss-media-query-parser": "^0.2.3", - "postcss-resolve-nested-selector": "^0.1.1", - "postcss-selector-parser": "^6.0.6", - "postcss-value-parser": "^4.1.0" - }, - "peerDependencies": { - "stylelint": "^14.5.1" - } - }, - "node_modules/stylelint/node_modules/balanced-match": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-2.0.0.tgz", - "integrity": "sha512-1ugUSr8BHXRnK23KfuYS+gVMC3LB8QGH9W1iGtDPsNWoQbgtXSExkBu2aDR4epiGWZOjZsj6lDl/N/AqqTC3UA==", - "dev": true - }, - "node_modules/stylelint/node_modules/global-modules": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-2.0.0.tgz", - "integrity": "sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A==", - "dev": true, - "dependencies": { - "global-prefix": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/stylelint/node_modules/global-prefix": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-3.0.0.tgz", - "integrity": "sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==", - "dev": true, - "dependencies": { - "ini": "^1.3.5", - "kind-of": "^6.0.2", - "which": "^1.3.1" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/stylelint/node_modules/hosted-git-info": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-4.1.0.tgz", - "integrity": "sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/stylelint/node_modules/kind-of": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", - "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/stylelint/node_modules/lru-cache": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-6.0.0.tgz", - "integrity": "sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==", - "dev": true, - "dependencies": { - "yallist": "^4.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/stylelint/node_modules/meow": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/meow/-/meow-9.0.0.tgz", - "integrity": "sha512-+obSblOQmRhcyBt62furQqRAQpNyWXo8BuQ5bN7dG8wmwQ+vwHKp/rCFD4CrTP8CsDQD1sjoZ94K417XEUk8IQ==", - "dev": true, - "dependencies": { - "@types/minimist": "^1.2.0", - "camelcase-keys": "^6.2.2", - "decamelize": "^1.2.0", - "decamelize-keys": "^1.1.0", - "hard-rejection": "^2.1.0", - "minimist-options": "4.1.0", - "normalize-package-data": "^3.0.0", - "read-pkg-up": "^7.0.1", - "redent": "^3.0.0", - "trim-newlines": "^3.0.0", - "type-fest": "^0.18.0", - "yargs-parser": "^20.2.3" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/stylelint/node_modules/normalize-package-data": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-3.0.3.tgz", - "integrity": "sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==", - "dev": true, - "dependencies": { - "hosted-git-info": "^4.0.1", - "is-core-module": "^2.5.0", - "semver": "^7.3.4", - "validate-npm-package-license": "^3.0.1" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/stylelint/node_modules/resolve-from": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-5.0.0.tgz", - "integrity": "sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/stylelint/node_modules/semver": { - "version": "7.3.8", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.3.8.tgz", - "integrity": "sha512-NB1ctGL5rlHrPJtFDVIVzTyQylMLu9N9VICA6HSFJo8MCGVTMW6gfpicwKmmK/dAjTOrqu5l63JJOpDSrAis3A==", - "dev": true, - "dependencies": { - "lru-cache": "^6.0.0" - }, - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/stylelint/node_modules/type-fest": { - "version": "0.18.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.18.1.tgz", - "integrity": "sha512-OIAYXk8+ISY+qTOwkHtKqzAuxchoMiD9Udx+FSGQDuiRR+PJKJHc2NJAXlbhkGwTt/4/nKZxELY1w3ReWOL8mw==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/stylelint/node_modules/write-file-atomic": { - "version": "4.0.2", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-4.0.2.tgz", - "integrity": "sha512-7KxauUdBmSdWnmpaGFg+ppNjKF8uNLry8LyzjauQDOVONfFLNKrKvQOxZ/VuTIcS/gge/YNahf5RIIQWTSarlg==", - "dev": true, - "dependencies": { - "imurmurhash": "^0.1.4", - "signal-exit": "^3.0.7" - }, - "engines": { - "node": "^12.13.0 || ^14.15.0 || >=16.0.0" - } - }, - "node_modules/stylelint/node_modules/yallist": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", - "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==", - "dev": true - }, - "node_modules/stylelint/node_modules/yargs-parser": { - "version": "20.2.9", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", - "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/stylis": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/stylis/-/stylis-4.1.3.tgz", - "integrity": "sha512-GP6WDNWf+o403jrEp9c5jibKavrtLW+/qYGhFxFrG8maXhwTBI7gLLhiBb0o7uFccWN+EOS9aMO6cGHWAO07OA==" - }, - "node_modules/supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dependencies": { - "has-flag": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/supports-hyperlinks": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/supports-hyperlinks/-/supports-hyperlinks-2.3.0.tgz", - "integrity": "sha512-RpsAZlpWcDwOPQA22aCH4J0t7L8JmAvsCxfOSEwm7cQs3LshN36QaTkwd70DnBOXDWGssw2eUoc8CaRWT0XunA==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0", - "supports-color": "^7.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/supports-hyperlinks/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/supports-hyperlinks/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/supports-preserve-symlinks-flag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz", - "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==", - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/svg-parser": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/svg-parser/-/svg-parser-2.0.4.tgz", - "integrity": "sha512-e4hG1hRwoOdRb37cIMSgzNsxyzKfayW6VOflrwvR+/bzrkyxY/31WkbgnQpgtrNp1SdpJvpUAGTa/ZoiPNDuRQ==", - "dev": true - }, - "node_modules/svg-tags": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/svg-tags/-/svg-tags-1.0.0.tgz", - "integrity": "sha512-ovssysQTa+luh7A5Weu3Rta6FJlFBBbInjOh722LIt6klpU2/HtdUbszju/G4devcvk8PGt7FCLv5wftu3THUA==", - "dev": true - }, - "node_modules/svgo": { - "version": "2.8.0", - "resolved": "https://registry.npmjs.org/svgo/-/svgo-2.8.0.tgz", - "integrity": "sha512-+N/Q9kV1+F+UeWYoSiULYo4xYSDQlTgb+ayMobAXPwMnLvop7oxKMo9OzIrX5x3eS4L4f2UHhc9axXwY8DpChg==", - "dev": true, - "dependencies": { - "@trysound/sax": "0.2.0", - "commander": "^7.2.0", - "css-select": "^4.1.3", - "css-tree": "^1.1.3", - "csso": "^4.2.0", - "picocolors": "^1.0.0", - "stable": "^0.1.8" - }, - "bin": { - "svgo": "bin/svgo" - }, - "engines": { - "node": ">=10.13.0" - } - }, - "node_modules/svgo/node_modules/commander": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", - "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", - "dev": true, - "engines": { - "node": ">= 10" - } - }, - "node_modules/symbol-tree": { - "version": "3.2.4", - "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", - "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==", - "dev": true - }, - "node_modules/table": { - "version": "6.8.1", - "resolved": "https://registry.npmjs.org/table/-/table-6.8.1.tgz", - "integrity": "sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA==", - "dev": true, - "dependencies": { - "ajv": "^8.0.1", - "lodash.truncate": "^4.4.2", - "slice-ansi": "^4.0.0", - "string-width": "^4.2.3", - "strip-ansi": "^6.0.1" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/table/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.1", - "json-schema-traverse": "^1.0.0", - "require-from-string": "^2.0.2", - "uri-js": "^4.2.2" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/epoberezkin" - } - }, - "node_modules/table/node_modules/json-schema-traverse": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", - "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", - "dev": true - }, - "node_modules/tannin": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/tannin/-/tannin-1.2.0.tgz", - "integrity": "sha512-U7GgX/RcSeUETbV7gYgoz8PD7Ni4y95pgIP/Z6ayI3CfhSujwKEBlGFTCRN+Aqnuyf4AN2yHL+L8x+TCGjb9uA==", - "dependencies": { - "@tannin/plural-forms": "^1.1.0" - } - }, - "node_modules/tapable": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", - "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/tar-fs": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/tar-fs/-/tar-fs-2.1.1.tgz", - "integrity": "sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng==", - "dev": true, - "dependencies": { - "chownr": "^1.1.1", - "mkdirp-classic": "^0.5.2", - "pump": "^3.0.0", - "tar-stream": "^2.1.4" - } - }, - "node_modules/tar-stream": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/tar-stream/-/tar-stream-2.2.0.tgz", - "integrity": "sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==", - "dev": true, - "dependencies": { - "bl": "^4.0.3", - "end-of-stream": "^1.4.1", - "fs-constants": "^1.0.0", - "inherits": "^2.0.3", - "readable-stream": "^3.1.1" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/terminal-link": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/terminal-link/-/terminal-link-2.1.1.tgz", - "integrity": "sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ==", - "dev": true, - "dependencies": { - "ansi-escapes": "^4.2.1", - "supports-hyperlinks": "^2.0.0" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/terser": { - "version": "5.16.1", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.16.1.tgz", - "integrity": "sha512-xvQfyfA1ayT0qdK47zskQgRZeWLoOQ8JQ6mIgRGVNwZKdQMU+5FkCBjmv4QjcrTzyZquRw2FVtlJSRUmMKQslw==", - "dev": true, - "dependencies": { - "@jridgewell/source-map": "^0.3.2", - "acorn": "^8.5.0", - "commander": "^2.20.0", - "source-map-support": "~0.5.20" - }, - "bin": { - "terser": "bin/terser" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/terser-webpack-plugin": { - "version": "5.3.6", - "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.6.tgz", - "integrity": "sha512-kfLFk+PoLUQIbLmB1+PZDMRSZS99Mp+/MHqDNmMA6tOItzRt+Npe3E+fsMs5mfcM0wCtrrdU387UnV+vnSffXQ==", - "dev": true, - "dependencies": { - "@jridgewell/trace-mapping": "^0.3.14", - "jest-worker": "^27.4.5", - "schema-utils": "^3.1.1", - "serialize-javascript": "^6.0.0", - "terser": "^5.14.1" - }, - "engines": { - "node": ">= 10.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "^5.1.0" - }, - "peerDependenciesMeta": { - "@swc/core": { - "optional": true - }, - "esbuild": { - "optional": true - }, - "uglify-js": { - "optional": true - } - } - }, - "node_modules/terser/node_modules/commander": { - "version": "2.20.3", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", - "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", - "dev": true - }, - "node_modules/test-exclude": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-6.0.0.tgz", - "integrity": "sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w==", - "dev": true, - "dependencies": { - "@istanbuljs/schema": "^0.1.2", - "glob": "^7.1.4", - "minimatch": "^3.0.4" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/text-table": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", - "integrity": "sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==", - "dev": true - }, - "node_modules/throat": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/throat/-/throat-6.0.1.tgz", - "integrity": "sha512-8hmiGIJMDlwjg7dlJ4yKGLK8EsYqKgPWbG3b4wjJddKNwc7N7Dpn08Df4szr/sZdMVeOstrdYSsqzX6BYbcB+w==", - "dev": true - }, - "node_modules/through": { - "version": "2.3.8", - "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", - "integrity": "sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==", - "dev": true - }, - "node_modules/thunky": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", - "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==", - "dev": true - }, - "node_modules/tiny-emitter": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/tiny-emitter/-/tiny-emitter-2.1.0.tgz", - "integrity": "sha512-NB6Dk1A9xgQPMoGqC5CVXn123gWyte215ONT5Pp5a0yt4nlEoO1ZWeCwpncaekPHXO60i47ihFnZPiRPjRMq4Q==" - }, - "node_modules/tmpl": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.5.tgz", - "integrity": "sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==", - "dev": true - }, - "node_modules/to-fast-properties": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", - "integrity": "sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==", - "engines": { - "node": ">=4" - } - }, - "node_modules/to-regex-range": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", - "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dev": true, - "dependencies": { - "is-number": "^7.0.0" - }, - "engines": { - "node": ">=8.0" - } - }, - "node_modules/toidentifier": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", - "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", - "dev": true, - "engines": { - "node": ">=0.6" - } - }, - "node_modules/totalist": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/totalist/-/totalist-1.1.0.tgz", - "integrity": "sha512-gduQwd1rOdDMGxFG1gEvhV88Oirdo2p+KjoYFU7k2g+i7n6AFFbDQ5kMPUsW0pNbfQsB/cwXvT1i4Bue0s9g5g==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/tough-cookie": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-4.1.2.tgz", - "integrity": "sha512-G9fqXWoYFZgTc2z8Q5zaHy/vJMjm+WV0AkAeHxVCQiEB1b+dGvWzFW6QV07cY5jQ5gRkeid2qIkzkxUnmoQZUQ==", - "dev": true, - "dependencies": { - "psl": "^1.1.33", - "punycode": "^2.1.1", - "universalify": "^0.2.0", - "url-parse": "^1.5.3" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/tr46": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-2.1.0.tgz", - "integrity": "sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==", - "dev": true, - "dependencies": { - "punycode": "^2.1.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/traverse": { - "version": "0.6.7", - "resolved": "https://registry.npmjs.org/traverse/-/traverse-0.6.7.tgz", - "integrity": "sha512-/y956gpUo9ZNCb99YjxG7OaslxZWHfCHAUUfshwqOXmxUIvqLjVO581BT+gM59+QV9tFe6/CGG53tsA1Y7RSdg==", - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/tree-kill": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/tree-kill/-/tree-kill-1.2.2.tgz", - "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", - "dev": true, - "bin": { - "tree-kill": "cli.js" - } - }, - "node_modules/trim-newlines": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/trim-newlines/-/trim-newlines-3.0.1.tgz", - "integrity": "sha512-c1PTsA3tYrIsLGkJkzHF+w9F2EyxfXGo4UyJc4pFL++FMjnq0HJS69T3M7d//gKrFKwy429bouPescbjecU+Zw==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/trim-repeated": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/trim-repeated/-/trim-repeated-1.0.0.tgz", - "integrity": "sha512-pkonvlKk8/ZuR0D5tLW8ljt5I8kmxp2XKymhepUeOdCEfKpZaktSArkLHZt76OB1ZvO9bssUsDty4SWhLvZpLg==", - "dev": true, - "dependencies": { - "escape-string-regexp": "^1.0.2" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/trim-repeated/node_modules/escape-string-regexp": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", - "integrity": "sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==", - "dev": true, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/tsconfig-paths": { - "version": "3.14.1", - "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-3.14.1.tgz", - "integrity": "sha512-fxDhWnFSLt3VuTwtvJt5fpwxBHg5AdKWMsgcPOOIilyjymcYVZoCQF8fvFRezCNfblEXmi+PcM1eYHeOAgXCOQ==", - "dev": true, - "dependencies": { - "@types/json5": "^0.0.29", - "json5": "^1.0.1", - "minimist": "^1.2.6", - "strip-bom": "^3.0.0" - } - }, - "node_modules/tsconfig-paths/node_modules/json5": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", - "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", - "dev": true, - "dependencies": { - "minimist": "^1.2.0" - }, - "bin": { - "json5": "lib/cli.js" - } - }, - "node_modules/tsconfig-paths/node_modules/strip-bom": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", - "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/tslib": { - "version": "2.4.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.4.1.tgz", - "integrity": "sha512-tGyy4dAjRIEwI7BzsB0lynWgOpfqjUdq91XXAlIWD2OwKBH7oCl/GZG/HT4BOHrTlPMOASlMQ7veyTqpmRcrNA==" - }, - "node_modules/tsutils": { - "version": "3.21.0", - "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", - "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", - "dev": true, - "dependencies": { - "tslib": "^1.8.1" - }, - "engines": { - "node": ">= 6" - }, - "peerDependencies": { - "typescript": ">=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta" - } - }, - "node_modules/tsutils/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", - "dev": true - }, - "node_modules/turbo-combine-reducers": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/turbo-combine-reducers/-/turbo-combine-reducers-1.0.2.tgz", - "integrity": "sha512-gHbdMZlA6Ym6Ur5pSH/UWrNQMIM9IqTH6SoL1DbHpqEdQ8i+cFunSmSlFykPt0eGQwZ4d/XTHOl74H0/kFBVWw==" - }, - "node_modules/type-check": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.4.0.tgz", - "integrity": "sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew==", - "dev": true, - "dependencies": { - "prelude-ls": "^1.2.1" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/type-detect": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/type-detect/-/type-detect-4.0.8.tgz", - "integrity": "sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/type-fest": { - "version": "0.21.3", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", - "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/type-is": { - "version": "1.6.18", - "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", - "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", - "dev": true, - "dependencies": { - "media-typer": "0.3.0", - "mime-types": "~2.1.24" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/typedarray-to-buffer": { - "version": "3.1.5", - "resolved": "https://registry.npmjs.org/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz", - "integrity": "sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==", - "dev": true, - "dependencies": { - "is-typedarray": "^1.0.0" - } - }, - "node_modules/uc.micro": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.6.tgz", - "integrity": "sha512-8Y75pvTYkLJW2hWQHXxoqRgV7qb9B+9vFEtidML+7koHUFapnVJAZ6cKs+Qjz5Aw3aZWHMC6u0wJE3At+nSGwA==", - "dev": true - }, - "node_modules/unbox-primitive": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/unbox-primitive/-/unbox-primitive-1.0.2.tgz", - "integrity": "sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "has-bigints": "^1.0.2", - "has-symbols": "^1.0.3", - "which-boxed-primitive": "^1.0.2" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/unbzip2-stream": { - "version": "1.4.3", - "resolved": "https://registry.npmjs.org/unbzip2-stream/-/unbzip2-stream-1.4.3.tgz", - "integrity": "sha512-mlExGW4w71ebDJviH16lQLtZS32VKqsSfk80GCfUlwT/4/hNRFsoscrF/c++9xinkMzECL1uL9DDwXqFWkruPg==", - "dev": true, - "dependencies": { - "buffer": "^5.2.1", - "through": "^2.3.8" - } - }, - "node_modules/unicode-canonical-property-names-ecmascript": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-2.0.0.tgz", - "integrity": "sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/unicode-match-property-ecmascript": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-2.0.0.tgz", - "integrity": "sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==", - "dev": true, - "dependencies": { - "unicode-canonical-property-names-ecmascript": "^2.0.0", - "unicode-property-aliases-ecmascript": "^2.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/unicode-match-property-value-ecmascript": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-2.1.0.tgz", - "integrity": "sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/unicode-property-aliases-ecmascript": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-2.1.0.tgz", - "integrity": "sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==", - "dev": true, - "engines": { - "node": ">=4" - } - }, - "node_modules/universalify": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.2.0.tgz", - "integrity": "sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==", - "dev": true, - "engines": { - "node": ">= 4.0.0" - } - }, - "node_modules/unpipe": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", - "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/update-browserslist-db": { - "version": "1.0.10", - "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz", - "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==", - "funding": [ - { - "type": "opencollective", - "url": "https://opencollective.com/browserslist" - }, - { - "type": "tidelift", - "url": "https://tidelift.com/funding/github/npm/browserslist" - } - ], - "dependencies": { - "escalade": "^3.1.1", - "picocolors": "^1.0.0" - }, - "bin": { - "browserslist-lint": "cli.js" - }, - "peerDependencies": { - "browserslist": ">= 4.21.0" - } - }, - "node_modules/upper-case": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/upper-case/-/upper-case-2.0.2.tgz", - "integrity": "sha512-KgdgDGJt2TpuwBUIjgG6lzw2GWFRCW9Qkfkiv0DxqHHLYJHmtmdUIKcZd8rHgFSjopVTlw6ggzCm1b8MFQwikg==", - "dependencies": { - "tslib": "^2.0.3" - } - }, - "node_modules/upper-case-first": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/upper-case-first/-/upper-case-first-2.0.2.tgz", - "integrity": "sha512-514ppYHBaKwfJRK/pNC6c/OxfGa0obSnAl106u97Ed0I625Nin96KAjttZF6ZL3e1XLtphxnqrOi9iWgm+u+bg==", - "dependencies": { - "tslib": "^2.0.3" - } - }, - "node_modules/uri-js": { - "version": "4.4.1", - "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.4.1.tgz", - "integrity": "sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==", - "dev": true, - "dependencies": { - "punycode": "^2.1.0" - } - }, - "node_modules/url-loader": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/url-loader/-/url-loader-4.1.1.tgz", - "integrity": "sha512-3BTV812+AVHHOJQO8O5MkWgZ5aosP7GnROJwvzLS9hWDj00lZ6Z0wNak423Lp9PBZN05N+Jk/N5Si8jRAlGyWA==", - "dev": true, - "dependencies": { - "loader-utils": "^2.0.0", - "mime-types": "^2.1.27", - "schema-utils": "^3.0.0" - }, - "engines": { - "node": ">= 10.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "file-loader": "*", - "webpack": "^4.0.0 || ^5.0.0" - }, - "peerDependenciesMeta": { - "file-loader": { - "optional": true - } - } - }, - "node_modules/url-parse": { - "version": "1.5.10", - "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.5.10.tgz", - "integrity": "sha512-WypcfiRhfeUP9vvF0j6rw0J3hrWrw6iZv3+22h6iRMJ/8z1Tj6XfLP4DsUix5MhMPnXpiHDoKyoZ/bdCkwBCiQ==", - "dev": true, - "dependencies": { - "querystringify": "^2.1.1", - "requires-port": "^1.0.0" - } - }, - "node_modules/use-lilius": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/use-lilius/-/use-lilius-2.0.3.tgz", - "integrity": "sha512-+Q7nspdv+QGnyHGVMd6yAdLrqv5EGB4n3ix4GJH0JEE27weKCLCLmZSuAr5Nw+yPBCZn/iZ+KjL5+UykLCWXrw==", - "dependencies": { - "date-fns": "^2.29.2" - }, - "peerDependencies": { - "react": "*", - "react-dom": "*" - } - }, - "node_modules/use-memo-one": { - "version": "1.1.3", - "resolved": "https://registry.npmjs.org/use-memo-one/-/use-memo-one-1.1.3.tgz", - "integrity": "sha512-g66/K7ZQGYrI6dy8GLpVcMsBp4s17xNkYJVSMvTEevGy3nDxHOfE6z8BVE22+5G5x7t3+bhzrlTDB7ObrEE0cQ==", - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0 || ^18.0.0" - } - }, - "node_modules/use-sync-external-store": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz", - "integrity": "sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==", - "peerDependencies": { - "react": "^16.8.0 || ^17.0.0 || ^18.0.0" - } - }, - "node_modules/util-deprecate": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", - "integrity": "sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==", - "dev": true - }, - "node_modules/utils-merge": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", - "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", - "dev": true, - "engines": { - "node": ">= 0.4.0" - } - }, - "node_modules/uuid": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/uuid/-/uuid-8.3.2.tgz", - "integrity": "sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==", - "bin": { - "uuid": "dist/bin/uuid" - } - }, - "node_modules/v8-compile-cache": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz", - "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==", - "dev": true - }, - "node_modules/v8-to-istanbul": { - "version": "8.1.1", - "resolved": "https://registry.npmjs.org/v8-to-istanbul/-/v8-to-istanbul-8.1.1.tgz", - "integrity": "sha512-FGtKtv3xIpR6BYhvgH8MI/y78oT7d8Au3ww4QIxymrCtZEh5b8gCw2siywE+puhEmuWKDtmfrvF5UlB298ut3w==", - "dev": true, - "dependencies": { - "@types/istanbul-lib-coverage": "^2.0.1", - "convert-source-map": "^1.6.0", - "source-map": "^0.7.3" - }, - "engines": { - "node": ">=10.12.0" - } - }, - "node_modules/v8-to-istanbul/node_modules/source-map": { - "version": "0.7.4", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.7.4.tgz", - "integrity": "sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==", - "dev": true, - "engines": { - "node": ">= 8" - } - }, - "node_modules/validate-npm-package-license": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", - "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", - "dev": true, - "dependencies": { - "spdx-correct": "^3.0.0", - "spdx-expression-parse": "^3.0.0" - } - }, - "node_modules/valtio": { - "version": "1.7.6", - "resolved": "https://registry.npmjs.org/valtio/-/valtio-1.7.6.tgz", - "integrity": "sha512-zsGrCCYOIpy8egQxftduFyJusF/BMu3CganhHKUOE/I6t6V6yA1MDfZZkrYoWYCGkC3rSBYcIHEEsoYQM9lV2w==", - "dependencies": { - "proxy-compare": "2.3.0", - "use-sync-external-store": "1.2.0" - }, - "engines": { - "node": ">=12.7.0" - }, - "peerDependencies": { - "@babel/helper-module-imports": ">=7.12", - "@babel/types": ">=7.13", - "aslemammad-vite-plugin-macro": ">=1.0.0-alpha.1", - "babel-plugin-macros": ">=3.0", - "react": ">=16.8", - "vite": ">=2.8.6" - }, - "peerDependenciesMeta": { - "@babel/helper-module-imports": { - "optional": true - }, - "@babel/types": { - "optional": true - }, - "aslemammad-vite-plugin-macro": { - "optional": true - }, - "babel-plugin-macros": { - "optional": true - }, - "react": { - "optional": true - }, - "vite": { - "optional": true - } - } - }, - "node_modules/vary": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", - "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", - "dev": true, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/w3c-hr-time": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz", - "integrity": "sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ==", - "deprecated": "Use your platform's native performance.now() and performance.timeOrigin.", - "dev": true, - "dependencies": { - "browser-process-hrtime": "^1.0.0" - } - }, - "node_modules/w3c-xmlserializer": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz", - "integrity": "sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA==", - "dev": true, - "dependencies": { - "xml-name-validator": "^3.0.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/wait-on": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/wait-on/-/wait-on-6.0.1.tgz", - "integrity": "sha512-zht+KASY3usTY5u2LgaNqn/Cd8MukxLGjdcZxT2ns5QzDmTFc4XoWBgC+C/na+sMRZTuVygQoMYwdcVjHnYIVw==", - "dev": true, - "dependencies": { - "axios": "^0.25.0", - "joi": "^17.6.0", - "lodash": "^4.17.21", - "minimist": "^1.2.5", - "rxjs": "^7.5.4" - }, - "bin": { - "wait-on": "bin/wait-on" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/walker": { - "version": "1.0.8", - "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.8.tgz", - "integrity": "sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ==", - "dev": true, - "dependencies": { - "makeerror": "1.0.12" - } - }, - "node_modules/watchpack": { - "version": "2.4.0", - "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.0.tgz", - "integrity": "sha512-Lcvm7MGST/4fup+ifyKi2hjyIAwcdI4HRgtvTpIUxBRhB+RFtUh8XtDOxUfctVCnhVi+QQj49i91OyvzkJl6cg==", - "dev": true, - "dependencies": { - "glob-to-regexp": "^0.4.1", - "graceful-fs": "^4.1.2" - }, - "engines": { - "node": ">=10.13.0" - } - }, - "node_modules/wbuf": { - "version": "1.7.3", - "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz", - "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==", - "dev": true, - "dependencies": { - "minimalistic-assert": "^1.0.0" - } - }, - "node_modules/webidl-conversions": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-6.1.0.tgz", - "integrity": "sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w==", - "dev": true, - "engines": { - "node": ">=10.4" - } - }, - "node_modules/webpack": { - "version": "5.75.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.75.0.tgz", - "integrity": "sha512-piaIaoVJlqMsPtX/+3KTTO6jfvrSYgauFVdt8cr9LTHKmcq/AMd4mhzsiP7ZF/PGRNPGA8336jldh9l2Kt2ogQ==", - "dev": true, - "dependencies": { - "@types/eslint-scope": "^3.7.3", - "@types/estree": "^0.0.51", - "@webassemblyjs/ast": "1.11.1", - "@webassemblyjs/wasm-edit": "1.11.1", - "@webassemblyjs/wasm-parser": "1.11.1", - "acorn": "^8.7.1", - "acorn-import-assertions": "^1.7.6", - "browserslist": "^4.14.5", - "chrome-trace-event": "^1.0.2", - "enhanced-resolve": "^5.10.0", - "es-module-lexer": "^0.9.0", - "eslint-scope": "5.1.1", - "events": "^3.2.0", - "glob-to-regexp": "^0.4.1", - "graceful-fs": "^4.2.9", - "json-parse-even-better-errors": "^2.3.1", - "loader-runner": "^4.2.0", - "mime-types": "^2.1.27", - "neo-async": "^2.6.2", - "schema-utils": "^3.1.0", - "tapable": "^2.1.1", - "terser-webpack-plugin": "^5.1.3", - "watchpack": "^2.4.0", - "webpack-sources": "^3.2.3" - }, - "bin": { - "webpack": "bin/webpack.js" - }, - "engines": { - "node": ">=10.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependenciesMeta": { - "webpack-cli": { - "optional": true - } - } - }, - "node_modules/webpack-bundle-analyzer": { - "version": "4.7.0", - "resolved": "https://registry.npmjs.org/webpack-bundle-analyzer/-/webpack-bundle-analyzer-4.7.0.tgz", - "integrity": "sha512-j9b8ynpJS4K+zfO5GGwsAcQX4ZHpWV+yRiHDiL+bE0XHJ8NiPYLTNVQdlFYWxtpg9lfAQNlwJg16J9AJtFSXRg==", - "dev": true, - "dependencies": { - "acorn": "^8.0.4", - "acorn-walk": "^8.0.0", - "chalk": "^4.1.0", - "commander": "^7.2.0", - "gzip-size": "^6.0.0", - "lodash": "^4.17.20", - "opener": "^1.5.2", - "sirv": "^1.0.7", - "ws": "^7.3.1" - }, - "bin": { - "webpack-bundle-analyzer": "lib/bin/analyzer.js" - }, - "engines": { - "node": ">= 10.13.0" - } - }, - "node_modules/webpack-bundle-analyzer/node_modules/acorn-walk": { - "version": "8.2.0", - "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.2.0.tgz", - "integrity": "sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==", - "dev": true, - "engines": { - "node": ">=0.4.0" - } - }, - "node_modules/webpack-bundle-analyzer/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/webpack-bundle-analyzer/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/webpack-bundle-analyzer/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/webpack-bundle-analyzer/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/webpack-bundle-analyzer/node_modules/commander": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", - "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", - "dev": true, - "engines": { - "node": ">= 10" - } - }, - "node_modules/webpack-bundle-analyzer/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/webpack-bundle-analyzer/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/webpack-cli": { - "version": "4.10.0", - "resolved": "https://registry.npmjs.org/webpack-cli/-/webpack-cli-4.10.0.tgz", - "integrity": "sha512-NLhDfH/h4O6UOy+0LSso42xvYypClINuMNBVVzX4vX98TmTaTUxwRbXdhucbFMd2qLaCTcLq/PdYrvi8onw90w==", - "dev": true, - "dependencies": { - "@discoveryjs/json-ext": "^0.5.0", - "@webpack-cli/configtest": "^1.2.0", - "@webpack-cli/info": "^1.5.0", - "@webpack-cli/serve": "^1.7.0", - "colorette": "^2.0.14", - "commander": "^7.0.0", - "cross-spawn": "^7.0.3", - "fastest-levenshtein": "^1.0.12", - "import-local": "^3.0.2", - "interpret": "^2.2.0", - "rechoir": "^0.7.0", - "webpack-merge": "^5.7.3" - }, - "bin": { - "webpack-cli": "bin/cli.js" - }, - "engines": { - "node": ">=10.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "4.x.x || 5.x.x" - }, - "peerDependenciesMeta": { - "@webpack-cli/generators": { - "optional": true - }, - "@webpack-cli/migrate": { - "optional": true - }, - "webpack-bundle-analyzer": { - "optional": true - }, - "webpack-dev-server": { - "optional": true - } - } - }, - "node_modules/webpack-cli/node_modules/commander": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/commander/-/commander-7.2.0.tgz", - "integrity": "sha512-QrWXB+ZQSVPmIWIhtEO9H+gwHaMGYiF5ChvoJ+K9ZGHG/sVsa6yiesAD1GC/x46sET00Xlwo1u49RVVVzvcSkw==", - "dev": true, - "engines": { - "node": ">= 10" - } - }, - "node_modules/webpack-cli/node_modules/cross-spawn": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.3.tgz", - "integrity": "sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==", - "dev": true, - "dependencies": { - "path-key": "^3.1.0", - "shebang-command": "^2.0.0", - "which": "^2.0.1" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/webpack-cli/node_modules/shebang-command": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", - "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", - "dev": true, - "dependencies": { - "shebang-regex": "^3.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/webpack-cli/node_modules/shebang-regex": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", - "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/webpack-cli/node_modules/which": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", - "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", - "dev": true, - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "node-which": "bin/node-which" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/webpack-dev-middleware": { - "version": "5.3.3", - "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-5.3.3.tgz", - "integrity": "sha512-hj5CYrY0bZLB+eTO+x/j67Pkrquiy7kWepMHmUMoPsmcUaeEnQJqFzHJOyxgWlq746/wUuA64p9ta34Kyb01pA==", - "dev": true, - "dependencies": { - "colorette": "^2.0.10", - "memfs": "^3.4.3", - "mime-types": "^2.1.31", - "range-parser": "^1.2.1", - "schema-utils": "^4.0.0" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "^4.0.0 || ^5.0.0" - } - }, - "node_modules/webpack-dev-middleware/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.1", - "json-schema-traverse": "^1.0.0", - "require-from-string": "^2.0.2", - "uri-js": "^4.2.2" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/epoberezkin" - } - }, - "node_modules/webpack-dev-middleware/node_modules/ajv-keywords": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz", - "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.3" - }, - "peerDependencies": { - "ajv": "^8.8.2" - } - }, - "node_modules/webpack-dev-middleware/node_modules/json-schema-traverse": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", - "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", - "dev": true - }, - "node_modules/webpack-dev-middleware/node_modules/schema-utils": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz", - "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==", - "dev": true, - "dependencies": { - "@types/json-schema": "^7.0.9", - "ajv": "^8.8.0", - "ajv-formats": "^2.1.1", - "ajv-keywords": "^5.0.0" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - } - }, - "node_modules/webpack-dev-server": { - "version": "4.11.1", - "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-4.11.1.tgz", - "integrity": "sha512-lILVz9tAUy1zGFwieuaQtYiadImb5M3d+H+L1zDYalYoDl0cksAB1UNyuE5MMWJrG6zR1tXkCP2fitl7yoUJiw==", - "dev": true, - "dependencies": { - "@types/bonjour": "^3.5.9", - "@types/connect-history-api-fallback": "^1.3.5", - "@types/express": "^4.17.13", - "@types/serve-index": "^1.9.1", - "@types/serve-static": "^1.13.10", - "@types/sockjs": "^0.3.33", - "@types/ws": "^8.5.1", - "ansi-html-community": "^0.0.8", - "bonjour-service": "^1.0.11", - "chokidar": "^3.5.3", - "colorette": "^2.0.10", - "compression": "^1.7.4", - "connect-history-api-fallback": "^2.0.0", - "default-gateway": "^6.0.3", - "express": "^4.17.3", - "graceful-fs": "^4.2.6", - "html-entities": "^2.3.2", - "http-proxy-middleware": "^2.0.3", - "ipaddr.js": "^2.0.1", - "open": "^8.0.9", - "p-retry": "^4.5.0", - "rimraf": "^3.0.2", - "schema-utils": "^4.0.0", - "selfsigned": "^2.1.1", - "serve-index": "^1.9.1", - "sockjs": "^0.3.24", - "spdy": "^4.0.2", - "webpack-dev-middleware": "^5.3.1", - "ws": "^8.4.2" - }, - "bin": { - "webpack-dev-server": "bin/webpack-dev-server.js" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - }, - "peerDependencies": { - "webpack": "^4.37.0 || ^5.0.0" - }, - "peerDependenciesMeta": { - "webpack-cli": { - "optional": true - } - } - }, - "node_modules/webpack-dev-server/node_modules/ajv": { - "version": "8.11.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.11.2.tgz", - "integrity": "sha512-E4bfmKAhGiSTvMfL1Myyycaub+cUEU2/IvpylXkUu7CHBkBj1f/ikdzbD7YQ6FKUbixDxeYvB/xY4fvyroDlQg==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.1", - "json-schema-traverse": "^1.0.0", - "require-from-string": "^2.0.2", - "uri-js": "^4.2.2" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/epoberezkin" - } - }, - "node_modules/webpack-dev-server/node_modules/ajv-keywords": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz", - "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==", - "dev": true, - "dependencies": { - "fast-deep-equal": "^3.1.3" - }, - "peerDependencies": { - "ajv": "^8.8.2" - } - }, - "node_modules/webpack-dev-server/node_modules/json-schema-traverse": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", - "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", - "dev": true - }, - "node_modules/webpack-dev-server/node_modules/rimraf": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-3.0.2.tgz", - "integrity": "sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==", - "dev": true, - "dependencies": { - "glob": "^7.1.3" - }, - "bin": { - "rimraf": "bin.js" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, - "node_modules/webpack-dev-server/node_modules/schema-utils": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.0.0.tgz", - "integrity": "sha512-1edyXKgh6XnJsJSQ8mKWXnN/BVaIbFMLpouRUrXgVq7WYne5kw3MW7UPhO44uRXQSIpTSXoJbmrR2X0w9kUTyg==", - "dev": true, - "dependencies": { - "@types/json-schema": "^7.0.9", - "ajv": "^8.8.0", - "ajv-formats": "^2.1.1", - "ajv-keywords": "^5.0.0" - }, - "engines": { - "node": ">= 12.13.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/webpack" - } - }, - "node_modules/webpack-dev-server/node_modules/ws": { - "version": "8.11.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.11.0.tgz", - "integrity": "sha512-HPG3wQd9sNQoT9xHyNCXoDUa+Xw/VevmY9FoHyQ+g+rrMn4j6FB4np7Z0OhdTgjx6MgQLK7jwSy1YecU1+4Asg==", - "dev": true, - "engines": { - "node": ">=10.0.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": "^5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - }, - "node_modules/webpack-merge": { - "version": "5.8.0", - "resolved": "https://registry.npmjs.org/webpack-merge/-/webpack-merge-5.8.0.tgz", - "integrity": "sha512-/SaI7xY0831XwP6kzuwhKWVKDP9t1QY1h65lAFLbZqMPIuYcD9QAW4u9STIbU9kaJbPBB/geU/gLr1wDjOhQ+Q==", - "dev": true, - "dependencies": { - "clone-deep": "^4.0.1", - "wildcard": "^2.0.0" - }, - "engines": { - "node": ">=10.0.0" - } - }, - "node_modules/webpack-merge/node_modules/clone-deep": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", - "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", - "dev": true, - "dependencies": { - "is-plain-object": "^2.0.4", - "kind-of": "^6.0.2", - "shallow-clone": "^3.0.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/webpack-merge/node_modules/is-plain-object": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", - "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", - "dev": true, - "dependencies": { - "isobject": "^3.0.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/webpack-merge/node_modules/kind-of": { - "version": "6.0.3", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", - "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/webpack-merge/node_modules/shallow-clone": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", - "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", - "dev": true, - "dependencies": { - "kind-of": "^6.0.2" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/webpack-sources": { - "version": "3.2.3", - "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz", - "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==", - "dev": true, - "engines": { - "node": ">=10.13.0" - } - }, - "node_modules/websocket-driver": { - "version": "0.7.4", - "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.4.tgz", - "integrity": "sha512-b17KeDIQVjvb0ssuSDF2cYXSg2iztliJ4B9WdsuB6J952qCPKmnVq4DyW5motImXHDC1cBT/1UezrJVsKw5zjg==", - "dev": true, - "dependencies": { - "http-parser-js": ">=0.5.1", - "safe-buffer": ">=5.1.0", - "websocket-extensions": ">=0.1.1" - }, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/websocket-extensions": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.4.tgz", - "integrity": "sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==", - "dev": true, - "engines": { - "node": ">=0.8.0" - } - }, - "node_modules/whatwg-encoding": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", - "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", - "dev": true, - "dependencies": { - "iconv-lite": "0.4.24" - } - }, - "node_modules/whatwg-encoding/node_modules/iconv-lite": { - "version": "0.4.24", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", - "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dev": true, - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/whatwg-mimetype": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", - "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==", - "dev": true - }, - "node_modules/whatwg-url": { - "version": "8.7.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-8.7.0.tgz", - "integrity": "sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==", - "dev": true, - "dependencies": { - "lodash": "^4.7.0", - "tr46": "^2.1.0", - "webidl-conversions": "^6.1.0" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/which": { - "version": "1.3.1", - "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", - "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", - "dev": true, - "dependencies": { - "isexe": "^2.0.0" - }, - "bin": { - "which": "bin/which" - } - }, - "node_modules/which-boxed-primitive": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/which-boxed-primitive/-/which-boxed-primitive-1.0.2.tgz", - "integrity": "sha512-bwZdv0AKLpplFY2KZRX6TvyuN7ojjr7lwkg6ml0roIy9YeuSr7JS372qlNW18UQYzgYK9ziGcerWqZOmEn9VNg==", - "dev": true, - "dependencies": { - "is-bigint": "^1.0.1", - "is-boolean-object": "^1.1.0", - "is-number-object": "^1.0.4", - "is-string": "^1.0.5", - "is-symbol": "^1.0.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/which-module": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", - "integrity": "sha512-B+enWhmw6cjfVC7kS8Pj9pCrKSc5txArRyaYGe088shv/FGWH+0Rjx/xPgtsWfsUtS27FkP697E4DDhgrgoc0Q==" - }, - "node_modules/wildcard": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/wildcard/-/wildcard-2.0.0.tgz", - "integrity": "sha512-JcKqAHLPxcdb9KM49dufGXn2x3ssnfjbcaQdLlfZsL9rH9wgDQjUtDxbo8NE0F6SFvydeu1VhZe7hZuHsB2/pw==", - "dev": true - }, - "node_modules/word-wrap": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", - "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==", - "dev": true, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/wrap-ansi": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-7.0.0.tgz", - "integrity": "sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.0.0", - "string-width": "^4.1.0", - "strip-ansi": "^6.0.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/wrap-ansi?sponsor=1" - } - }, - "node_modules/wrap-ansi/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/wrap-ansi/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/wrap-ansi/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/wrappy": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", - "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", - "dev": true - }, - "node_modules/write-file-atomic": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-3.0.3.tgz", - "integrity": "sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==", - "dev": true, - "dependencies": { - "imurmurhash": "^0.1.4", - "is-typedarray": "^1.0.0", - "signal-exit": "^3.0.2", - "typedarray-to-buffer": "^3.1.5" - } - }, - "node_modules/ws": { - "version": "7.5.9", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.9.tgz", - "integrity": "sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==", - "dev": true, - "engines": { - "node": ">=8.3.0" - }, - "peerDependencies": { - "bufferutil": "^4.0.1", - "utf-8-validate": "^5.0.2" - }, - "peerDependenciesMeta": { - "bufferutil": { - "optional": true - }, - "utf-8-validate": { - "optional": true - } - } - }, - "node_modules/xml-name-validator": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", - "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==", - "dev": true - }, - "node_modules/xmlchars": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", - "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==", - "dev": true - }, - "node_modules/y18n": { - "version": "5.0.8", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-5.0.8.tgz", - "integrity": "sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/yallist": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/yallist/-/yallist-2.1.2.tgz", - "integrity": "sha512-ncTzHV7NvsQZkYe1DW7cbDLm0YpzHmZF5r/iyP3ZnQtMiJ+pjzisCiMNI+Sj+xQF5pXhSHxSB3uDbsBTzY/c2A==", - "dev": true - }, - "node_modules/yaml": { - "version": "1.10.2", - "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.10.2.tgz", - "integrity": "sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==", - "engines": { - "node": ">= 6" - } - }, - "node_modules/yargs": { - "version": "16.2.0", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-16.2.0.tgz", - "integrity": "sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw==", - "dev": true, - "dependencies": { - "cliui": "^7.0.2", - "escalade": "^3.1.1", - "get-caller-file": "^2.0.5", - "require-directory": "^2.1.1", - "string-width": "^4.2.0", - "y18n": "^5.0.5", - "yargs-parser": "^20.2.2" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/yargs-parser": { - "version": "18.1.3", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-18.1.3.tgz", - "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", - "dev": true, - "dependencies": { - "camelcase": "^5.0.0", - "decamelize": "^1.2.0" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/yargs-parser/node_modules/camelcase": { - "version": "5.3.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", - "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", - "dev": true, - "engines": { - "node": ">=6" - } - }, - "node_modules/yargs/node_modules/yargs-parser": { - "version": "20.2.9", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-20.2.9.tgz", - "integrity": "sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==", - "dev": true, - "engines": { - "node": ">=10" - } - }, - "node_modules/yauzl": { - "version": "2.10.0", - "resolved": "https://registry.npmjs.org/yauzl/-/yauzl-2.10.0.tgz", - "integrity": "sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==", - "dev": true, - "dependencies": { - "buffer-crc32": "~0.2.3", - "fd-slicer": "~1.1.0" - } - }, - "node_modules/yocto-queue": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/yocto-queue/-/yocto-queue-0.1.0.tgz", - "integrity": "sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==", - "dev": true, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - } - }, + "lockfileVersion": 1, "dependencies": { "@algolia/cache-browser-local-storage": { "version": "4.17.0", @@ -21523,6 +141,7 @@ "version": "2.2.0", "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.0.tgz", "integrity": "sha512-qRmjj8nj9qmLTQXXmaR1cck3UXSRMPrbsLJAasZpF+t3riI71BXed5ebIOYwQntykeZuhjsdweEc9BxH5Jc26w==", + "dev": true, "requires": { "@jridgewell/gen-mapping": "^0.1.0", "@jridgewell/trace-mapping": "^0.3.9" @@ -21539,12 +158,14 @@ "@babel/compat-data": { "version": "7.20.5", "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.20.5.tgz", - "integrity": "sha512-KZXo2t10+/jxmkhNXc7pZTqRvSOIvVv/+lJwHS+B2rErwOyjuVRh60yVpb7liQ1U5t7lLJ1bz+t8tSypUZdm0g==" + "integrity": "sha512-KZXo2t10+/jxmkhNXc7pZTqRvSOIvVv/+lJwHS+B2rErwOyjuVRh60yVpb7liQ1U5t7lLJ1bz+t8tSypUZdm0g==", + "dev": true }, "@babel/core": { "version": "7.20.5", "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.20.5.tgz", "integrity": "sha512-UdOWmk4pNWTm/4DlPUl/Pt4Gz4rcEMb7CY0Y3eJl5Yz1vI8ZJGmHWaVE55LoxRjdpx0z259GE9U5STA9atUinQ==", + "dev": true, "requires": { "@ampproject/remapping": "^2.1.0", "@babel/code-frame": "^7.18.6", @@ -21578,6 +199,7 @@ "version": "7.20.5", "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.20.5.tgz", "integrity": "sha512-jl7JY2Ykn9S0yj4DQP82sYvPU+T3g0HFcWTqDLqiuA9tGRNIj9VfbtXGAYTTkyNEnQk1jkMGOdYka8aG/lulCA==", + "dev": true, "requires": { "@babel/types": "^7.20.5", "@jridgewell/gen-mapping": "^0.3.2", @@ -21588,6 +210,7 @@ "version": "0.3.2", "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.2.tgz", "integrity": "sha512-mh65xKQAzI6iBcFzwv28KVWSmCkdRBWoOh+bYQGW3+6OZvbbN3TqMGo5hqYxQniRcH9F2VZIoJCm4pa3BPDK/A==", + "dev": true, "requires": { "@jridgewell/set-array": "^1.0.1", "@jridgewell/sourcemap-codec": "^1.4.10", @@ -21619,6 +242,7 @@ "version": "7.20.0", "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.20.0.tgz", "integrity": "sha512-0jp//vDGp9e8hZzBc6N/KwA5ZK3Wsm/pfm4CrY7vzegkVxc65SgSn6wYOnwHe9Js9HRQ1YTCKLGPzDtaS3RoLQ==", + "dev": true, "requires": { "@babel/compat-data": "^7.20.0", "@babel/helper-validator-option": "^7.18.6", @@ -21668,7 +292,8 @@ "@babel/helper-environment-visitor": { "version": "7.18.9", "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.18.9.tgz", - "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==" + "integrity": "sha512-3r/aACDJ3fhQ/EVgFy0hpj8oHyHpQc+LPtJoY9SzTThAsStm4Ptegq92vqKoE3vD706ZVFWITnMnxucw+S9Ipg==", + "dev": true }, "@babel/helper-explode-assignable-expression": { "version": "7.18.6", @@ -21683,6 +308,7 @@ "version": "7.19.0", "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.19.0.tgz", "integrity": "sha512-WAwHBINyrpqywkUH0nTnNgI5ina5TFn85HKS0pbPDfxFfhyR/aNQEn4hGi1P1JyT//I0t4OgXUlofzWILRvS5w==", + "dev": true, "requires": { "@babel/template": "^7.18.10", "@babel/types": "^7.19.0" @@ -21692,6 +318,7 @@ "version": "7.18.6", "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.18.6.tgz", "integrity": "sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==", + "dev": true, "requires": { "@babel/types": "^7.18.6" } @@ -21717,6 +344,7 @@ "version": "7.20.2", "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.20.2.tgz", "integrity": "sha512-zvBKyJXRbmK07XhMuujYoJ48B5yvvmM6+wcpv6Ivj4Yg6qO7NOZOSnvZN9CRl1zz1Z4cKf8YejmCMh8clOoOeA==", + "dev": true, "requires": { "@babel/helper-environment-visitor": "^7.18.9", "@babel/helper-module-imports": "^7.18.6", @@ -21771,6 +399,7 @@ "version": "7.20.2", "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.20.2.tgz", "integrity": "sha512-+0woI/WPq59IrqDYbVGfshjT5Dmk/nnbdpcF8SnMhhXObpTq2KNBdLFRFrkVdbDOyUmHBCxzm5FHV1rACIkIbA==", + "dev": true, "requires": { "@babel/types": "^7.20.2" } @@ -21788,6 +417,7 @@ "version": "7.18.6", "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.18.6.tgz", "integrity": "sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==", + "dev": true, "requires": { "@babel/types": "^7.18.6" } @@ -21805,7 +435,8 @@ "@babel/helper-validator-option": { "version": "7.18.6", "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.18.6.tgz", - "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==" + "integrity": "sha512-XO7gESt5ouv/LRJdrVjkShckw6STTaB7l9BrpBaAHDeF5YZT+01PCwmR0SJHnkW6i8OwW/EVWRShfi4j2x+KQw==", + "dev": true }, "@babel/helper-wrap-function": { "version": "7.20.5", @@ -21823,6 +454,7 @@ "version": "7.20.6", "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.20.6.tgz", "integrity": "sha512-Pf/OjgfgFRW5bApskEz5pvidpim7tEDPlFtKcNRXWmfHGn9IEI2W2flqRQXTFb7gIPTyK++N6rVHuwKut4XK6w==", + "dev": true, "requires": { "@babel/template": "^7.18.10", "@babel/traverse": "^7.20.5", @@ -21842,7 +474,8 @@ "@babel/parser": { "version": "7.20.5", "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.20.5.tgz", - "integrity": "sha512-r27t/cy/m9uKLXQNWWebeCUHgnAZq0CpG1OwKRxzJMP1vpSU4bSIK2hq+/cp0bQxetkXx38n09rNu8jVkcK/zA==" + "integrity": "sha512-r27t/cy/m9uKLXQNWWebeCUHgnAZq0CpG1OwKRxzJMP1vpSU4bSIK2hq+/cp0bQxetkXx38n09rNu8jVkcK/zA==", + "dev": true }, "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { "version": "7.18.6", @@ -22725,6 +1358,7 @@ "version": "7.18.10", "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.18.10.tgz", "integrity": "sha512-TI+rCtooWHr3QJ27kJxfjutghu44DLnasDMwpDqCXVTal9RLp3RSYNh4NdBrRP2cQAoG9A8juOQl6P6oZG4JxA==", + "dev": true, "requires": { "@babel/code-frame": "^7.18.6", "@babel/parser": "^7.18.10", @@ -22735,6 +1369,7 @@ "version": "7.20.5", "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.20.5.tgz", "integrity": "sha512-WM5ZNN3JITQIq9tFZaw1ojLU3WgWdtkxnhM1AegMS+PvHjkM5IXjmYEGY7yukz5XS4sJyEf2VzWjI8uAavhxBQ==", + "dev": true, "requires": { "@babel/code-frame": "^7.18.6", "@babel/generator": "^7.20.5", @@ -22768,8 +1403,7 @@ "version": "2.0.2", "resolved": "https://registry.npmjs.org/@csstools/selector-specificity/-/selector-specificity-2.0.2.tgz", "integrity": "sha512-IkpVW/ehM1hWKln4fCA3NzJU8KwD+kIOvPZA4cqxoJHtE21CCzjyp+Kxbu0i5I4tBNOlXPL9mjwnWlL0VEG4Fg==", - "dev": true, - "requires": {} + "dev": true }, "@discoveryjs/json-ext": { "version": "0.5.7", @@ -22891,8 +1525,7 @@ "@emotion/use-insertion-effect-with-fallbacks": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/@emotion/use-insertion-effect-with-fallbacks/-/use-insertion-effect-with-fallbacks-1.0.0.tgz", - "integrity": "sha512-1eEgUGmkaljiBnRMTdksDV1W4kUnmwgp7X9G8B++9GYwl1lUdqSndSriIrTJ0N7LQaoauY9JJ2yhiOYK5+NI4A==", - "requires": {} + "integrity": "sha512-1eEgUGmkaljiBnRMTdksDV1W4kUnmwgp7X9G8B++9GYwl1lUdqSndSriIrTJ0N7LQaoauY9JJ2yhiOYK5+NI4A==" }, "@emotion/utils": { "version": "1.2.0", @@ -23572,6 +2205,7 @@ "version": "0.1.1", "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.1.1.tgz", "integrity": "sha512-sQXCasFk+U8lWYEe66WxRDOE9PjVz4vSM51fTu3Hw+ClTpUSQb718772vH3pyS5pShp6lvQM7SxgIDXXXmOX7w==", + "dev": true, "requires": { "@jridgewell/set-array": "^1.0.0", "@jridgewell/sourcemap-codec": "^1.4.10" @@ -23580,12 +2214,14 @@ "@jridgewell/resolve-uri": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.0.tgz", - "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==" + "integrity": "sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==", + "dev": true }, "@jridgewell/set-array": { "version": "1.1.2", "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==" + "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "dev": true }, "@jridgewell/source-map": { "version": "0.3.2", @@ -23613,12 +2249,14 @@ "@jridgewell/sourcemap-codec": { "version": "1.4.14", "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==" + "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", + "dev": true }, "@jridgewell/trace-mapping": { "version": "0.3.17", "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.17.tgz", "integrity": "sha512-MCNzAp77qzKca9+W/+I0+sEpaUnZoeasnghNeVc41VZCEKaCH73Vq3BZZ/SzWIgrqE4H4ceI+p+b6C0mHf9T4g==", + "dev": true, "requires": { "@jridgewell/resolve-uri": "3.1.0", "@jridgewell/sourcemap-codec": "1.4.14" @@ -23688,6 +2326,170 @@ "tslib": "^2.3.1" } }, + "@newfold-labs/js-utility-ui-analytics": { + "version": "1.0.0", + "resolved": "https://npm.pkg.github.com/download/@newfold-labs/js-utility-ui-analytics/1.0.0/1acd013ebbd7f67ae761ae5137d0810c26e5366d", + "integrity": "sha512-CeeboYv+KTc8thnHD+9nZ2VnKn/Y4yuI3MXQsFCTfKEjmUnM6b1NOgN3t34kX/GgL1J1JC/DvO/lqeU+hnQwaQ==", + "requires": { + "@wordpress/api-fetch": "^6.30.0", + "@wordpress/data": "^9.3.0" + }, + "dependencies": { + "@wordpress/api-fetch": { + "version": "6.31.0", + "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.31.0.tgz", + "integrity": "sha512-3l2jT7eD6kOK+GM1qcXsk7BGmmrU+//uT1wWOSpx+x4vpPABKlm7yfPvjHG7SqbgHXQzLD6eFvo/nmwN3JbGNg==", + "requires": { + "@babel/runtime": "^7.16.0", + "@wordpress/i18n": "^4.34.0", + "@wordpress/url": "^3.35.0" + } + }, + "@wordpress/compose": { + "version": "6.11.0", + "resolved": "https://registry.npmjs.org/@wordpress/compose/-/compose-6.11.0.tgz", + "integrity": "sha512-3t6rJhsR1jmCsVvGntK4LCk153w7rR4dZtWnMr4pVJEjoyYU0IkMWz/KKvtQaPKRPaZ5DFVftp0btlyhu+LYnA==", + "requires": { + "@babel/runtime": "^7.16.0", + "@types/mousetrap": "^1.6.8", + "@wordpress/deprecated": "^3.34.0", + "@wordpress/dom": "^3.34.0", + "@wordpress/element": "^5.11.0", + "@wordpress/is-shallow-equal": "^4.34.0", + "@wordpress/keycodes": "^3.34.0", + "@wordpress/priority-queue": "^2.34.0", + "change-case": "^4.1.2", + "clipboard": "^2.0.8", + "mousetrap": "^1.6.5", + "use-memo-one": "^1.1.1" + } + }, + "@wordpress/data": { + "version": "9.4.0", + "resolved": "https://registry.npmjs.org/@wordpress/data/-/data-9.4.0.tgz", + "integrity": "sha512-kmB/riWZzwSSOCagOjl+2ual69DhGYljq/W4MjVuDJshOqP+jna8ecTl+58q5i4jeh01gLHSX7GyJQOGf4jcxQ==", + "requires": { + "@babel/runtime": "^7.16.0", + "@wordpress/compose": "^6.11.0", + "@wordpress/deprecated": "^3.34.0", + "@wordpress/element": "^5.11.0", + "@wordpress/is-shallow-equal": "^4.34.0", + "@wordpress/priority-queue": "^2.34.0", + "@wordpress/private-apis": "^0.16.0", + "@wordpress/redux-routine": "^4.34.0", + "deepmerge": "^4.3.0", + "equivalent-key-map": "^0.2.2", + "is-plain-object": "^5.0.0", + "is-promise": "^4.0.0", + "redux": "^4.1.2", + "turbo-combine-reducers": "^1.0.2", + "use-memo-one": "^1.1.1" + } + }, + "@wordpress/deprecated": { + "version": "3.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/deprecated/-/deprecated-3.34.0.tgz", + "integrity": "sha512-erd4Clun4IeluiFDcppg6Nnf77eP2lXGWihjJsKRmppt96bW5XRFSw4peaeXhwiNQ+4rBid2Khchw8xlizQxTQ==", + "requires": { + "@babel/runtime": "^7.16.0", + "@wordpress/hooks": "^3.34.0" + } + }, + "@wordpress/dom": { + "version": "3.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/dom/-/dom-3.34.0.tgz", + "integrity": "sha512-V2Rksv9uB90qc9akkQjKizantKeNcZNlJe44RWENge70BwLnydZaWbz6o42ROMPWpAiWRbcVXJC83ujmJPLFng==", + "requires": { + "@babel/runtime": "^7.16.0", + "@wordpress/deprecated": "^3.34.0" + } + }, + "@wordpress/element": { + "version": "5.11.0", + "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.11.0.tgz", + "integrity": "sha512-PRmh2LLNsBKVwYGlff3Mq4P87icBin0AgP52wU0BpJw/Eiy4VnCm+PDw9LCEOMCTVIpLeJXN1VUt+yGZ+VzW6w==", + "requires": { + "@babel/runtime": "^7.16.0", + "@types/react": "^18.0.21", + "@types/react-dom": "^18.0.6", + "@wordpress/escape-html": "^2.34.0", + "change-case": "^4.1.2", + "is-plain-object": "^5.0.0", + "react": "^18.2.0", + "react-dom": "^18.2.0" + } + }, + "@wordpress/escape-html": { + "version": "2.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/escape-html/-/escape-html-2.34.0.tgz", + "integrity": "sha512-xVBtkAfQmOeXb76CQESJeChDq1EA73PCUCJNRxRyDhCIyHBYWp+DmtvhXfwwuHnf0haJhQY2iQNqt5eKZPjBdQ==", + "requires": { + "@babel/runtime": "^7.16.0" + } + }, + "@wordpress/i18n": { + "version": "4.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.34.0.tgz", + "integrity": "sha512-rC1Ll/48GNsYHFF8cUU1V+bfqjBtHAsDsB7F8O81tXjfkJDFsNq7J8Gti47lAgeqvQ934y+sj5gAmFaM7A+AdA==", + "requires": { + "@babel/runtime": "^7.16.0", + "@wordpress/hooks": "^3.34.0", + "gettext-parser": "^1.3.1", + "memize": "^2.1.0", + "sprintf-js": "^1.1.1", + "tannin": "^1.2.0" + } + }, + "@wordpress/is-shallow-equal": { + "version": "4.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/is-shallow-equal/-/is-shallow-equal-4.34.0.tgz", + "integrity": "sha512-/KcMrEu9VjSpBYls+NNKvh8z5SRC9lm+qbY9jGQx1i/S3e0Fw+gl/AGMt5o2mLNYaL9V3MGVM4NbINfjEqR+MA==", + "requires": { + "@babel/runtime": "^7.16.0" + } + }, + "@wordpress/keycodes": { + "version": "3.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/keycodes/-/keycodes-3.34.0.tgz", + "integrity": "sha512-gwzOrv+jCYJdMMgCInFQErlxq4FDhJWE8vzBjqZW+meACeyWqVsfLGTfVgc/qWqy/hno+IivfiQbHLCBAO1tFw==", + "requires": { + "@babel/runtime": "^7.16.0", + "@wordpress/i18n": "^4.34.0", + "change-case": "^4.1.2" + } + }, + "@wordpress/priority-queue": { + "version": "2.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/priority-queue/-/priority-queue-2.34.0.tgz", + "integrity": "sha512-JGG0c5QCzb5VxdjlK+/Tow0DEHZg+eyGPXGUtwqobd+bsw1Rz1b4rJPpicx9BxRB6+bkDik/7jpL2vv8X/nQKA==", + "requires": { + "@babel/runtime": "^7.16.0", + "requestidlecallback": "^0.3.0" + } + }, + "@wordpress/redux-routine": { + "version": "4.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/redux-routine/-/redux-routine-4.34.0.tgz", + "integrity": "sha512-enRjrXfXturuFg5+AkR0ZOdEtF16JVP+sGicm+SFWe5lz+/Mbfc4yFQ041XPc1b3jgk2xYG2yA0EUAFNj9aotA==", + "requires": { + "@babel/runtime": "^7.16.0", + "is-plain-object": "^5.0.0", + "is-promise": "^4.0.0", + "rungen": "^0.3.2" + } + }, + "deepmerge": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/deepmerge/-/deepmerge-4.3.1.tgz", + "integrity": "sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==" + }, + "memize": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/memize/-/memize-2.1.0.tgz", + "integrity": "sha512-yywVJy8ctVlN5lNPxsep5urnZ6TTclwPEyigM9M3Bi8vseJBOfqNrGWN/r8NzuIt3PovM323W04blJfGQfQSVg==" + } + } + }, "@newfold-labs/wp-module-ai": { "version": "git+ssh://git@github.com/newfold-labs/js-utility-ai.git#02a51a8706f03f83f76d143252155d84321a00eb", "from": "@newfold-labs/wp-module-ai@github:newfold-labs/js-utility-ai#1.0.0", @@ -23894,57 +2696,49 @@ "version": "6.5.1", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-6.5.1.tgz", "integrity": "sha512-9PYGcXrAxitycIjRmZB+Q0JaN07GZIWaTBIGQzfaZv+qr1n8X1XUEJ5rZ/vx6OVD9RRYlrNnXWExQXcmZeD/BQ==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-plugin-remove-jsx-attribute": { "version": "6.5.0", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-attribute/-/babel-plugin-remove-jsx-attribute-6.5.0.tgz", "integrity": "sha512-8zYdkym7qNyfXpWvu4yq46k41pyNM9SOstoWhKlm+IfdCE1DdnRKeMUPsWIEO/DEkaWxJ8T9esNdG3QwQ93jBA==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-plugin-remove-jsx-empty-expression": { "version": "6.5.0", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-empty-expression/-/babel-plugin-remove-jsx-empty-expression-6.5.0.tgz", "integrity": "sha512-NFdxMq3xA42Kb1UbzCVxplUc0iqSyM9X8kopImvFnB+uSDdzIHOdbs1op8ofAvVRtbg4oZiyRl3fTYeKcOe9Iw==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-plugin-replace-jsx-attribute-value": { "version": "6.5.1", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-replace-jsx-attribute-value/-/babel-plugin-replace-jsx-attribute-value-6.5.1.tgz", "integrity": "sha512-8DPaVVE3fd5JKuIC29dqyMB54sA6mfgki2H2+swh+zNJoynC8pMPzOkidqHOSc6Wj032fhl8Z0TVn1GiPpAiJg==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-plugin-svg-dynamic-title": { "version": "6.5.1", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-dynamic-title/-/babel-plugin-svg-dynamic-title-6.5.1.tgz", "integrity": "sha512-FwOEi0Il72iAzlkaHrlemVurgSQRDFbk0OC8dSvD5fSBPHltNh7JtLsxmZUhjYBZo2PpcU/RJvvi6Q0l7O7ogw==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-plugin-svg-em-dimensions": { "version": "6.5.1", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-em-dimensions/-/babel-plugin-svg-em-dimensions-6.5.1.tgz", "integrity": "sha512-gWGsiwjb4tw+ITOJ86ndY/DZZ6cuXMNE/SjcDRg+HLuCmwpcjOktwRF9WgAiycTqJD/QXqL2f8IzE2Rzh7aVXA==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-plugin-transform-react-native-svg": { "version": "6.5.1", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-react-native-svg/-/babel-plugin-transform-react-native-svg-6.5.1.tgz", "integrity": "sha512-2jT3nTayyYP7kI6aGutkyfJ7UMGtuguD72OjeGLwVNyfPRBD8zQthlvL+fAbAKk5n9ZNcvFkp/b1lZ7VsYqVJg==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-plugin-transform-svg-component": { "version": "6.5.1", "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-svg-component/-/babel-plugin-transform-svg-component-6.5.1.tgz", "integrity": "sha512-a1p6LF5Jt33O3rZoVRBqdxL350oge54iZWHNI6LJB5tQ7EelvD/Mb1mfBiZNAan0dt4i3VArkFRjA4iObuNykQ==", - "dev": true, - "requires": {} + "dev": true }, "@svgr/babel-preset": { "version": "6.5.1", @@ -24861,8 +3655,7 @@ "version": "1.2.0", "resolved": "https://registry.npmjs.org/@webpack-cli/configtest/-/configtest-1.2.0.tgz", "integrity": "sha512-4FB8Tj6xyVkyqjj1OaTqCjXYULB9FMkqQ8yGrZjRDrYh0nOE+7Lhs45WioWQQMV+ceFlE368Ukhe6xdvJM9Egg==", - "dev": true, - "requires": {} + "dev": true }, "@webpack-cli/info": { "version": "1.5.0", @@ -24877,8 +3670,7 @@ "version": "1.7.0", "resolved": "https://registry.npmjs.org/@webpack-cli/serve/-/serve-1.7.0.tgz", "integrity": "sha512-oxnCNGj88fL+xzV+dacXs44HcDwf1ovs3AuEzvP7mqXw7fQntqIhQ1BRmynh4qEKQSSSRSWVyXRjmTbZIX9V2Q==", - "dev": true, - "requires": {} + "dev": true }, "@wordpress/a11y": { "version": "3.25.0", @@ -24927,8 +3719,7 @@ "version": "4.6.0", "resolved": "https://registry.npmjs.org/@wordpress/babel-plugin-import-jsx-pragma/-/babel-plugin-import-jsx-pragma-4.6.0.tgz", "integrity": "sha512-Ca20Qrn31jVZ+6IsrXqBJo81FqVI3LUE63tPYyICFQf6GX7giqTt4GKnHBUDNpbwbHiV6Pk+IlsveYundvCHqw==", - "dev": true, - "requires": {} + "dev": true }, "@wordpress/babel-preset-default": { "version": "7.7.0", @@ -26190,8 +4981,7 @@ "version": "4.8.0", "resolved": "https://registry.npmjs.org/@wordpress/npm-package-json-lint-config/-/npm-package-json-lint-config-4.8.0.tgz", "integrity": "sha512-g6Nx3UL/YEhW0jEAi3PdHJJAtWCvBO0MKtOjvFamC4NyJ7LHEe1QzhxlTToVhbs/AxST3jga0z+atPFAg6UtFg==", - "dev": true, - "requires": {} + "dev": true }, "@wordpress/plugins": { "version": "5.2.0", @@ -26331,8 +5121,7 @@ "version": "2.6.0", "resolved": "https://registry.npmjs.org/@wordpress/prettier-config/-/prettier-config-2.6.0.tgz", "integrity": "sha512-yvs/GhA1HTpgh1gA7sp0yDxRgvXYDvyTgFSIgCBkYYKyNnynED/D140BJjS4s4LGqdCFfEmcib/DHxL5HTWJ4g==", - "dev": true, - "requires": {} + "dev": true }, "@wordpress/primitives": { "version": "3.23.0", @@ -26370,6 +5159,14 @@ "requestidlecallback": "^0.3.0" } }, + "@wordpress/private-apis": { + "version": "0.16.0", + "resolved": "https://registry.npmjs.org/@wordpress/private-apis/-/private-apis-0.16.0.tgz", + "integrity": "sha512-4zNzPgdkyYkJwymK8yfPtZ13VPGErnhdbMWxFKmVmo2OiqcwCGRBqAl6fiG3gZhlHOaZqAAmEniFxY3ew1za1w==", + "requires": { + "@babel/runtime": "^7.16.0" + } + }, "@wordpress/redux-routine": { "version": "4.26.0", "resolved": "https://registry.npmjs.org/@wordpress/redux-routine/-/redux-routine-4.26.0.tgz", @@ -26629,6 +5426,12 @@ "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true }, + "prettier": { + "version": "npm:wp-prettier@2.6.2", + "resolved": "https://registry.npmjs.org/wp-prettier/-/wp-prettier-2.6.2.tgz", + "integrity": "sha512-AV33EzqiFJ3fj+mPlKABN59YFPReLkDxQnj067Z3uEOeRQf3g05WprL0RDuqM7UBhSRo9W1rMSC2KvZmjE5UOA==", + "dev": true + }, "supports-color": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", @@ -26987,15 +5790,13 @@ "version": "1.8.0", "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.8.0.tgz", "integrity": "sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==", - "dev": true, - "requires": {} + "dev": true }, "acorn-jsx": { "version": "5.3.2", "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.3.2.tgz", "integrity": "sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==", - "dev": true, - "requires": {} + "dev": true }, "acorn-walk": { "version": "7.2.0", @@ -27034,8 +5835,7 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/ajv-errors/-/ajv-errors-1.0.1.tgz", "integrity": "sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ==", - "dev": true, - "requires": {} + "dev": true }, "ajv-formats": { "version": "2.1.1", @@ -27070,8 +5870,7 @@ "version": "3.5.2", "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.5.2.tgz", "integrity": "sha512-5p6WTN0DdTGVQk6VjcEju19IgaHudalcfabD7yhDGeA6bcQnmL+CpveLJq/3hvfwd1aof6L386Ougkx6RfyMIQ==", - "dev": true, - "requires": {} + "dev": true }, "algoliasearch": { "version": "4.17.0", @@ -27638,6 +6437,7 @@ "version": "4.21.4", "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.21.4.tgz", "integrity": "sha512-CBHJJdDmgjl3daYjN5Cp5kbTf1mUhZoS+beLklHIvkOWscs83YAhLlF3Wsh/lciQYAcbBJgTOD44VtG31ZM4Hw==", + "dev": true, "requires": { "caniuse-lite": "^1.0.30001400", "electron-to-chromium": "^1.4.251", @@ -27746,7 +6546,8 @@ "caniuse-lite": { "version": "1.0.30001439", "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001439.tgz", - "integrity": "sha512-1MgUzEkoMO6gKfXflStpYgZDlFM7M/ck/bgfVCACO5vnAf0fXoNVHdWtqGU+MYca+4bL9Z5bpOVmR33cWW9G2A==" + "integrity": "sha512-1MgUzEkoMO6gKfXflStpYgZDlFM7M/ck/bgfVCACO5vnAf0fXoNVHdWtqGU+MYca+4bL9Z5bpOVmR33cWW9G2A==", + "dev": true }, "capital-case": { "version": "1.0.4", @@ -28300,8 +7101,7 @@ "version": "6.3.1", "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-6.3.1.tgz", "integrity": "sha512-fBffmak0bPAnyqc/HO8C3n2sHrp9wcqQz6ES9koRF2/mLOVAx9zIQ3Y7R29sYCteTPqMCwns4WYQoCX91Xl3+w==", - "dev": true, - "requires": {} + "dev": true }, "css-functions-list": { "version": "3.1.0", @@ -28446,8 +7246,7 @@ "version": "3.1.0", "resolved": "https://registry.npmjs.org/cssnano-utils/-/cssnano-utils-3.1.0.tgz", "integrity": "sha512-JQNR19/YZhz4psLX/rQ9M83e3z2Wf/HdJbryzte4a3NSuafyp9w/I4U+hx5C2S9g41qlstH7DEWnZaaj83OuEA==", - "dev": true, - "requires": {} + "dev": true }, "csso": { "version": "4.2.0", @@ -28522,6 +7321,7 @@ "version": "4.3.4", "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "dev": true, "requires": { "ms": "2.1.2" } @@ -28839,7 +7639,8 @@ "electron-to-chromium": { "version": "1.4.284", "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.284.tgz", - "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==" + "integrity": "sha512-M8WEXFuKXMYMVr45fo8mq0wUrrJHheiKZf6BArTKk9ZBYCKJEOU5H8cdWgDT+qCVZf7Na4lVUaZsA+h6uA9+PA==", + "dev": true }, "emittery": { "version": "0.8.1", @@ -28988,7 +7789,8 @@ "escalade": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==" + "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "dev": true }, "escape-html": { "version": "1.0.3", @@ -29244,8 +8046,7 @@ "version": "8.5.0", "resolved": "https://registry.npmjs.org/eslint-config-prettier/-/eslint-config-prettier-8.5.0.tgz", "integrity": "sha512-obmWKLUNCnhtQRKc+tmnYuQl0pFU1ibYJQ5BGhTVB08bHe9wC8qUeG7c08dj9XX+AuPj1YSGSQIHl1pnDHZR0Q==", - "dev": true, - "requires": {} + "dev": true }, "eslint-import-resolver-node": { "version": "0.3.6", @@ -29465,8 +8266,7 @@ "version": "4.6.0", "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-4.6.0.tgz", "integrity": "sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==", - "dev": true, - "requires": {} + "dev": true }, "eslint-scope": { "version": "5.1.1", @@ -30187,7 +8987,8 @@ "gensync": { "version": "1.0.0-beta.2", "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.2.tgz", - "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==" + "integrity": "sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==", + "dev": true }, "get-caller-file": { "version": "2.0.5", @@ -30296,7 +9097,8 @@ "globals": { "version": "11.12.0", "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", - "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==" + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==", + "dev": true }, "globby": { "version": "11.1.0", @@ -30643,8 +9445,7 @@ "version": "5.1.0", "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-5.1.0.tgz", "integrity": "sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==", - "dev": true, - "requires": {} + "dev": true }, "ieee754": { "version": "1.2.1", @@ -31879,8 +10680,7 @@ "version": "1.2.3", "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.3.tgz", "integrity": "sha512-+3NpwQEnRoIBtx4fyhblQDPgJI0H1IEIkX7ShLUjPGA7TtUTvI1oiKi3SR4oBR0hQhQR80l4WAe5RrXBwWMA8w==", - "dev": true, - "requires": {} + "dev": true }, "jest-regex-util": { "version": "27.5.1", @@ -32546,7 +11346,8 @@ "jsesc": { "version": "2.5.2", "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==" + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", + "dev": true }, "json-parse-even-better-errors": { "version": "2.3.1", @@ -32574,7 +11375,8 @@ "json5": { "version": "2.2.1", "resolved": "https://registry.npmjs.org/json5/-/json5-2.2.1.tgz", - "integrity": "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==" + "integrity": "sha512-1hqLFMSrGHRHxav9q9gNjJ5EXznIxGVO09xQRrwplcS8qs28pZ8s8hupZAmqDwZUmVZ2Qb2jnyPOWcDH8m8dlA==", + "dev": true }, "jsonc-parser": { "version": "3.0.0", @@ -33253,7 +12055,8 @@ "ms": { "version": "2.1.2", "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==", + "dev": true }, "multicast-dns": { "version": "7.2.5", @@ -33352,7 +12155,8 @@ "node-releases": { "version": "2.0.7", "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-2.0.7.tgz", - "integrity": "sha512-EJ3rzxL9pTWPjk5arA0s0dgXpnyiAbJDE6wHT62g7VsgrgQgmmZ+Ru++M1BFofncWja+Pnn3rEr3fieRySAdKQ==" + "integrity": "sha512-EJ3rzxL9pTWPjk5arA0s0dgXpnyiAbJDE6wHT62g7VsgrgQgmmZ+Ru++M1BFofncWja+Pnn3rEr3fieRySAdKQ==", + "dev": true }, "nopt": { "version": "1.0.10", @@ -33860,7 +12664,8 @@ "picocolors": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.0.0.tgz", - "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==" + "integrity": "sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ==", + "dev": true }, "picomatch": { "version": "2.3.1", @@ -33999,29 +12804,25 @@ "version": "5.1.2", "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-5.1.2.tgz", "integrity": "sha512-+L8208OVbHVF2UQf1iDmRcbdjJkuBF6IS29yBDSiWUIzpYaAhtNl6JYnYm12FnkeCwQqF5LeklOu6rAqgfBZqQ==", - "dev": true, - "requires": {} + "dev": true }, "postcss-discard-duplicates": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-5.1.0.tgz", "integrity": "sha512-zmX3IoSI2aoenxHV6C7plngHWWhUOV3sP1T8y2ifzxzbtnuhk1EdPwm0S1bIUNaJ2eNbWeGLEwzw8huPD67aQw==", - "dev": true, - "requires": {} + "dev": true }, "postcss-discard-empty": { "version": "5.1.1", "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-5.1.1.tgz", "integrity": "sha512-zPz4WljiSuLWsI0ir4Mcnr4qQQ5e1Ukc3i7UfE2XcrwKK2LIPIqE5jxMRxO6GbI3cv//ztXDsXwEWT3BHOGh3A==", - "dev": true, - "requires": {} + "dev": true }, "postcss-discard-overridden": { "version": "5.1.0", "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-5.1.0.tgz", "integrity": "sha512-21nOL7RqWR1kasIVdKs8HNqQJhFxLsyRfAnUDm4Fe4t4mCWL9OJiHvlHPjcd8zc5Myu89b/7wZDnOSjFgeWRtw==", - "dev": true, - "requires": {} + "dev": true }, "postcss-loader": { "version": "6.2.1", @@ -34132,8 +12933,7 @@ "version": "3.0.0", "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-3.0.0.tgz", "integrity": "sha512-bdHleFnP3kZ4NYDhuGlVK+CMrQ/pqUm8bx/oGL93K6gVwiclvX5x0n76fYMKuIGKzlABOy13zsvqjb0f92TEXw==", - "dev": true, - "requires": {} + "dev": true }, "postcss-modules-local-by-default": { "version": "4.0.0", @@ -34168,8 +12968,7 @@ "version": "5.1.0", "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-5.1.0.tgz", "integrity": "sha512-mSgUJ+pd/ldRGVx26p2wz9dNZ7ji6Pn8VWBajMXFf8jk7vUoSrZ2lt/wZR7DtlZYKesmZI680qjr2CeFF2fbUg==", - "dev": true, - "requires": {} + "dev": true }, "postcss-normalize-display-values": { "version": "5.1.0", @@ -34284,15 +13083,13 @@ "version": "6.0.0", "resolved": "https://registry.npmjs.org/postcss-safe-parser/-/postcss-safe-parser-6.0.0.tgz", "integrity": "sha512-FARHN8pwH+WiS2OPCxJI8FuRJpTVnn6ZNFiqAM2aeW2LwTHWWmWgIyKC6cUo0L8aeKiF/14MNvnpls6R2PBeMQ==", - "dev": true, - "requires": {} + "dev": true }, "postcss-scss": { "version": "4.0.6", "resolved": "https://registry.npmjs.org/postcss-scss/-/postcss-scss-4.0.6.tgz", "integrity": "sha512-rLDPhJY4z/i4nVFZ27j9GqLxj1pwxE80eAzUNRMXtcpipFYIeowerzBgG3yJhMtObGEXidtIgbUpQ3eLDsf5OQ==", - "dev": true, - "requires": {} + "dev": true }, "postcss-selector-parser": { "version": "6.0.11", @@ -34340,12 +13137,6 @@ "integrity": "sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==", "dev": true }, - "prettier": { - "version": "npm:wp-prettier@2.6.2", - "resolved": "https://registry.npmjs.org/wp-prettier/-/wp-prettier-2.6.2.tgz", - "integrity": "sha512-AV33EzqiFJ3fj+mPlKABN59YFPReLkDxQnj067Z3uEOeRQf3g05WprL0RDuqM7UBhSRo9W1rMSC2KvZmjE5UOA==", - "dev": true - }, "prettier-linter-helpers": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/prettier-linter-helpers/-/prettier-linter-helpers-1.0.0.tgz", @@ -34503,8 +13294,7 @@ "version": "8.5.0", "resolved": "https://registry.npmjs.org/ws/-/ws-8.5.0.tgz", "integrity": "sha512-BWX0SWVgLPzYwF8lTzEy1egjhS4S4OEAHfsO8o65WOVsrnSRGaSiUaa9e0ggGlkMTtBlmOpEXiie9RUcBO86qg==", - "dev": true, - "requires": {} + "dev": true } } }, @@ -34582,8 +13372,7 @@ "re-resizable": { "version": "6.9.9", "resolved": "https://registry.npmjs.org/re-resizable/-/re-resizable-6.9.9.tgz", - "integrity": "sha512-l+MBlKZffv/SicxDySKEEh42hR6m5bAHfNu3Tvxks2c4Ah+ldnWjfnVRwxo/nxF27SsUsxDS0raAzFuJNKABXA==", - "requires": {} + "integrity": "sha512-l+MBlKZffv/SicxDySKEEh42hR6m5bAHfNu3Tvxks2c4Ah+ldnWjfnVRwxo/nxF27SsUsxDS0raAzFuJNKABXA==" }, "react": { "version": "18.2.0", @@ -34606,8 +13395,7 @@ "react-colorful": { "version": "5.6.1", "resolved": "https://registry.npmjs.org/react-colorful/-/react-colorful-5.6.1.tgz", - "integrity": "sha512-1exovf0uGTGyq5mXQT0zgQ80uvj2PCwvF8zY1RN9/vbJVSjSo3fsB/4L3ObbF7u70NduSiK4xu4Y6q1MHoUGEw==", - "requires": {} + "integrity": "sha512-1exovf0uGTGyq5mXQT0zgQ80uvj2PCwvF8zY1RN9/vbJVSjSo3fsB/4L3ObbF7u70NduSiK4xu4Y6q1MHoUGEw==" }, "react-dom": { "version": "18.2.0", @@ -34802,8 +13590,7 @@ "reakit-utils": { "version": "0.15.2", "resolved": "https://registry.npmjs.org/reakit-utils/-/reakit-utils-0.15.2.tgz", - "integrity": "sha512-i/RYkq+W6hvfFmXw5QW7zvfJJT/K8a4qZ0hjA79T61JAFPGt23DsfxwyBbyK91GZrJ9HMrXFVXWMovsKBc1qEQ==", - "requires": {} + "integrity": "sha512-i/RYkq+W6hvfFmXw5QW7zvfJJT/K8a4qZ0hjA79T61JAFPGt23DsfxwyBbyK91GZrJ9HMrXFVXWMovsKBc1qEQ==" }, "reakit-warning": { "version": "0.6.2", @@ -35193,7 +13980,8 @@ "semver": { "version": "6.3.0", "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", - "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==", + "dev": true }, "send": { "version": "0.18.0", @@ -35785,15 +14573,6 @@ "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", "dev": true }, - "string_decoder": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", - "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", - "dev": true, - "requires": { - "safe-buffer": "~5.2.0" - } - }, "string-length": { "version": "4.0.2", "resolved": "https://registry.npmjs.org/string-length/-/string-length-4.0.2.tgz", @@ -35861,6 +14640,15 @@ "es-abstract": "^1.20.4" } }, + "string_decoder": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "dev": true, + "requires": { + "safe-buffer": "~5.2.0" + } + }, "strip-ansi": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.1.tgz", @@ -36107,8 +14895,7 @@ "version": "6.0.0", "resolved": "https://registry.npmjs.org/stylelint-config-recommended/-/stylelint-config-recommended-6.0.0.tgz", "integrity": "sha512-ZorSSdyMcxWpROYUvLEMm0vSZud2uB7tX1hzBZwvVY9SV/uly4AvvJPPhCcymZL3fcQhEQG5AELmrxWqtmzacw==", - "dev": true, - "requires": {} + "dev": true }, "stylelint-config-recommended-scss": { "version": "5.0.2", @@ -36630,6 +15417,7 @@ "version": "1.0.10", "resolved": "https://registry.npmjs.org/update-browserslist-db/-/update-browserslist-db-1.0.10.tgz", "integrity": "sha512-OztqDenkfFkbSG+tRxBeAnCVPckDBcvibKd35yDONx6OU8N7sqgwc7rCbkJ/WcYtVRZ4ba68d6byhC21GFh7sQ==", + "dev": true, "requires": { "escalade": "^3.1.1", "picocolors": "^1.0.0" @@ -36692,14 +15480,12 @@ "use-memo-one": { "version": "1.1.3", "resolved": "https://registry.npmjs.org/use-memo-one/-/use-memo-one-1.1.3.tgz", - "integrity": "sha512-g66/K7ZQGYrI6dy8GLpVcMsBp4s17xNkYJVSMvTEevGy3nDxHOfE6z8BVE22+5G5x7t3+bhzrlTDB7ObrEE0cQ==", - "requires": {} + "integrity": "sha512-g66/K7ZQGYrI6dy8GLpVcMsBp4s17xNkYJVSMvTEevGy3nDxHOfE6z8BVE22+5G5x7t3+bhzrlTDB7ObrEE0cQ==" }, "use-sync-external-store": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/use-sync-external-store/-/use-sync-external-store-1.2.0.tgz", - "integrity": "sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==", - "requires": {} + "integrity": "sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==" }, "util-deprecate": { "version": "1.0.2", @@ -37151,8 +15937,7 @@ "version": "8.11.0", "resolved": "https://registry.npmjs.org/ws/-/ws-8.11.0.tgz", "integrity": "sha512-HPG3wQd9sNQoT9xHyNCXoDUa+Xw/VevmY9FoHyQ+g+rrMn4j6FB4np7Z0OhdTgjx6MgQLK7jwSy1YecU1+4Asg==", - "dev": true, - "requires": {} + "dev": true } } }, @@ -37361,8 +16146,7 @@ "version": "7.5.9", "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.9.tgz", "integrity": "sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==", - "dev": true, - "requires": {} + "dev": true }, "xml-name-validator": { "version": "3.0.0", diff --git a/package.json b/package.json index 638bbd9..906725a 100644 --- a/package.json +++ b/package.json @@ -16,6 +16,7 @@ "test:e2e": "echo \"No tests implemented\"" }, "dependencies": { + "@newfold-labs/js-utility-ui-analytics": "1.0.0", "@newfold-labs/wp-module-ai": "github:newfold-labs/js-utility-ai#1.0.0", "@wordpress/api-fetch": "6.20.0", "@wordpress/components": "23.0.0", diff --git a/src/components/Feedback.js b/src/components/Feedback.js index f1f9d4d..9c71a07 100644 --- a/src/components/Feedback.js +++ b/src/components/Feedback.js @@ -1,7 +1,7 @@ import { useEffect, useState, useRef } from "@wordpress/element"; import { __ } from "@wordpress/i18n"; // -import { InteractionAPIs } from "../utils"; +import { Analytics, InteractionAPIs } from "../utils"; const Feedback = ({ postId }) => { const [status, setStatus] = useState(""); @@ -11,6 +11,7 @@ const Feedback = ({ postId }) => { const postFeedback = async () => { if (status === "helpful" || status === "notHelpful") { InteractionAPIs.postFeedback(postId, status); + Analytics.sendEvent('feedback', 'status'); } }; diff --git a/src/components/SearchResults.js b/src/components/SearchResults.js index 30cf67a..c21691e 100644 --- a/src/components/SearchResults.js +++ b/src/components/SearchResults.js @@ -7,7 +7,7 @@ import { ReactComponent as SearchIcon } from "../icons/search.svg"; // import { AlgoliaResult } from "./AlgoliaResult"; import { ResultContent } from "./ResultContent"; -import { LocalStorageUtils } from "../utils"; +import { Analytics, LocalStorageUtils } from "../utils"; import Loader from "./Loader"; const SearchResults = () => { @@ -25,6 +25,7 @@ const SearchResults = () => { setPostId(postId); LocalStorageUtils.persistResult(resultContentFormatted, postId); LocalStorageUtils.persistSearchInput(searchInput); + Analytics.sendEvent('search', postId); }; useEffect(() => { diff --git a/src/index.js b/src/index.js index 3ac131e..73b9f3c 100644 --- a/src/index.js +++ b/src/index.js @@ -1,14 +1,20 @@ import { PluginSidebar } from "@wordpress/edit-post"; import React, { render } from "@wordpress/element"; import { registerPlugin } from "@wordpress/plugins"; +import { HiiveAnalytics, HiiveEvent } from "@newfold-labs/js-utility-ui-analytics"; import "../styles.scss"; import HelpCenter from "./components/HelpCenter"; import Modal from "./components/Modal"; import { ReactComponent as Help } from "./icons/help.svg"; -import { LocalStorageUtils } from "./utils"; +import { Analytics, LocalStorageUtils } from "./utils"; -const wpContentContainer = document.getElementById("wpcontent"); +HiiveAnalytics.initialize({ + urls: { + single: window.nfdHelpCenter.restUrl + "/newfold-data/v1/events", + }, +}); +const wpContentContainer = document.getElementById("wpcontent"); export const toggleHelp = (visible) => { wpContentContainer.classList.toggle("wpcontent-container", visible); @@ -22,9 +28,11 @@ window.newfoldEmbeddedHelp.toggleNFDLaunchedEmbeddedHelp = () => { const helpVisible = LocalStorageUtils.getHelpVisible(); if (Object.is(helpVisible, undefined)) { toggleHelp(true); + Analytics.sendEvent("page", "opened"); return; } toggleHelp(!helpVisible); + Analytics.sendEvent("page", "closed"); }; window.newfoldEmbeddedHelp.toggleNFDUnlaunchedEmbeddedHelp = diff --git a/src/utils.js b/src/utils.js index fff69ef..7025352 100644 --- a/src/utils.js +++ b/src/utils.js @@ -1,6 +1,7 @@ +import { HiiveAnalytics, HiiveEvent } from "@newfold-labs/js-utility-ui-analytics"; import apiFetch from "@wordpress/api-fetch"; -const base = "nfd-help/v1"; +const base = "nfd-help-center/v1"; export const InteractionAPIs = { postFeedback: (postId, status) => @@ -39,3 +40,10 @@ export const LocalStorageUtils = { return localStorage.getItem("searchInput"); } } + +export const Analytics = { + sendEvent: (event, data) => { + const hiiveEvent = new HiiveEvent('nfd-help-center', event, { value: data, time: new Date() }); + HiiveAnalytics.send(hiiveEvent); + } +} From e9f977f21b6d93f4fb65bdbb5ec64ca894c1448e Mon Sep 17 00:00:00 2001 From: amartya-dev Date: Wed, 31 May 2023 16:38:50 +0530 Subject: [PATCH 2/2] render help icon only when the person has capability --- includes/HelpCenter.php | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/includes/HelpCenter.php b/includes/HelpCenter.php index 7e0109f..283abf4 100644 --- a/includes/HelpCenter.php +++ b/includes/HelpCenter.php @@ -59,11 +59,11 @@ public function newfold_help_center( \WP_Admin_Bar $admin_bar ) { ), ); $help_enabled = $this->container->get('capabilities')->get( 'canAccessHelpCenter' ); - // if ( $help_enabled ) { + if ( $help_enabled ) { $admin_bar->add_menu( $help_center_menu ); $menu_name = $this->container->plugin()->id . '-help-center'; $admin_bar->remove_menu( $menu_name ); - // } + } } }