diff --git a/frontend/README.md b/frontend/README.md new file mode 100644 index 0000000..58beeac --- /dev/null +++ b/frontend/README.md @@ -0,0 +1,70 @@ +# Getting Started with Create React App + +This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app). + +## Available Scripts + +In the project directory, you can run: + +### `npm start` + +Runs the app in the development mode.\ +Open [http://localhost:3000](http://localhost:3000) to view it in your browser. + +The page will reload when you make changes.\ +You may also see any lint errors in the console. + +### `npm test` + +Launches the test runner in the interactive watch mode.\ +See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information. + +### `npm run build` + +Builds the app for production to the `build` folder.\ +It correctly bundles React in production mode and optimizes the build for the best performance. + +The build is minified and the filenames include the hashes.\ +Your app is ready to be deployed! + +See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information. + +### `npm run eject` + +**Note: this is a one-way operation. Once you `eject`, you can't go back!** + +If you aren't satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project. + +Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point you're on your own. + +You don't have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldn't feel obligated to use this feature. However we understand that this tool wouldn't be useful if you couldn't customize it when you are ready for it. + +## Learn More + +You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started). + +To learn React, check out the [React documentation](https://reactjs.org/). + +### Code Splitting + +This section has moved here: [https://facebook.github.io/create-react-app/docs/code-splitting](https://facebook.github.io/create-react-app/docs/code-splitting) + +### Analyzing the Bundle Size + +This section has moved here: [https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size](https://facebook.github.io/create-react-app/docs/analyzing-the-bundle-size) + +### Making a Progressive Web App + +This section has moved here: [https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app](https://facebook.github.io/create-react-app/docs/making-a-progressive-web-app) + +### Advanced Configuration + +This section has moved here: [https://facebook.github.io/create-react-app/docs/advanced-configuration](https://facebook.github.io/create-react-app/docs/advanced-configuration) + +### Deployment + +This section has moved here: [https://facebook.github.io/create-react-app/docs/deployment](https://facebook.github.io/create-react-app/docs/deployment) + +### `npm run build` fails to minify + +This section has moved here: [https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify](https://facebook.github.io/create-react-app/docs/troubleshooting#npm-run-build-fails-to-minify) diff --git a/frontend/build/asset-manifest.json b/frontend/build/asset-manifest.json new file mode 100644 index 0000000..b59aec1 --- /dev/null +++ b/frontend/build/asset-manifest.json @@ -0,0 +1,16 @@ +{ + "files": { + "main.css": "/static/css/main.266fc98c.css", + "main.js": "/static/js/main.c2248845.js", + "static/js/453.d855a71b.chunk.js": "/static/js/453.d855a71b.chunk.js", + "static/media/robot-logo.png": "/static/media/robot-logo.0e3f28483031c984f239.png", + "index.html": "/index.html", + "main.266fc98c.css.map": "/static/css/main.266fc98c.css.map", + "main.c2248845.js.map": "/static/js/main.c2248845.js.map", + "453.d855a71b.chunk.js.map": "/static/js/453.d855a71b.chunk.js.map" + }, + "entrypoints": [ + "static/css/main.266fc98c.css", + "static/js/main.c2248845.js" + ] +} \ No newline at end of file diff --git a/frontend/build/favicon.ico b/frontend/build/favicon.ico new file mode 100644 index 0000000..a11777c Binary files /dev/null and b/frontend/build/favicon.ico differ diff --git a/frontend/build/index.html b/frontend/build/index.html new file mode 100644 index 0000000..5b1dfdd --- /dev/null +++ b/frontend/build/index.html @@ -0,0 +1 @@ +iRonoc React App | Portfolio | Software Engineer | DevOps | Data Analytics | Conor Heffron
\ No newline at end of file diff --git a/frontend/build/logo192.png b/frontend/build/logo192.png new file mode 100644 index 0000000..fc44b0a Binary files /dev/null and b/frontend/build/logo192.png differ diff --git a/frontend/build/logo512.png b/frontend/build/logo512.png new file mode 100644 index 0000000..a4e47a6 Binary files /dev/null and b/frontend/build/logo512.png differ diff --git a/frontend/build/manifest.json b/frontend/build/manifest.json new file mode 100644 index 0000000..080d6c7 --- /dev/null +++ b/frontend/build/manifest.json @@ -0,0 +1,25 @@ +{ + "short_name": "React App", + "name": "Create React App Sample", + "icons": [ + { + "src": "favicon.ico", + "sizes": "64x64 32x32 24x24 16x16", + "type": "image/x-icon" + }, + { + "src": "logo192.png", + "type": "image/png", + "sizes": "192x192" + }, + { + "src": "logo512.png", + "type": "image/png", + "sizes": "512x512" + } + ], + "start_url": ".", + "display": "standalone", + "theme_color": "#000000", + "background_color": "#ffffff" +} diff --git a/src/main/webapp/static/imgs/robot-logo.png b/frontend/build/robot-logo.png similarity index 100% rename from src/main/webapp/static/imgs/robot-logo.png rename to frontend/build/robot-logo.png diff --git a/frontend/build/robots.txt b/frontend/build/robots.txt new file mode 100644 index 0000000..e9e57dc --- /dev/null +++ b/frontend/build/robots.txt @@ -0,0 +1,3 @@ +# https://www.robotstxt.org/robotstxt.html +User-agent: * +Disallow: diff --git a/frontend/build/static/css/main.266fc98c.css b/frontend/build/static/css/main.266fc98c.css new file mode 100644 index 0000000..a462e75 --- /dev/null +++ b/frontend/build/static/css/main.266fc98c.css @@ -0,0 +1,13 @@ +@charset "UTF-8";/*! + * Bootstrap v5.1.3 (https://getbootstrap.com/) + * Copyright 2011-2021 The Bootstrap Authors + * Copyright 2011-2021 Twitter, Inc. + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) + */body{-webkit-tap-highlight-color:transparent}.carousel-control-next,.carousel-control-prev,.nav-pills .nav-link,.nav-tabs .nav-link{background:0 0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#1d428a;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.carousel-caption{bottom:auto;top:0}.App-intro{content:"";display:inline-block}#my-intro{padding-left:15%;padding-right:15%} +/*! + * Bootstrap v5.1.3 (https://getbootstrap.com/) + * Copyright 2011-2021 The Bootstrap Authors + * Copyright 2011-2021 Twitter, Inc. + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE) + */:root{--bs-blue:#0d6efd;--bs-indigo:#6610f2;--bs-purple:#6f42c1;--bs-pink:#d63384;--bs-red:#dc3545;--bs-orange:#fd7e14;--bs-yellow:#ffc107;--bs-green:#198754;--bs-teal:#20c997;--bs-cyan:#0dcaf0;--bs-white:#fff;--bs-gray:#6c757d;--bs-gray-dark:#343a40;--bs-gray-100:#f8f9fa;--bs-gray-200:#e9ecef;--bs-gray-300:#dee2e6;--bs-gray-400:#ced4da;--bs-gray-500:#adb5bd;--bs-gray-600:#6c757d;--bs-gray-700:#495057;--bs-gray-800:#343a40;--bs-gray-900:#212529;--bs-primary:#0d6efd;--bs-secondary:#6c757d;--bs-success:#198754;--bs-info:#0dcaf0;--bs-warning:#ffc107;--bs-danger:#dc3545;--bs-light:#f8f9fa;--bs-dark:#212529;--bs-primary-rgb:13,110,253;--bs-secondary-rgb:108,117,125;--bs-success-rgb:25,135,84;--bs-info-rgb:13,202,240;--bs-warning-rgb:255,193,7;--bs-danger-rgb:220,53,69;--bs-light-rgb:248,249,250;--bs-dark-rgb:33,37,41;--bs-white-rgb:255,255,255;--bs-black-rgb:0,0,0;--bs-body-color-rgb:33,37,41;--bs-body-bg-rgb:255,255,255;--bs-font-sans-serif:system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Liberation Sans",sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--bs-font-monospace:SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--bs-gradient:linear-gradient(180deg,#ffffff26,#fff0);--bs-body-font-family:var(--bs-font-sans-serif);--bs-body-font-size:1rem;--bs-body-font-weight:400;--bs-body-line-height:1.5;--bs-body-color:#212529;--bs-body-bg:#fff}*,:after,:before{box-sizing:border-box}@media (prefers-reduced-motion:no-preference){:root{scroll-behavior:smooth}}body{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:rgba(0,0,0,0);background-color:#fff;background-color:var(--bs-body-bg);color:#212529;color:var(--bs-body-color);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-family:var(--bs-body-font-family);font-size:1rem;font-size:var(--bs-body-font-size);font-weight:400;font-weight:var(--bs-body-font-weight);line-height:1.5;line-height:var(--bs-body-line-height);margin:0;text-align:var(--bs-body-text-align)}hr{background-color:currentColor;border:0;color:inherit;margin:1rem 0;opacity:.25}hr:not([size]){height:1px}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-weight:500;line-height:1.2;margin-bottom:.5rem;margin-top:0}.h1,h1{font-size:calc(1.375rem + 1.5vw)}@media (min-width:1200px){.h1,h1{font-size:2.5rem}}.h2,h2{font-size:calc(1.325rem + .9vw)}@media (min-width:1200px){.h2,h2{font-size:2rem}}.h3,h3{font-size:calc(1.3rem + .6vw)}@media (min-width:1200px){.h3,h3{font-size:1.75rem}}.h4,h4{font-size:calc(1.275rem + .3vw)}@media (min-width:1200px){.h4,h4{font-size:1.5rem}}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}p{margin-bottom:1rem;margin-top:0}abbr[data-bs-original-title],abbr[title]{cursor:help;-webkit-text-decoration:underline dotted;text-decoration:underline dotted;-webkit-text-decoration-skip-ink:none;text-decoration-skip-ink:none}address{font-style:normal;line-height:inherit;margin-bottom:1rem}ol,ul{padding-left:2rem}dl,ol,ul{margin-bottom:1rem;margin-top:0}ol ol,ol ul,ul ol,ul ul{margin-bottom:0}dt{font-weight:700}dd{margin-bottom:.5rem;margin-left:0}blockquote{margin:0 0 1rem}b,strong{font-weight:bolder}.small,small{font-size:.875em}.mark,mark{background-color:#fcf8e3;padding:.2em}sub,sup{font-size:.75em;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}a{color:#0d6efd;text-decoration:underline}a:hover{color:#0a58ca}a:not([href]):not([class]),a:not([href]):not([class]):hover{color:inherit;text-decoration:none}code,kbd,pre,samp{direction:ltr;font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-family:var(--bs-font-monospace);font-size:1em;unicode-bidi:bidi-override}pre{display:block;font-size:.875em;margin-bottom:1rem;margin-top:0;overflow:auto}pre code{color:inherit;font-size:inherit;word-break:normal}code{word-wrap:break-word;color:#d63384;font-size:.875em}a>code{color:inherit}kbd{background-color:#212529;border-radius:.2rem;color:#fff;font-size:.875em;padding:.2rem .4rem}kbd kbd{font-size:1em;font-weight:700;padding:0}figure{margin:0 0 1rem}img,svg{vertical-align:middle}table{border-collapse:collapse;caption-side:bottom}caption{color:#6c757d;padding-bottom:.5rem;padding-top:.5rem;text-align:left}th{text-align:inherit;text-align:-webkit-match-parent}tbody,td,tfoot,th,thead,tr{border:0 solid;border-color:inherit}label{display:inline-block}button{border-radius:0}button:focus:not(:focus-visible){outline:0}button,input,optgroup,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit;margin:0}button,select{text-transform:none}[role=button]{cursor:pointer}select{word-wrap:normal}select:disabled{opacity:1}[list]::-webkit-calendar-picker-indicator{display:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]:not(:disabled),[type=reset]:not(:disabled),[type=submit]:not(:disabled),button:not(:disabled){cursor:pointer}::-moz-focus-inner{border-style:none;padding:0}textarea{resize:vertical}fieldset{border:0;margin:0;min-width:0;padding:0}legend{float:left;font-size:calc(1.275rem + .3vw);line-height:inherit;margin-bottom:.5rem;padding:0;width:100%}@media (min-width:1200px){legend{font-size:1.5rem}}legend+*{clear:left}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-fields-wrapper,::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute,::-webkit-datetime-edit-month-field,::-webkit-datetime-edit-text,::-webkit-datetime-edit-year-field{padding:0}::-webkit-inner-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-color-swatch-wrapper{padding:0}::file-selector-button{font:inherit}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}output{display:inline-block}iframe{border:0}summary{cursor:pointer;display:list-item}progress{vertical-align:initial}[hidden]{display:none!important}.lead{font-size:1.25rem;font-weight:300}.display-1{font-size:calc(1.625rem + 4.5vw);font-weight:300;line-height:1.2}@media (min-width:1200px){.display-1{font-size:5rem}}.display-2{font-size:calc(1.575rem + 3.9vw);font-weight:300;line-height:1.2}@media (min-width:1200px){.display-2{font-size:4.5rem}}.display-3{font-size:calc(1.525rem + 3.3vw);font-weight:300;line-height:1.2}@media (min-width:1200px){.display-3{font-size:4rem}}.display-4{font-size:calc(1.475rem + 2.7vw);font-weight:300;line-height:1.2}@media (min-width:1200px){.display-4{font-size:3.5rem}}.display-5{font-size:calc(1.425rem + 2.1vw);font-weight:300;line-height:1.2}@media (min-width:1200px){.display-5{font-size:3rem}}.display-6{font-size:calc(1.375rem + 1.5vw);font-weight:300;line-height:1.2}@media (min-width:1200px){.display-6{font-size:2.5rem}}.list-inline,.list-unstyled{list-style:none;padding-left:0}.list-inline-item{display:inline-block}.list-inline-item:not(:last-child){margin-right:.5rem}.initialism{font-size:.875em;text-transform:uppercase}.blockquote{font-size:1.25rem;margin-bottom:1rem}.blockquote>:last-child{margin-bottom:0}.blockquote-footer{color:#6c757d;font-size:.875em;margin-bottom:1rem;margin-top:-1rem}.blockquote-footer:before{content:"— "}.img-fluid,.img-thumbnail{height:auto;max-width:100%}.img-thumbnail{background-color:#fff;border:1px solid #dee2e6;border-radius:.25rem;padding:.25rem}.figure{display:inline-block}.figure-img{line-height:1;margin-bottom:.5rem}.figure-caption{color:#6c757d;font-size:.875em}.container,.container-fluid,.container-lg,.container-md,.container-sm,.container-xl,.container-xxl{margin-left:auto;margin-right:auto;padding-left:.75rem;padding-left:var(--bs-gutter-x,.75rem);padding-right:.75rem;padding-right:var(--bs-gutter-x,.75rem);width:100%}@media (min-width:576px){.container,.container-sm{max-width:540px}}@media (min-width:768px){.container,.container-md,.container-sm{max-width:720px}}@media (min-width:992px){.container,.container-lg,.container-md,.container-sm{max-width:960px}}@media (min-width:1200px){.container,.container-lg,.container-md,.container-sm,.container-xl{max-width:1140px}}@media (min-width:1400px){.container,.container-lg,.container-md,.container-sm,.container-xl,.container-xxl{max-width:1320px}}.row{--bs-gutter-x:1.5rem;--bs-gutter-y:0;display:flex;flex-wrap:wrap;margin-left:calc(var(--bs-gutter-x)*-.5);margin-right:calc(var(--bs-gutter-x)*-.5);margin-top:calc(var(--bs-gutter-y)*-1)}.row>*{flex-shrink:0;margin-top:var(--bs-gutter-y);max-width:100%;padding-left:calc(var(--bs-gutter-x)*.5);padding-right:calc(var(--bs-gutter-x)*.5);width:100%}.col{flex:1 0}.row-cols-auto>*{flex:0 0 auto;width:auto}.row-cols-1>*{flex:0 0 auto;width:100%}.row-cols-2>*{flex:0 0 auto;width:50%}.row-cols-3>*{flex:0 0 auto;width:33.3333333333%}.row-cols-4>*{flex:0 0 auto;width:25%}.row-cols-5>*{flex:0 0 auto;width:20%}.row-cols-6>*{flex:0 0 auto;width:16.6666666667%}.col-auto{flex:0 0 auto;width:auto}.col-1{flex:0 0 auto;width:8.33333333%}.col-2{flex:0 0 auto;width:16.66666667%}.col-3{flex:0 0 auto;width:25%}.col-4{flex:0 0 auto;width:33.33333333%}.col-5{flex:0 0 auto;width:41.66666667%}.col-6{flex:0 0 auto;width:50%}.col-7{flex:0 0 auto;width:58.33333333%}.col-8{flex:0 0 auto;width:66.66666667%}.col-9{flex:0 0 auto;width:75%}.col-10{flex:0 0 auto;width:83.33333333%}.col-11{flex:0 0 auto;width:91.66666667%}.col-12{flex:0 0 auto;width:100%}.offset-1{margin-left:8.33333333%}.offset-2{margin-left:16.66666667%}.offset-3{margin-left:25%}.offset-4{margin-left:33.33333333%}.offset-5{margin-left:41.66666667%}.offset-6{margin-left:50%}.offset-7{margin-left:58.33333333%}.offset-8{margin-left:66.66666667%}.offset-9{margin-left:75%}.offset-10{margin-left:83.33333333%}.offset-11{margin-left:91.66666667%}.g-0,.gx-0{--bs-gutter-x:0}.g-0,.gy-0{--bs-gutter-y:0}.g-1,.gx-1{--bs-gutter-x:0.25rem}.g-1,.gy-1{--bs-gutter-y:0.25rem}.g-2,.gx-2{--bs-gutter-x:0.5rem}.g-2,.gy-2{--bs-gutter-y:0.5rem}.g-3,.gx-3{--bs-gutter-x:1rem}.g-3,.gy-3{--bs-gutter-y:1rem}.g-4,.gx-4{--bs-gutter-x:1.5rem}.g-4,.gy-4{--bs-gutter-y:1.5rem}.g-5,.gx-5{--bs-gutter-x:3rem}.g-5,.gy-5{--bs-gutter-y:3rem}@media (min-width:576px){.col-sm{flex:1 0}.row-cols-sm-auto>*{flex:0 0 auto;width:auto}.row-cols-sm-1>*{flex:0 0 auto;width:100%}.row-cols-sm-2>*{flex:0 0 auto;width:50%}.row-cols-sm-3>*{flex:0 0 auto;width:33.3333333333%}.row-cols-sm-4>*{flex:0 0 auto;width:25%}.row-cols-sm-5>*{flex:0 0 auto;width:20%}.row-cols-sm-6>*{flex:0 0 auto;width:16.6666666667%}.col-sm-auto{flex:0 0 auto;width:auto}.col-sm-1{flex:0 0 auto;width:8.33333333%}.col-sm-2{flex:0 0 auto;width:16.66666667%}.col-sm-3{flex:0 0 auto;width:25%}.col-sm-4{flex:0 0 auto;width:33.33333333%}.col-sm-5{flex:0 0 auto;width:41.66666667%}.col-sm-6{flex:0 0 auto;width:50%}.col-sm-7{flex:0 0 auto;width:58.33333333%}.col-sm-8{flex:0 0 auto;width:66.66666667%}.col-sm-9{flex:0 0 auto;width:75%}.col-sm-10{flex:0 0 auto;width:83.33333333%}.col-sm-11{flex:0 0 auto;width:91.66666667%}.col-sm-12{flex:0 0 auto;width:100%}.offset-sm-0{margin-left:0}.offset-sm-1{margin-left:8.33333333%}.offset-sm-2{margin-left:16.66666667%}.offset-sm-3{margin-left:25%}.offset-sm-4{margin-left:33.33333333%}.offset-sm-5{margin-left:41.66666667%}.offset-sm-6{margin-left:50%}.offset-sm-7{margin-left:58.33333333%}.offset-sm-8{margin-left:66.66666667%}.offset-sm-9{margin-left:75%}.offset-sm-10{margin-left:83.33333333%}.offset-sm-11{margin-left:91.66666667%}.g-sm-0,.gx-sm-0{--bs-gutter-x:0}.g-sm-0,.gy-sm-0{--bs-gutter-y:0}.g-sm-1,.gx-sm-1{--bs-gutter-x:0.25rem}.g-sm-1,.gy-sm-1{--bs-gutter-y:0.25rem}.g-sm-2,.gx-sm-2{--bs-gutter-x:0.5rem}.g-sm-2,.gy-sm-2{--bs-gutter-y:0.5rem}.g-sm-3,.gx-sm-3{--bs-gutter-x:1rem}.g-sm-3,.gy-sm-3{--bs-gutter-y:1rem}.g-sm-4,.gx-sm-4{--bs-gutter-x:1.5rem}.g-sm-4,.gy-sm-4{--bs-gutter-y:1.5rem}.g-sm-5,.gx-sm-5{--bs-gutter-x:3rem}.g-sm-5,.gy-sm-5{--bs-gutter-y:3rem}}@media (min-width:768px){.col-md{flex:1 0}.row-cols-md-auto>*{flex:0 0 auto;width:auto}.row-cols-md-1>*{flex:0 0 auto;width:100%}.row-cols-md-2>*{flex:0 0 auto;width:50%}.row-cols-md-3>*{flex:0 0 auto;width:33.3333333333%}.row-cols-md-4>*{flex:0 0 auto;width:25%}.row-cols-md-5>*{flex:0 0 auto;width:20%}.row-cols-md-6>*{flex:0 0 auto;width:16.6666666667%}.col-md-auto{flex:0 0 auto;width:auto}.col-md-1{flex:0 0 auto;width:8.33333333%}.col-md-2{flex:0 0 auto;width:16.66666667%}.col-md-3{flex:0 0 auto;width:25%}.col-md-4{flex:0 0 auto;width:33.33333333%}.col-md-5{flex:0 0 auto;width:41.66666667%}.col-md-6{flex:0 0 auto;width:50%}.col-md-7{flex:0 0 auto;width:58.33333333%}.col-md-8{flex:0 0 auto;width:66.66666667%}.col-md-9{flex:0 0 auto;width:75%}.col-md-10{flex:0 0 auto;width:83.33333333%}.col-md-11{flex:0 0 auto;width:91.66666667%}.col-md-12{flex:0 0 auto;width:100%}.offset-md-0{margin-left:0}.offset-md-1{margin-left:8.33333333%}.offset-md-2{margin-left:16.66666667%}.offset-md-3{margin-left:25%}.offset-md-4{margin-left:33.33333333%}.offset-md-5{margin-left:41.66666667%}.offset-md-6{margin-left:50%}.offset-md-7{margin-left:58.33333333%}.offset-md-8{margin-left:66.66666667%}.offset-md-9{margin-left:75%}.offset-md-10{margin-left:83.33333333%}.offset-md-11{margin-left:91.66666667%}.g-md-0,.gx-md-0{--bs-gutter-x:0}.g-md-0,.gy-md-0{--bs-gutter-y:0}.g-md-1,.gx-md-1{--bs-gutter-x:0.25rem}.g-md-1,.gy-md-1{--bs-gutter-y:0.25rem}.g-md-2,.gx-md-2{--bs-gutter-x:0.5rem}.g-md-2,.gy-md-2{--bs-gutter-y:0.5rem}.g-md-3,.gx-md-3{--bs-gutter-x:1rem}.g-md-3,.gy-md-3{--bs-gutter-y:1rem}.g-md-4,.gx-md-4{--bs-gutter-x:1.5rem}.g-md-4,.gy-md-4{--bs-gutter-y:1.5rem}.g-md-5,.gx-md-5{--bs-gutter-x:3rem}.g-md-5,.gy-md-5{--bs-gutter-y:3rem}}@media (min-width:992px){.col-lg{flex:1 0}.row-cols-lg-auto>*{flex:0 0 auto;width:auto}.row-cols-lg-1>*{flex:0 0 auto;width:100%}.row-cols-lg-2>*{flex:0 0 auto;width:50%}.row-cols-lg-3>*{flex:0 0 auto;width:33.3333333333%}.row-cols-lg-4>*{flex:0 0 auto;width:25%}.row-cols-lg-5>*{flex:0 0 auto;width:20%}.row-cols-lg-6>*{flex:0 0 auto;width:16.6666666667%}.col-lg-auto{flex:0 0 auto;width:auto}.col-lg-1{flex:0 0 auto;width:8.33333333%}.col-lg-2{flex:0 0 auto;width:16.66666667%}.col-lg-3{flex:0 0 auto;width:25%}.col-lg-4{flex:0 0 auto;width:33.33333333%}.col-lg-5{flex:0 0 auto;width:41.66666667%}.col-lg-6{flex:0 0 auto;width:50%}.col-lg-7{flex:0 0 auto;width:58.33333333%}.col-lg-8{flex:0 0 auto;width:66.66666667%}.col-lg-9{flex:0 0 auto;width:75%}.col-lg-10{flex:0 0 auto;width:83.33333333%}.col-lg-11{flex:0 0 auto;width:91.66666667%}.col-lg-12{flex:0 0 auto;width:100%}.offset-lg-0{margin-left:0}.offset-lg-1{margin-left:8.33333333%}.offset-lg-2{margin-left:16.66666667%}.offset-lg-3{margin-left:25%}.offset-lg-4{margin-left:33.33333333%}.offset-lg-5{margin-left:41.66666667%}.offset-lg-6{margin-left:50%}.offset-lg-7{margin-left:58.33333333%}.offset-lg-8{margin-left:66.66666667%}.offset-lg-9{margin-left:75%}.offset-lg-10{margin-left:83.33333333%}.offset-lg-11{margin-left:91.66666667%}.g-lg-0,.gx-lg-0{--bs-gutter-x:0}.g-lg-0,.gy-lg-0{--bs-gutter-y:0}.g-lg-1,.gx-lg-1{--bs-gutter-x:0.25rem}.g-lg-1,.gy-lg-1{--bs-gutter-y:0.25rem}.g-lg-2,.gx-lg-2{--bs-gutter-x:0.5rem}.g-lg-2,.gy-lg-2{--bs-gutter-y:0.5rem}.g-lg-3,.gx-lg-3{--bs-gutter-x:1rem}.g-lg-3,.gy-lg-3{--bs-gutter-y:1rem}.g-lg-4,.gx-lg-4{--bs-gutter-x:1.5rem}.g-lg-4,.gy-lg-4{--bs-gutter-y:1.5rem}.g-lg-5,.gx-lg-5{--bs-gutter-x:3rem}.g-lg-5,.gy-lg-5{--bs-gutter-y:3rem}}@media (min-width:1200px){.col-xl{flex:1 0}.row-cols-xl-auto>*{flex:0 0 auto;width:auto}.row-cols-xl-1>*{flex:0 0 auto;width:100%}.row-cols-xl-2>*{flex:0 0 auto;width:50%}.row-cols-xl-3>*{flex:0 0 auto;width:33.3333333333%}.row-cols-xl-4>*{flex:0 0 auto;width:25%}.row-cols-xl-5>*{flex:0 0 auto;width:20%}.row-cols-xl-6>*{flex:0 0 auto;width:16.6666666667%}.col-xl-auto{flex:0 0 auto;width:auto}.col-xl-1{flex:0 0 auto;width:8.33333333%}.col-xl-2{flex:0 0 auto;width:16.66666667%}.col-xl-3{flex:0 0 auto;width:25%}.col-xl-4{flex:0 0 auto;width:33.33333333%}.col-xl-5{flex:0 0 auto;width:41.66666667%}.col-xl-6{flex:0 0 auto;width:50%}.col-xl-7{flex:0 0 auto;width:58.33333333%}.col-xl-8{flex:0 0 auto;width:66.66666667%}.col-xl-9{flex:0 0 auto;width:75%}.col-xl-10{flex:0 0 auto;width:83.33333333%}.col-xl-11{flex:0 0 auto;width:91.66666667%}.col-xl-12{flex:0 0 auto;width:100%}.offset-xl-0{margin-left:0}.offset-xl-1{margin-left:8.33333333%}.offset-xl-2{margin-left:16.66666667%}.offset-xl-3{margin-left:25%}.offset-xl-4{margin-left:33.33333333%}.offset-xl-5{margin-left:41.66666667%}.offset-xl-6{margin-left:50%}.offset-xl-7{margin-left:58.33333333%}.offset-xl-8{margin-left:66.66666667%}.offset-xl-9{margin-left:75%}.offset-xl-10{margin-left:83.33333333%}.offset-xl-11{margin-left:91.66666667%}.g-xl-0,.gx-xl-0{--bs-gutter-x:0}.g-xl-0,.gy-xl-0{--bs-gutter-y:0}.g-xl-1,.gx-xl-1{--bs-gutter-x:0.25rem}.g-xl-1,.gy-xl-1{--bs-gutter-y:0.25rem}.g-xl-2,.gx-xl-2{--bs-gutter-x:0.5rem}.g-xl-2,.gy-xl-2{--bs-gutter-y:0.5rem}.g-xl-3,.gx-xl-3{--bs-gutter-x:1rem}.g-xl-3,.gy-xl-3{--bs-gutter-y:1rem}.g-xl-4,.gx-xl-4{--bs-gutter-x:1.5rem}.g-xl-4,.gy-xl-4{--bs-gutter-y:1.5rem}.g-xl-5,.gx-xl-5{--bs-gutter-x:3rem}.g-xl-5,.gy-xl-5{--bs-gutter-y:3rem}}@media (min-width:1400px){.col-xxl{flex:1 0}.row-cols-xxl-auto>*{flex:0 0 auto;width:auto}.row-cols-xxl-1>*{flex:0 0 auto;width:100%}.row-cols-xxl-2>*{flex:0 0 auto;width:50%}.row-cols-xxl-3>*{flex:0 0 auto;width:33.3333333333%}.row-cols-xxl-4>*{flex:0 0 auto;width:25%}.row-cols-xxl-5>*{flex:0 0 auto;width:20%}.row-cols-xxl-6>*{flex:0 0 auto;width:16.6666666667%}.col-xxl-auto{flex:0 0 auto;width:auto}.col-xxl-1{flex:0 0 auto;width:8.33333333%}.col-xxl-2{flex:0 0 auto;width:16.66666667%}.col-xxl-3{flex:0 0 auto;width:25%}.col-xxl-4{flex:0 0 auto;width:33.33333333%}.col-xxl-5{flex:0 0 auto;width:41.66666667%}.col-xxl-6{flex:0 0 auto;width:50%}.col-xxl-7{flex:0 0 auto;width:58.33333333%}.col-xxl-8{flex:0 0 auto;width:66.66666667%}.col-xxl-9{flex:0 0 auto;width:75%}.col-xxl-10{flex:0 0 auto;width:83.33333333%}.col-xxl-11{flex:0 0 auto;width:91.66666667%}.col-xxl-12{flex:0 0 auto;width:100%}.offset-xxl-0{margin-left:0}.offset-xxl-1{margin-left:8.33333333%}.offset-xxl-2{margin-left:16.66666667%}.offset-xxl-3{margin-left:25%}.offset-xxl-4{margin-left:33.33333333%}.offset-xxl-5{margin-left:41.66666667%}.offset-xxl-6{margin-left:50%}.offset-xxl-7{margin-left:58.33333333%}.offset-xxl-8{margin-left:66.66666667%}.offset-xxl-9{margin-left:75%}.offset-xxl-10{margin-left:83.33333333%}.offset-xxl-11{margin-left:91.66666667%}.g-xxl-0,.gx-xxl-0{--bs-gutter-x:0}.g-xxl-0,.gy-xxl-0{--bs-gutter-y:0}.g-xxl-1,.gx-xxl-1{--bs-gutter-x:0.25rem}.g-xxl-1,.gy-xxl-1{--bs-gutter-y:0.25rem}.g-xxl-2,.gx-xxl-2{--bs-gutter-x:0.5rem}.g-xxl-2,.gy-xxl-2{--bs-gutter-y:0.5rem}.g-xxl-3,.gx-xxl-3{--bs-gutter-x:1rem}.g-xxl-3,.gy-xxl-3{--bs-gutter-y:1rem}.g-xxl-4,.gx-xxl-4{--bs-gutter-x:1.5rem}.g-xxl-4,.gy-xxl-4{--bs-gutter-y:1.5rem}.g-xxl-5,.gx-xxl-5{--bs-gutter-x:3rem}.g-xxl-5,.gy-xxl-5{--bs-gutter-y:3rem}}.table{--bs-table-bg:#0000;--bs-table-accent-bg:#0000;--bs-table-striped-color:#212529;--bs-table-striped-bg:#0000000d;--bs-table-active-color:#212529;--bs-table-active-bg:#0000001a;--bs-table-hover-color:#212529;--bs-table-hover-bg:rgba(0,0,0,.075);border-color:#dee2e6;color:#212529;margin-bottom:1rem;vertical-align:top;width:100%}.table>:not(caption)>*>*{background-color:var(--bs-table-bg);border-bottom-width:1px;box-shadow:inset 0 0 0 9999px var(--bs-table-accent-bg);padding:.5rem}.table>tbody{vertical-align:inherit}.table>thead{vertical-align:bottom}.table>:not(:first-child){border-top:2px solid}.caption-top{caption-side:top}.table-sm>:not(caption)>*>*{padding:.25rem}.table-bordered>:not(caption)>*{border-width:1px 0}.table-bordered>:not(caption)>*>*{border-width:0 1px}.table-borderless>:not(caption)>*>*{border-bottom-width:0}.table-borderless>:not(:first-child){border-top-width:0}.table-striped>tbody>tr:nth-of-type(odd)>*{--bs-table-accent-bg:var(--bs-table-striped-bg);color:var(--bs-table-striped-color)}.table-active{--bs-table-accent-bg:var(--bs-table-active-bg);color:var(--bs-table-active-color)}.table-hover>tbody>tr:hover>*{--bs-table-accent-bg:var(--bs-table-hover-bg);color:var(--bs-table-hover-color)}.table-primary{--bs-table-bg:#cfe2ff;--bs-table-striped-bg:#c5d7f2;--bs-table-striped-color:#000;--bs-table-active-bg:#bacbe6;--bs-table-active-color:#000;--bs-table-hover-bg:#bfd1ec;--bs-table-hover-color:#000;border-color:#bacbe6;color:#000}.table-secondary{--bs-table-bg:#e2e3e5;--bs-table-striped-bg:#d7d8da;--bs-table-striped-color:#000;--bs-table-active-bg:#cbccce;--bs-table-active-color:#000;--bs-table-hover-bg:#d1d2d4;--bs-table-hover-color:#000;border-color:#cbccce;color:#000}.table-success{--bs-table-bg:#d1e7dd;--bs-table-striped-bg:#c7dbd2;--bs-table-striped-color:#000;--bs-table-active-bg:#bcd0c7;--bs-table-active-color:#000;--bs-table-hover-bg:#c1d6cc;--bs-table-hover-color:#000;border-color:#bcd0c7;color:#000}.table-info{--bs-table-bg:#cff4fc;--bs-table-striped-bg:#c5e8ef;--bs-table-striped-color:#000;--bs-table-active-bg:#badce3;--bs-table-active-color:#000;--bs-table-hover-bg:#bfe2e9;--bs-table-hover-color:#000;border-color:#badce3;color:#000}.table-warning{--bs-table-bg:#fff3cd;--bs-table-striped-bg:#f2e7c3;--bs-table-striped-color:#000;--bs-table-active-bg:#e6dbb9;--bs-table-active-color:#000;--bs-table-hover-bg:#ece1be;--bs-table-hover-color:#000;border-color:#e6dbb9;color:#000}.table-danger{--bs-table-bg:#f8d7da;--bs-table-striped-bg:#eccccf;--bs-table-striped-color:#000;--bs-table-active-bg:#dfc2c4;--bs-table-active-color:#000;--bs-table-hover-bg:#e5c7ca;--bs-table-hover-color:#000;border-color:#dfc2c4;color:#000}.table-light{--bs-table-bg:#f8f9fa;--bs-table-striped-bg:#ecedee;--bs-table-striped-color:#000;--bs-table-active-bg:#dfe0e1;--bs-table-active-color:#000;--bs-table-hover-bg:#e5e6e7;--bs-table-hover-color:#000;border-color:#dfe0e1;color:#000}.table-dark{--bs-table-bg:#212529;--bs-table-striped-bg:#2c3034;--bs-table-striped-color:#fff;--bs-table-active-bg:#373b3e;--bs-table-active-color:#fff;--bs-table-hover-bg:#323539;--bs-table-hover-color:#fff;border-color:#373b3e;color:#fff}.table-responsive{-webkit-overflow-scrolling:touch;overflow-x:auto}@media (max-width:575.98px){.table-responsive-sm{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:767.98px){.table-responsive-md{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:991.98px){.table-responsive-lg{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:1199.98px){.table-responsive-xl{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (max-width:1399.98px){.table-responsive-xxl{-webkit-overflow-scrolling:touch;overflow-x:auto}}.form-label{margin-bottom:.5rem}.col-form-label{font-size:inherit;line-height:1.5;margin-bottom:0;padding-bottom:calc(.375rem + 1px);padding-top:calc(.375rem + 1px)}.col-form-label-lg{font-size:1.25rem;padding-bottom:calc(.5rem + 1px);padding-top:calc(.5rem + 1px)}.col-form-label-sm{font-size:.875rem;padding-bottom:calc(.25rem + 1px);padding-top:calc(.25rem + 1px)}.form-text{color:#6c757d;font-size:.875em;margin-top:.25rem}.form-control{-webkit-appearance:none;appearance:none;background-clip:padding-box;background-color:#fff;border:1px solid #ced4da;border-radius:.25rem;color:#212529;display:block;font-size:1rem;font-weight:400;line-height:1.5;padding:.375rem .75rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}@media (prefers-reduced-motion:reduce){.form-control{transition:none}}.form-control[type=file]{overflow:hidden}.form-control[type=file]:not(:disabled):not([readonly]){cursor:pointer}.form-control:focus{background-color:#fff;border-color:#86b7fe;box-shadow:0 0 0 .25rem #0d6efd40;color:#212529;outline:0}.form-control::-webkit-date-and-time-value{height:1.5em}.form-control::placeholder{color:#6c757d;opacity:1}.form-control:disabled,.form-control[readonly]{background-color:#e9ecef;opacity:1}.form-control::file-selector-button{background-color:#e9ecef;border:0 solid;border-color:inherit;border-inline-end-width:1px;border-radius:0;color:#212529;margin:-.375rem -.75rem;margin-inline-end:.75rem;padding:.375rem .75rem;pointer-events:none;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-control::file-selector-button{transition:none}}.form-control:hover:not(:disabled):not([readonly])::file-selector-button{background-color:#dde0e3}.form-control::-webkit-file-upload-button{background-color:#e9ecef;border:0 solid;border-color:inherit;border-inline-end-width:1px;border-radius:0;color:#212529;margin:-.375rem -.75rem;margin-inline-end:.75rem;padding:.375rem .75rem;pointer-events:none;-webkit-transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.form-control::-webkit-file-upload-button{-webkit-transition:none;transition:none}}.form-control:hover:not(:disabled):not([readonly])::-webkit-file-upload-button{background-color:#dde0e3}.form-control-plaintext{background-color:initial;border:solid #0000;border-width:1px 0;color:#212529;display:block;line-height:1.5;margin-bottom:0;padding:.375rem 0;width:100%}.form-control-plaintext.form-control-lg,.form-control-plaintext.form-control-sm{padding-left:0;padding-right:0}.form-control-sm{border-radius:.2rem;font-size:.875rem;min-height:calc(1.5em + .5rem + 2px);padding:.25rem .5rem}.form-control-sm::file-selector-button{margin:-.25rem -.5rem;margin-inline-end:.5rem;padding:.25rem .5rem}.form-control-sm::-webkit-file-upload-button{margin:-.25rem -.5rem;margin-inline-end:.5rem;padding:.25rem .5rem}.form-control-lg{border-radius:.3rem;font-size:1.25rem;min-height:calc(1.5em + 1rem + 2px);padding:.5rem 1rem}.form-control-lg::file-selector-button{margin:-.5rem -1rem;margin-inline-end:1rem;padding:.5rem 1rem}.form-control-lg::-webkit-file-upload-button{margin:-.5rem -1rem;margin-inline-end:1rem;padding:.5rem 1rem}textarea.form-control{min-height:calc(1.5em + .75rem + 2px)}textarea.form-control-sm{min-height:calc(1.5em + .5rem + 2px)}textarea.form-control-lg{min-height:calc(1.5em + 1rem + 2px)}.form-control-color{height:auto;padding:.375rem;width:3rem}.form-control-color:not(:disabled):not([readonly]){cursor:pointer}.form-control-color::-moz-color-swatch{border-radius:.25rem;height:1.5em}.form-control-color::-webkit-color-swatch{border-radius:.25rem;height:1.5em}.form-select{-moz-padding-start:calc(.75rem - 3px);-webkit-appearance:none;appearance:none;background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;background-size:16px 12px;border:1px solid #ced4da;border-radius:.25rem;color:#212529;display:block;font-size:1rem;font-weight:400;line-height:1.5;padding:.375rem 2.25rem .375rem .75rem;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:100%}@media (prefers-reduced-motion:reduce){.form-select{transition:none}}.form-select:focus{border-color:#86b7fe;box-shadow:0 0 0 .25rem #0d6efd40;outline:0}.form-select[multiple],.form-select[size]:not([size="1"]){background-image:none;padding-right:.75rem}.form-select:disabled{background-color:#e9ecef}.form-select:-moz-focusring{color:#0000;text-shadow:0 0 0 #212529}.form-select-sm{border-radius:.2rem;font-size:.875rem;padding-bottom:.25rem;padding-left:.5rem;padding-top:.25rem}.form-select-lg{border-radius:.3rem;font-size:1.25rem;padding-bottom:.5rem;padding-left:1rem;padding-top:.5rem}.form-check{display:block;margin-bottom:.125rem;min-height:1.5rem;padding-left:1.5em}.form-check .form-check-input{float:left;margin-left:-1.5em}.form-check-input{color-adjust:exact;-webkit-appearance:none;appearance:none;background-color:#fff;background-position:50%;background-repeat:no-repeat;background-size:contain;border:1px solid #00000040;height:1em;margin-top:.25em;-webkit-print-color-adjust:exact;vertical-align:top;width:1em}.form-check-input[type=checkbox]{border-radius:.25em}.form-check-input[type=radio]{border-radius:50%}.form-check-input:active{filter:brightness(90%)}.form-check-input:focus{border-color:#86b7fe;box-shadow:0 0 0 .25rem #0d6efd40;outline:0}.form-check-input:checked{background-color:#0d6efd;border-color:#0d6efd}.form-check-input:checked[type=checkbox]{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3E%3C/svg%3E")}.form-check-input:checked[type=radio]{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='2' fill='%23fff'/%3E%3C/svg%3E")}.form-check-input[type=checkbox]:indeterminate{background-color:#0d6efd;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3E%3Cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/%3E%3C/svg%3E");border-color:#0d6efd}.form-check-input:disabled{filter:none;opacity:.5;pointer-events:none}.form-check-input:disabled~.form-check-label,.form-check-input[disabled]~.form-check-label{opacity:.5}.form-switch{padding-left:2.5em}.form-switch .form-check-input{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='rgba(0, 0, 0, 0.25)'/%3E%3C/svg%3E");background-position:0;border-radius:2em;margin-left:-2.5em;transition:background-position .15s ease-in-out;width:2em}@media (prefers-reduced-motion:reduce){.form-switch .form-check-input{transition:none}}.form-switch .form-check-input:focus{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%2386b7fe'/%3E%3C/svg%3E")}.form-switch .form-check-input:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3E%3Ccircle r='3' fill='%23fff'/%3E%3C/svg%3E");background-position:100%}.form-check-inline{display:inline-block;margin-right:1rem}.btn-check{clip:rect(0,0,0,0);pointer-events:none;position:absolute}.btn-check:disabled+.btn,.btn-check[disabled]+.btn{filter:none;opacity:.65;pointer-events:none}.form-range{-webkit-appearance:none;appearance:none;background-color:initial;height:1.5rem;padding:0;width:100%}.form-range:focus{outline:0}.form-range:focus::-webkit-slider-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .25rem #0d6efd40}.form-range:focus::-moz-range-thumb{box-shadow:0 0 0 1px #fff,0 0 0 .25rem #0d6efd40}.form-range::-moz-focus-outer{border:0}.form-range::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background-color:#0d6efd;border:0;border-radius:1rem;height:1rem;margin-top:-.25rem;-webkit-transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:1rem}@media (prefers-reduced-motion:reduce){.form-range::-webkit-slider-thumb{-webkit-transition:none;transition:none}}.form-range::-webkit-slider-thumb:active{background-color:#b6d4fe}.form-range::-webkit-slider-runnable-track{background-color:#dee2e6;border-color:#0000;border-radius:1rem;color:#0000;cursor:pointer;height:.5rem;width:100%}.form-range::-moz-range-thumb{appearance:none;background-color:#0d6efd;border:0;border-radius:1rem;height:1rem;-moz-transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;transition:background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;width:1rem}@media (prefers-reduced-motion:reduce){.form-range::-moz-range-thumb{-moz-transition:none;transition:none}}.form-range::-moz-range-thumb:active{background-color:#b6d4fe}.form-range::-moz-range-track{background-color:#dee2e6;border-color:#0000;border-radius:1rem;color:#0000;cursor:pointer;height:.5rem;width:100%}.form-range:disabled{pointer-events:none}.form-range:disabled::-webkit-slider-thumb{background-color:#adb5bd}.form-range:disabled::-moz-range-thumb{background-color:#adb5bd}.form-floating{position:relative}.form-floating>.form-control,.form-floating>.form-select{height:calc(3.5rem + 2px);line-height:1.25}.form-floating>label{border:1px solid #0000;height:100%;left:0;padding:1rem .75rem;pointer-events:none;position:absolute;top:0;transform-origin:0 0;transition:opacity .1s ease-in-out,transform .1s ease-in-out}@media (prefers-reduced-motion:reduce){.form-floating>label{transition:none}}.form-floating>.form-control{padding:1rem .75rem}.form-floating>.form-control::placeholder{color:#0000}.form-floating>.form-control:focus,.form-floating>.form-control:not(:placeholder-shown){padding-bottom:.625rem;padding-top:1.625rem}.form-floating>.form-control:-webkit-autofill{padding-bottom:.625rem;padding-top:1.625rem}.form-floating>.form-select{padding-bottom:.625rem;padding-top:1.625rem}.form-floating>.form-control:focus~label,.form-floating>.form-control:not(:placeholder-shown)~label,.form-floating>.form-select~label{opacity:.65;transform:scale(.85) translateY(-.5rem) translateX(.15rem)}.form-floating>.form-control:-webkit-autofill~label{opacity:.65;transform:scale(.85) translateY(-.5rem) translateX(.15rem)}.input-group{align-items:stretch;display:flex;flex-wrap:wrap;position:relative;width:100%}.input-group>.form-control,.input-group>.form-select{flex:1 1 auto;min-width:0;position:relative;width:1%}.input-group>.form-control:focus,.input-group>.form-select:focus{z-index:3}.input-group .btn{position:relative;z-index:2}.input-group .btn:focus{z-index:3}.input-group-text{align-items:center;background-color:#e9ecef;border:1px solid #ced4da;border-radius:.25rem;color:#212529;display:flex;font-size:1rem;font-weight:400;line-height:1.5;padding:.375rem .75rem;text-align:center;white-space:nowrap}.input-group-lg>.btn,.input-group-lg>.form-control,.input-group-lg>.form-select,.input-group-lg>.input-group-text{border-radius:.3rem;font-size:1.25rem;padding:.5rem 1rem}.input-group-sm>.btn,.input-group-sm>.form-control,.input-group-sm>.form-select,.input-group-sm>.input-group-text{border-radius:.2rem;font-size:.875rem;padding:.25rem .5rem}.input-group-lg>.form-select,.input-group-sm>.form-select{padding-right:3rem}.input-group.has-validation>.dropdown-toggle:nth-last-child(n+4),.input-group.has-validation>:nth-last-child(n+3):not(.dropdown-toggle):not(.dropdown-menu),.input-group:not(.has-validation)>.dropdown-toggle:nth-last-child(n+3),.input-group:not(.has-validation)>:not(:last-child):not(.dropdown-toggle):not(.dropdown-menu){border-bottom-right-radius:0;border-top-right-radius:0}.input-group>:not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback){border-bottom-left-radius:0;border-top-left-radius:0;margin-left:-1px}.valid-feedback{color:#198754;display:none;font-size:.875em;margin-top:.25rem;width:100%}.valid-tooltip{background-color:#198754e6;border-radius:.25rem;color:#fff;display:none;font-size:.875rem;margin-top:.1rem;max-width:100%;padding:.25rem .5rem;position:absolute;top:100%;z-index:5}.is-valid~.valid-feedback,.is-valid~.valid-tooltip,.was-validated :valid~.valid-feedback,.was-validated :valid~.valid-tooltip{display:block}.form-control.is-valid,.was-validated .form-control:valid{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3E%3C/svg%3E");background-position:right calc(.375em + .1875rem) center;background-repeat:no-repeat;background-size:calc(.75em + .375rem) calc(.75em + .375rem);border-color:#198754;padding-right:calc(1.5em + .75rem)}.form-control.is-valid:focus,.was-validated .form-control:valid:focus{border-color:#198754;box-shadow:0 0 0 .25rem #19875440}.was-validated textarea.form-control:valid,textarea.form-control.is-valid{background-position:top calc(.375em + .1875rem) right calc(.375em + .1875rem);padding-right:calc(1.5em + .75rem)}.form-select.is-valid,.was-validated .form-select:valid{border-color:#198754}.form-select.is-valid:not([multiple]):not([size]),.form-select.is-valid:not([multiple])[size="1"],.was-validated .form-select:valid:not([multiple]):not([size]),.was-validated .form-select:valid:not([multiple])[size="1"]{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3E%3C/svg%3E"),url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3E%3Cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1z'/%3E%3C/svg%3E");background-position:right .75rem center,center right 2.25rem;background-size:16px 12px,calc(.75em + .375rem) calc(.75em + .375rem);padding-right:4.125rem}.form-select.is-valid:focus,.was-validated .form-select:valid:focus{border-color:#198754;box-shadow:0 0 0 .25rem #19875440}.form-check-input.is-valid,.was-validated .form-check-input:valid{border-color:#198754}.form-check-input.is-valid:checked,.was-validated .form-check-input:valid:checked{background-color:#198754}.form-check-input.is-valid:focus,.was-validated .form-check-input:valid:focus{box-shadow:0 0 0 .25rem #19875440}.form-check-input.is-valid~.form-check-label,.was-validated .form-check-input:valid~.form-check-label{color:#198754}.form-check-inline .form-check-input~.valid-feedback{margin-left:.5em}.input-group .form-control.is-valid,.input-group .form-select.is-valid,.was-validated .input-group .form-control:valid,.was-validated .input-group .form-select:valid{z-index:1}.input-group .form-control.is-valid:focus,.input-group .form-select.is-valid:focus,.was-validated .input-group .form-control:valid:focus,.was-validated .input-group .form-select:valid:focus{z-index:3}.invalid-feedback{color:#dc3545;display:none;font-size:.875em;margin-top:.25rem;width:100%}.invalid-tooltip{background-color:#dc3545e6;border-radius:.25rem;color:#fff;display:none;font-size:.875rem;margin-top:.1rem;max-width:100%;padding:.25rem .5rem;position:absolute;top:100%;z-index:5}.is-invalid~.invalid-feedback,.is-invalid~.invalid-tooltip,.was-validated :invalid~.invalid-feedback,.was-validated :invalid~.invalid-tooltip{display:block}.form-control.is-invalid,.was-validated .form-control:invalid{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545'%3E%3Ccircle cx='6' cy='6' r='4.5'/%3E%3Cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3E%3Ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3E%3C/svg%3E");background-position:right calc(.375em + .1875rem) center;background-repeat:no-repeat;background-size:calc(.75em + .375rem) calc(.75em + .375rem);border-color:#dc3545;padding-right:calc(1.5em + .75rem)}.form-control.is-invalid:focus,.was-validated .form-control:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .25rem #dc354540}.was-validated textarea.form-control:invalid,textarea.form-control.is-invalid{background-position:top calc(.375em + .1875rem) right calc(.375em + .1875rem);padding-right:calc(1.5em + .75rem)}.form-select.is-invalid,.was-validated .form-select:invalid{border-color:#dc3545}.form-select.is-invalid:not([multiple]):not([size]),.form-select.is-invalid:not([multiple])[size="1"],.was-validated .form-select:invalid:not([multiple]):not([size]),.was-validated .form-select:invalid:not([multiple])[size="1"]{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath fill='none' stroke='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3E%3C/svg%3E"),url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23dc3545'%3E%3Ccircle cx='6' cy='6' r='4.5'/%3E%3Cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3E%3Ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3E%3C/svg%3E");background-position:right .75rem center,center right 2.25rem;background-size:16px 12px,calc(.75em + .375rem) calc(.75em + .375rem);padding-right:4.125rem}.form-select.is-invalid:focus,.was-validated .form-select:invalid:focus{border-color:#dc3545;box-shadow:0 0 0 .25rem #dc354540}.form-check-input.is-invalid,.was-validated .form-check-input:invalid{border-color:#dc3545}.form-check-input.is-invalid:checked,.was-validated .form-check-input:invalid:checked{background-color:#dc3545}.form-check-input.is-invalid:focus,.was-validated .form-check-input:invalid:focus{box-shadow:0 0 0 .25rem #dc354540}.form-check-input.is-invalid~.form-check-label,.was-validated .form-check-input:invalid~.form-check-label{color:#dc3545}.form-check-inline .form-check-input~.invalid-feedback{margin-left:.5em}.input-group .form-control.is-invalid,.input-group .form-select.is-invalid,.was-validated .input-group .form-control:invalid,.was-validated .input-group .form-select:invalid{z-index:2}.input-group .form-control.is-invalid:focus,.input-group .form-select.is-invalid:focus,.was-validated .input-group .form-control:invalid:focus,.was-validated .input-group .form-select:invalid:focus{z-index:3}.btn{background-color:initial;border:1px solid #0000;border-radius:.25rem;color:#212529;cursor:pointer;display:inline-block;font-size:1rem;font-weight:400;line-height:1.5;padding:.375rem .75rem;text-align:center;text-decoration:none;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out;-webkit-user-select:none;user-select:none;vertical-align:middle}@media (prefers-reduced-motion:reduce){.btn{transition:none}}.btn:hover{color:#212529}.btn-check:focus+.btn,.btn:focus{box-shadow:0 0 0 .25rem #0d6efd40;outline:0}.btn.disabled,.btn:disabled,fieldset:disabled .btn{opacity:.65;pointer-events:none}.btn-primary{background-color:#0d6efd;border-color:#0d6efd;color:#fff}.btn-check:focus+.btn-primary,.btn-primary:focus,.btn-primary:hover{background-color:#0b5ed7;border-color:#0a58ca;color:#fff}.btn-check:focus+.btn-primary,.btn-primary:focus{box-shadow:0 0 0 .25rem #3184fd80}.btn-check:active+.btn-primary,.btn-check:checked+.btn-primary,.btn-primary.active,.btn-primary:active,.show>.btn-primary.dropdown-toggle{background-color:#0a58ca;border-color:#0a53be;color:#fff}.btn-check:active+.btn-primary:focus,.btn-check:checked+.btn-primary:focus,.btn-primary.active:focus,.btn-primary:active:focus,.show>.btn-primary.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #3184fd80}.btn-primary.disabled,.btn-primary:disabled{background-color:#0d6efd;border-color:#0d6efd;color:#fff}.btn-secondary{background-color:#6c757d;border-color:#6c757d;color:#fff}.btn-check:focus+.btn-secondary,.btn-secondary:focus,.btn-secondary:hover{background-color:#5c636a;border-color:#565e64;color:#fff}.btn-check:focus+.btn-secondary,.btn-secondary:focus{box-shadow:0 0 0 .25rem #828a9180}.btn-check:active+.btn-secondary,.btn-check:checked+.btn-secondary,.btn-secondary.active,.btn-secondary:active,.show>.btn-secondary.dropdown-toggle{background-color:#565e64;border-color:#51585e;color:#fff}.btn-check:active+.btn-secondary:focus,.btn-check:checked+.btn-secondary:focus,.btn-secondary.active:focus,.btn-secondary:active:focus,.show>.btn-secondary.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #828a9180}.btn-secondary.disabled,.btn-secondary:disabled{background-color:#6c757d;border-color:#6c757d;color:#fff}.btn-success{background-color:#198754;border-color:#198754;color:#fff}.btn-check:focus+.btn-success,.btn-success:focus,.btn-success:hover{background-color:#157347;border-color:#146c43;color:#fff}.btn-check:focus+.btn-success,.btn-success:focus{box-shadow:0 0 0 .25rem #3c996e80}.btn-check:active+.btn-success,.btn-check:checked+.btn-success,.btn-success.active,.btn-success:active,.show>.btn-success.dropdown-toggle{background-color:#146c43;border-color:#13653f;color:#fff}.btn-check:active+.btn-success:focus,.btn-check:checked+.btn-success:focus,.btn-success.active:focus,.btn-success:active:focus,.show>.btn-success.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #3c996e80}.btn-success.disabled,.btn-success:disabled{background-color:#198754;border-color:#198754;color:#fff}.btn-info{background-color:#0dcaf0;border-color:#0dcaf0;color:#000}.btn-check:focus+.btn-info,.btn-info:focus,.btn-info:hover{background-color:#31d2f2;border-color:#25cff2;color:#000}.btn-check:focus+.btn-info,.btn-info:focus{box-shadow:0 0 0 .25rem #0baccc80}.btn-check:active+.btn-info,.btn-check:checked+.btn-info,.btn-info.active,.btn-info:active,.show>.btn-info.dropdown-toggle{background-color:#3dd5f3;border-color:#25cff2;color:#000}.btn-check:active+.btn-info:focus,.btn-check:checked+.btn-info:focus,.btn-info.active:focus,.btn-info:active:focus,.show>.btn-info.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #0baccc80}.btn-info.disabled,.btn-info:disabled{background-color:#0dcaf0;border-color:#0dcaf0;color:#000}.btn-warning{background-color:#ffc107;border-color:#ffc107;color:#000}.btn-check:focus+.btn-warning,.btn-warning:focus,.btn-warning:hover{background-color:#ffca2c;border-color:#ffc720;color:#000}.btn-check:focus+.btn-warning,.btn-warning:focus{box-shadow:0 0 0 .25rem #d9a40680}.btn-check:active+.btn-warning,.btn-check:checked+.btn-warning,.btn-warning.active,.btn-warning:active,.show>.btn-warning.dropdown-toggle{background-color:#ffcd39;border-color:#ffc720;color:#000}.btn-check:active+.btn-warning:focus,.btn-check:checked+.btn-warning:focus,.btn-warning.active:focus,.btn-warning:active:focus,.show>.btn-warning.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #d9a40680}.btn-warning.disabled,.btn-warning:disabled{background-color:#ffc107;border-color:#ffc107;color:#000}.btn-danger{background-color:#dc3545;border-color:#dc3545;color:#fff}.btn-check:focus+.btn-danger,.btn-danger:focus,.btn-danger:hover{background-color:#bb2d3b;border-color:#b02a37;color:#fff}.btn-check:focus+.btn-danger,.btn-danger:focus{box-shadow:0 0 0 .25rem #e1536180}.btn-check:active+.btn-danger,.btn-check:checked+.btn-danger,.btn-danger.active,.btn-danger:active,.show>.btn-danger.dropdown-toggle{background-color:#b02a37;border-color:#a52834;color:#fff}.btn-check:active+.btn-danger:focus,.btn-check:checked+.btn-danger:focus,.btn-danger.active:focus,.btn-danger:active:focus,.show>.btn-danger.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #e1536180}.btn-danger.disabled,.btn-danger:disabled{background-color:#dc3545;border-color:#dc3545;color:#fff}.btn-light{background-color:#f8f9fa;border-color:#f8f9fa;color:#000}.btn-check:focus+.btn-light,.btn-light:focus,.btn-light:hover{background-color:#f9fafb;border-color:#f9fafb;color:#000}.btn-check:focus+.btn-light,.btn-light:focus{box-shadow:0 0 0 .25rem #d3d4d580}.btn-check:active+.btn-light,.btn-check:checked+.btn-light,.btn-light.active,.btn-light:active,.show>.btn-light.dropdown-toggle{background-color:#f9fafb;border-color:#f9fafb;color:#000}.btn-check:active+.btn-light:focus,.btn-check:checked+.btn-light:focus,.btn-light.active:focus,.btn-light:active:focus,.show>.btn-light.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #d3d4d580}.btn-light.disabled,.btn-light:disabled{background-color:#f8f9fa;border-color:#f8f9fa;color:#000}.btn-dark{background-color:#212529;border-color:#212529;color:#fff}.btn-check:focus+.btn-dark,.btn-dark:focus,.btn-dark:hover{background-color:#1c1f23;border-color:#1a1e21;color:#fff}.btn-check:focus+.btn-dark,.btn-dark:focus{box-shadow:0 0 0 .25rem #42464980}.btn-check:active+.btn-dark,.btn-check:checked+.btn-dark,.btn-dark.active,.btn-dark:active,.show>.btn-dark.dropdown-toggle{background-color:#1a1e21;border-color:#191c1f;color:#fff}.btn-check:active+.btn-dark:focus,.btn-check:checked+.btn-dark:focus,.btn-dark.active:focus,.btn-dark:active:focus,.show>.btn-dark.dropdown-toggle:focus{box-shadow:0 0 0 .25rem #42464980}.btn-dark.disabled,.btn-dark:disabled{background-color:#212529;border-color:#212529;color:#fff}.btn-outline-primary{border-color:#0d6efd;color:#0d6efd}.btn-outline-primary:hover{background-color:#0d6efd;border-color:#0d6efd;color:#fff}.btn-check:focus+.btn-outline-primary,.btn-outline-primary:focus{box-shadow:0 0 0 .25rem #0d6efd80}.btn-check:active+.btn-outline-primary,.btn-check:checked+.btn-outline-primary,.btn-outline-primary.active,.btn-outline-primary.dropdown-toggle.show,.btn-outline-primary:active{background-color:#0d6efd;border-color:#0d6efd;color:#fff}.btn-check:active+.btn-outline-primary:focus,.btn-check:checked+.btn-outline-primary:focus,.btn-outline-primary.active:focus,.btn-outline-primary.dropdown-toggle.show:focus,.btn-outline-primary:active:focus{box-shadow:0 0 0 .25rem #0d6efd80}.btn-outline-primary.disabled,.btn-outline-primary:disabled{background-color:initial;color:#0d6efd}.btn-outline-secondary{border-color:#6c757d;color:#6c757d}.btn-outline-secondary:hover{background-color:#6c757d;border-color:#6c757d;color:#fff}.btn-check:focus+.btn-outline-secondary,.btn-outline-secondary:focus{box-shadow:0 0 0 .25rem #6c757d80}.btn-check:active+.btn-outline-secondary,.btn-check:checked+.btn-outline-secondary,.btn-outline-secondary.active,.btn-outline-secondary.dropdown-toggle.show,.btn-outline-secondary:active{background-color:#6c757d;border-color:#6c757d;color:#fff}.btn-check:active+.btn-outline-secondary:focus,.btn-check:checked+.btn-outline-secondary:focus,.btn-outline-secondary.active:focus,.btn-outline-secondary.dropdown-toggle.show:focus,.btn-outline-secondary:active:focus{box-shadow:0 0 0 .25rem #6c757d80}.btn-outline-secondary.disabled,.btn-outline-secondary:disabled{background-color:initial;color:#6c757d}.btn-outline-success{border-color:#198754;color:#198754}.btn-outline-success:hover{background-color:#198754;border-color:#198754;color:#fff}.btn-check:focus+.btn-outline-success,.btn-outline-success:focus{box-shadow:0 0 0 .25rem #19875480}.btn-check:active+.btn-outline-success,.btn-check:checked+.btn-outline-success,.btn-outline-success.active,.btn-outline-success.dropdown-toggle.show,.btn-outline-success:active{background-color:#198754;border-color:#198754;color:#fff}.btn-check:active+.btn-outline-success:focus,.btn-check:checked+.btn-outline-success:focus,.btn-outline-success.active:focus,.btn-outline-success.dropdown-toggle.show:focus,.btn-outline-success:active:focus{box-shadow:0 0 0 .25rem #19875480}.btn-outline-success.disabled,.btn-outline-success:disabled{background-color:initial;color:#198754}.btn-outline-info{border-color:#0dcaf0;color:#0dcaf0}.btn-outline-info:hover{background-color:#0dcaf0;border-color:#0dcaf0;color:#000}.btn-check:focus+.btn-outline-info,.btn-outline-info:focus{box-shadow:0 0 0 .25rem #0dcaf080}.btn-check:active+.btn-outline-info,.btn-check:checked+.btn-outline-info,.btn-outline-info.active,.btn-outline-info.dropdown-toggle.show,.btn-outline-info:active{background-color:#0dcaf0;border-color:#0dcaf0;color:#000}.btn-check:active+.btn-outline-info:focus,.btn-check:checked+.btn-outline-info:focus,.btn-outline-info.active:focus,.btn-outline-info.dropdown-toggle.show:focus,.btn-outline-info:active:focus{box-shadow:0 0 0 .25rem #0dcaf080}.btn-outline-info.disabled,.btn-outline-info:disabled{background-color:initial;color:#0dcaf0}.btn-outline-warning{border-color:#ffc107;color:#ffc107}.btn-outline-warning:hover{background-color:#ffc107;border-color:#ffc107;color:#000}.btn-check:focus+.btn-outline-warning,.btn-outline-warning:focus{box-shadow:0 0 0 .25rem #ffc10780}.btn-check:active+.btn-outline-warning,.btn-check:checked+.btn-outline-warning,.btn-outline-warning.active,.btn-outline-warning.dropdown-toggle.show,.btn-outline-warning:active{background-color:#ffc107;border-color:#ffc107;color:#000}.btn-check:active+.btn-outline-warning:focus,.btn-check:checked+.btn-outline-warning:focus,.btn-outline-warning.active:focus,.btn-outline-warning.dropdown-toggle.show:focus,.btn-outline-warning:active:focus{box-shadow:0 0 0 .25rem #ffc10780}.btn-outline-warning.disabled,.btn-outline-warning:disabled{background-color:initial;color:#ffc107}.btn-outline-danger{border-color:#dc3545;color:#dc3545}.btn-outline-danger:hover{background-color:#dc3545;border-color:#dc3545;color:#fff}.btn-check:focus+.btn-outline-danger,.btn-outline-danger:focus{box-shadow:0 0 0 .25rem #dc354580}.btn-check:active+.btn-outline-danger,.btn-check:checked+.btn-outline-danger,.btn-outline-danger.active,.btn-outline-danger.dropdown-toggle.show,.btn-outline-danger:active{background-color:#dc3545;border-color:#dc3545;color:#fff}.btn-check:active+.btn-outline-danger:focus,.btn-check:checked+.btn-outline-danger:focus,.btn-outline-danger.active:focus,.btn-outline-danger.dropdown-toggle.show:focus,.btn-outline-danger:active:focus{box-shadow:0 0 0 .25rem #dc354580}.btn-outline-danger.disabled,.btn-outline-danger:disabled{background-color:initial;color:#dc3545}.btn-outline-light{border-color:#f8f9fa;color:#f8f9fa}.btn-outline-light:hover{background-color:#f8f9fa;border-color:#f8f9fa;color:#000}.btn-check:focus+.btn-outline-light,.btn-outline-light:focus{box-shadow:0 0 0 .25rem #f8f9fa80}.btn-check:active+.btn-outline-light,.btn-check:checked+.btn-outline-light,.btn-outline-light.active,.btn-outline-light.dropdown-toggle.show,.btn-outline-light:active{background-color:#f8f9fa;border-color:#f8f9fa;color:#000}.btn-check:active+.btn-outline-light:focus,.btn-check:checked+.btn-outline-light:focus,.btn-outline-light.active:focus,.btn-outline-light.dropdown-toggle.show:focus,.btn-outline-light:active:focus{box-shadow:0 0 0 .25rem #f8f9fa80}.btn-outline-light.disabled,.btn-outline-light:disabled{background-color:initial;color:#f8f9fa}.btn-outline-dark{border-color:#212529;color:#212529}.btn-outline-dark:hover{background-color:#212529;border-color:#212529;color:#fff}.btn-check:focus+.btn-outline-dark,.btn-outline-dark:focus{box-shadow:0 0 0 .25rem #21252980}.btn-check:active+.btn-outline-dark,.btn-check:checked+.btn-outline-dark,.btn-outline-dark.active,.btn-outline-dark.dropdown-toggle.show,.btn-outline-dark:active{background-color:#212529;border-color:#212529;color:#fff}.btn-check:active+.btn-outline-dark:focus,.btn-check:checked+.btn-outline-dark:focus,.btn-outline-dark.active:focus,.btn-outline-dark.dropdown-toggle.show:focus,.btn-outline-dark:active:focus{box-shadow:0 0 0 .25rem #21252980}.btn-outline-dark.disabled,.btn-outline-dark:disabled{background-color:initial;color:#212529}.btn-link{color:#0d6efd;font-weight:400;text-decoration:underline}.btn-link:hover{color:#0a58ca}.btn-link.disabled,.btn-link:disabled{color:#6c757d}.btn-group-lg>.btn,.btn-lg{border-radius:.3rem;font-size:1.25rem;padding:.5rem 1rem}.btn-group-sm>.btn,.btn-sm{border-radius:.2rem;font-size:.875rem;padding:.25rem .5rem}.fade{transition:opacity .15s linear}@media (prefers-reduced-motion:reduce){.fade{transition:none}}.fade:not(.show){opacity:0}.collapse:not(.show){display:none}.collapsing{height:0;overflow:hidden;transition:height .35s ease}@media (prefers-reduced-motion:reduce){.collapsing{transition:none}}.collapsing.collapse-horizontal{height:auto;transition:width .35s ease;width:0}@media (prefers-reduced-motion:reduce){.collapsing.collapse-horizontal{transition:none}}.dropdown,.dropend,.dropstart,.dropup{position:relative}.dropdown-toggle{white-space:nowrap}.dropdown-toggle:after{border-bottom:0;border-left:.3em solid #0000;border-right:.3em solid #0000;border-top:.3em solid;content:"";display:inline-block;margin-left:.255em;vertical-align:.255em}.dropdown-toggle:empty:after{margin-left:0}.dropdown-menu{background-clip:padding-box;background-color:#fff;border:1px solid #00000026;border-radius:.25rem;color:#212529;display:none;font-size:1rem;list-style:none;margin:0;min-width:10rem;padding:.5rem 0;position:absolute;text-align:left;z-index:1000}.dropdown-menu[data-bs-popper]{left:0;margin-top:.125rem;top:100%}.dropdown-menu-start{--bs-position:start}.dropdown-menu-start[data-bs-popper]{left:0;right:auto}.dropdown-menu-end{--bs-position:end}.dropdown-menu-end[data-bs-popper]{left:auto;right:0}@media (min-width:576px){.dropdown-menu-sm-start{--bs-position:start}.dropdown-menu-sm-start[data-bs-popper]{left:0;right:auto}.dropdown-menu-sm-end{--bs-position:end}.dropdown-menu-sm-end[data-bs-popper]{left:auto;right:0}}@media (min-width:768px){.dropdown-menu-md-start{--bs-position:start}.dropdown-menu-md-start[data-bs-popper]{left:0;right:auto}.dropdown-menu-md-end{--bs-position:end}.dropdown-menu-md-end[data-bs-popper]{left:auto;right:0}}@media (min-width:992px){.dropdown-menu-lg-start{--bs-position:start}.dropdown-menu-lg-start[data-bs-popper]{left:0;right:auto}.dropdown-menu-lg-end{--bs-position:end}.dropdown-menu-lg-end[data-bs-popper]{left:auto;right:0}}@media (min-width:1200px){.dropdown-menu-xl-start{--bs-position:start}.dropdown-menu-xl-start[data-bs-popper]{left:0;right:auto}.dropdown-menu-xl-end{--bs-position:end}.dropdown-menu-xl-end[data-bs-popper]{left:auto;right:0}}@media (min-width:1400px){.dropdown-menu-xxl-start{--bs-position:start}.dropdown-menu-xxl-start[data-bs-popper]{left:0;right:auto}.dropdown-menu-xxl-end{--bs-position:end}.dropdown-menu-xxl-end[data-bs-popper]{left:auto;right:0}}.dropup .dropdown-menu[data-bs-popper]{bottom:100%;margin-bottom:.125rem;margin-top:0;top:auto}.dropup .dropdown-toggle:after{border-bottom:.3em solid;border-left:.3em solid #0000;border-right:.3em solid #0000;border-top:0;content:"";display:inline-block;margin-left:.255em;vertical-align:.255em}.dropup .dropdown-toggle:empty:after{margin-left:0}.dropend .dropdown-menu[data-bs-popper]{left:100%;margin-left:.125rem;margin-top:0;right:auto;top:0}.dropend .dropdown-toggle:after{border-bottom:.3em solid #0000;border-left:.3em solid;border-right:0;border-top:.3em solid #0000;content:"";display:inline-block;margin-left:.255em;vertical-align:.255em}.dropend .dropdown-toggle:empty:after{margin-left:0}.dropend .dropdown-toggle:after{vertical-align:0}.dropstart .dropdown-menu[data-bs-popper]{left:auto;margin-right:.125rem;margin-top:0;right:100%;top:0}.dropstart .dropdown-toggle:after{content:"";display:inline-block;display:none;margin-left:.255em;vertical-align:.255em}.dropstart .dropdown-toggle:before{border-bottom:.3em solid #0000;border-right:.3em solid;border-top:.3em solid #0000;content:"";display:inline-block;margin-right:.255em;vertical-align:.255em}.dropstart .dropdown-toggle:empty:after{margin-left:0}.dropstart .dropdown-toggle:before{vertical-align:0}.dropdown-divider{border-top:1px solid #00000026;height:0;margin:.5rem 0;overflow:hidden}.dropdown-item{background-color:initial;border:0;clear:both;color:#212529;display:block;font-weight:400;padding:.25rem 1rem;text-align:inherit;text-decoration:none;white-space:nowrap;width:100%}.dropdown-item:focus,.dropdown-item:hover{background-color:#e9ecef;color:#1e2125}.dropdown-item.active,.dropdown-item:active{background-color:#0d6efd;color:#fff;text-decoration:none}.dropdown-item.disabled,.dropdown-item:disabled{background-color:initial;color:#adb5bd;pointer-events:none}.dropdown-menu.show{display:block}.dropdown-header{color:#6c757d;display:block;font-size:.875rem;margin-bottom:0;padding:.5rem 1rem;white-space:nowrap}.dropdown-item-text{color:#212529;display:block;padding:.25rem 1rem}.dropdown-menu-dark{background-color:#343a40;border-color:#00000026;color:#dee2e6}.dropdown-menu-dark .dropdown-item{color:#dee2e6}.dropdown-menu-dark .dropdown-item:focus,.dropdown-menu-dark .dropdown-item:hover{background-color:#ffffff26;color:#fff}.dropdown-menu-dark .dropdown-item.active,.dropdown-menu-dark .dropdown-item:active{background-color:#0d6efd;color:#fff}.dropdown-menu-dark .dropdown-item.disabled,.dropdown-menu-dark .dropdown-item:disabled{color:#adb5bd}.dropdown-menu-dark .dropdown-divider{border-color:#00000026}.dropdown-menu-dark .dropdown-item-text{color:#dee2e6}.dropdown-menu-dark .dropdown-header{color:#adb5bd}.btn-group,.btn-group-vertical{display:inline-flex;position:relative;vertical-align:middle}.btn-group-vertical>.btn,.btn-group>.btn{flex:1 1 auto;position:relative}.btn-group-vertical>.btn-check:checked+.btn,.btn-group-vertical>.btn-check:focus+.btn,.btn-group-vertical>.btn.active,.btn-group-vertical>.btn:active,.btn-group-vertical>.btn:focus,.btn-group-vertical>.btn:hover,.btn-group>.btn-check:checked+.btn,.btn-group>.btn-check:focus+.btn,.btn-group>.btn.active,.btn-group>.btn:active,.btn-group>.btn:focus,.btn-group>.btn:hover{z-index:1}.btn-toolbar{display:flex;flex-wrap:wrap;justify-content:flex-start}.btn-toolbar .input-group{width:auto}.btn-group>.btn-group:not(:first-child),.btn-group>.btn:not(:first-child){margin-left:-1px}.btn-group>.btn-group:not(:last-child)>.btn,.btn-group>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-right-radius:0;border-top-right-radius:0}.btn-group>.btn-group:not(:first-child)>.btn,.btn-group>.btn:nth-child(n+3),.btn-group>:not(.btn-check)+.btn{border-bottom-left-radius:0;border-top-left-radius:0}.dropdown-toggle-split{padding-left:.5625rem;padding-right:.5625rem}.dropdown-toggle-split:after,.dropend .dropdown-toggle-split:after,.dropup .dropdown-toggle-split:after{margin-left:0}.dropstart .dropdown-toggle-split:before{margin-right:0}.btn-group-sm>.btn+.dropdown-toggle-split,.btn-sm+.dropdown-toggle-split{padding-left:.375rem;padding-right:.375rem}.btn-group-lg>.btn+.dropdown-toggle-split,.btn-lg+.dropdown-toggle-split{padding-left:.75rem;padding-right:.75rem}.btn-group-vertical{align-items:flex-start;flex-direction:column;justify-content:center}.btn-group-vertical>.btn,.btn-group-vertical>.btn-group{width:100%}.btn-group-vertical>.btn-group:not(:first-child),.btn-group-vertical>.btn:not(:first-child){margin-top:-1px}.btn-group-vertical>.btn-group:not(:last-child)>.btn,.btn-group-vertical>.btn:not(:last-child):not(.dropdown-toggle){border-bottom-left-radius:0;border-bottom-right-radius:0}.btn-group-vertical>.btn-group:not(:first-child)>.btn,.btn-group-vertical>.btn~.btn{border-top-left-radius:0;border-top-right-radius:0}.nav{display:flex;flex-wrap:wrap;list-style:none;margin-bottom:0;padding-left:0}.nav-link{color:#0d6efd;display:block;padding:.5rem 1rem;text-decoration:none;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out}@media (prefers-reduced-motion:reduce){.nav-link{transition:none}}.nav-link:focus,.nav-link:hover{color:#0a58ca}.nav-link.disabled{color:#6c757d;cursor:default;pointer-events:none}.nav-tabs{border-bottom:1px solid #dee2e6}.nav-tabs .nav-link{background:none;border:1px solid #0000;border-top-left-radius:.25rem;border-top-right-radius:.25rem;margin-bottom:-1px}.nav-tabs .nav-link:focus,.nav-tabs .nav-link:hover{border-color:#e9ecef #e9ecef #dee2e6;isolation:isolate}.nav-tabs .nav-link.disabled{background-color:initial;border-color:#0000;color:#6c757d}.nav-tabs .nav-item.show .nav-link,.nav-tabs .nav-link.active{background-color:#fff;border-color:#dee2e6 #dee2e6 #fff;color:#495057}.nav-tabs .dropdown-menu{border-top-left-radius:0;border-top-right-radius:0;margin-top:-1px}.nav-pills .nav-link{background:none;border:0;border-radius:.25rem}.nav-pills .nav-link.active,.nav-pills .show>.nav-link{background-color:#0d6efd;color:#fff}.nav-fill .nav-item,.nav-fill>.nav-link{flex:1 1 auto;text-align:center}.nav-justified .nav-item,.nav-justified>.nav-link{flex-basis:0;flex-grow:1;text-align:center}.nav-fill .nav-item .nav-link,.nav-justified .nav-item .nav-link{width:100%}.tab-content>.tab-pane{display:none}.tab-content>.active{display:block}.navbar{align-items:center;display:flex;flex-wrap:wrap;justify-content:space-between;padding-bottom:.5rem;padding-top:.5rem;position:relative}.navbar>.container,.navbar>.container-fluid,.navbar>.container-lg,.navbar>.container-md,.navbar>.container-sm,.navbar>.container-xl,.navbar>.container-xxl{align-items:center;display:flex;flex-wrap:inherit;justify-content:space-between}.navbar-brand{font-size:1.25rem;margin-right:1rem;padding-bottom:.3125rem;padding-top:.3125rem;text-decoration:none;white-space:nowrap}.navbar-nav{display:flex;flex-direction:column;list-style:none;margin-bottom:0;padding-left:0}.navbar-nav .nav-link{padding-left:0;padding-right:0}.navbar-nav .dropdown-menu{position:static}.navbar-text{padding-bottom:.5rem;padding-top:.5rem}.navbar-collapse{align-items:center;flex-basis:100%;flex-grow:1}.navbar-toggler{background-color:initial;border:1px solid #0000;border-radius:.25rem;font-size:1.25rem;line-height:1;padding:.25rem .75rem;transition:box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.navbar-toggler{transition:none}}.navbar-toggler:hover{text-decoration:none}.navbar-toggler:focus{box-shadow:0 0 0 .25rem;outline:0;text-decoration:none}.navbar-toggler-icon{background-position:50%;background-repeat:no-repeat;background-size:100%;display:inline-block;height:1.5em;vertical-align:middle;width:1.5em}.navbar-nav-scroll{max-height:75vh;max-height:var(--bs-scroll-height,75vh);overflow-y:auto}@media (min-width:576px){.navbar-expand-sm{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-sm .navbar-nav{flex-direction:row}.navbar-expand-sm .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-sm .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-sm .navbar-nav-scroll{overflow:visible}.navbar-expand-sm .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-sm .navbar-toggler,.navbar-expand-sm .offcanvas-header{display:none}.navbar-expand-sm .offcanvas{background-color:initial;border-left:0;border-right:0;bottom:0;flex-grow:1;position:inherit;transform:none;transition:none;visibility:visible!important;z-index:1000}.navbar-expand-sm .offcanvas-bottom,.navbar-expand-sm .offcanvas-top{border-bottom:0;border-top:0;height:auto}.navbar-expand-sm .offcanvas-body{display:flex;flex-grow:0;overflow-y:visible;padding:0}}@media (min-width:768px){.navbar-expand-md{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-md .navbar-nav{flex-direction:row}.navbar-expand-md .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-md .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-md .navbar-nav-scroll{overflow:visible}.navbar-expand-md .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-md .navbar-toggler,.navbar-expand-md .offcanvas-header{display:none}.navbar-expand-md .offcanvas{background-color:initial;border-left:0;border-right:0;bottom:0;flex-grow:1;position:inherit;transform:none;transition:none;visibility:visible!important;z-index:1000}.navbar-expand-md .offcanvas-bottom,.navbar-expand-md .offcanvas-top{border-bottom:0;border-top:0;height:auto}.navbar-expand-md .offcanvas-body{display:flex;flex-grow:0;overflow-y:visible;padding:0}}@media (min-width:992px){.navbar-expand-lg{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-lg .navbar-nav{flex-direction:row}.navbar-expand-lg .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-lg .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-lg .navbar-nav-scroll{overflow:visible}.navbar-expand-lg .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-lg .navbar-toggler,.navbar-expand-lg .offcanvas-header{display:none}.navbar-expand-lg .offcanvas{background-color:initial;border-left:0;border-right:0;bottom:0;flex-grow:1;position:inherit;transform:none;transition:none;visibility:visible!important;z-index:1000}.navbar-expand-lg .offcanvas-bottom,.navbar-expand-lg .offcanvas-top{border-bottom:0;border-top:0;height:auto}.navbar-expand-lg .offcanvas-body{display:flex;flex-grow:0;overflow-y:visible;padding:0}}@media (min-width:1200px){.navbar-expand-xl{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-xl .navbar-nav{flex-direction:row}.navbar-expand-xl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xl .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-xl .navbar-nav-scroll{overflow:visible}.navbar-expand-xl .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-xl .navbar-toggler,.navbar-expand-xl .offcanvas-header{display:none}.navbar-expand-xl .offcanvas{background-color:initial;border-left:0;border-right:0;bottom:0;flex-grow:1;position:inherit;transform:none;transition:none;visibility:visible!important;z-index:1000}.navbar-expand-xl .offcanvas-bottom,.navbar-expand-xl .offcanvas-top{border-bottom:0;border-top:0;height:auto}.navbar-expand-xl .offcanvas-body{display:flex;flex-grow:0;overflow-y:visible;padding:0}}@media (min-width:1400px){.navbar-expand-xxl{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand-xxl .navbar-nav{flex-direction:row}.navbar-expand-xxl .navbar-nav .dropdown-menu{position:absolute}.navbar-expand-xxl .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand-xxl .navbar-nav-scroll{overflow:visible}.navbar-expand-xxl .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand-xxl .navbar-toggler,.navbar-expand-xxl .offcanvas-header{display:none}.navbar-expand-xxl .offcanvas{background-color:initial;border-left:0;border-right:0;bottom:0;flex-grow:1;position:inherit;transform:none;transition:none;visibility:visible!important;z-index:1000}.navbar-expand-xxl .offcanvas-bottom,.navbar-expand-xxl .offcanvas-top{border-bottom:0;border-top:0;height:auto}.navbar-expand-xxl .offcanvas-body{display:flex;flex-grow:0;overflow-y:visible;padding:0}}.navbar-expand{flex-wrap:nowrap;justify-content:flex-start}.navbar-expand .navbar-nav{flex-direction:row}.navbar-expand .navbar-nav .dropdown-menu{position:absolute}.navbar-expand .navbar-nav .nav-link{padding-left:.5rem;padding-right:.5rem}.navbar-expand .navbar-nav-scroll{overflow:visible}.navbar-expand .navbar-collapse{display:flex!important;flex-basis:auto}.navbar-expand .navbar-toggler,.navbar-expand .offcanvas-header{display:none}.navbar-expand .offcanvas{background-color:initial;border-left:0;border-right:0;bottom:0;flex-grow:1;position:inherit;transform:none;transition:none;visibility:visible!important;z-index:1000}.navbar-expand .offcanvas-bottom,.navbar-expand .offcanvas-top{border-bottom:0;border-top:0;height:auto}.navbar-expand .offcanvas-body{display:flex;flex-grow:0;overflow-y:visible;padding:0}.navbar-light .navbar-brand,.navbar-light .navbar-brand:focus,.navbar-light .navbar-brand:hover{color:#000000e6}.navbar-light .navbar-nav .nav-link{color:#0000008c}.navbar-light .navbar-nav .nav-link:focus,.navbar-light .navbar-nav .nav-link:hover{color:#000000b3}.navbar-light .navbar-nav .nav-link.disabled{color:#0000004d}.navbar-light .navbar-nav .nav-link.active,.navbar-light .navbar-nav .show>.nav-link{color:#000000e6}.navbar-light .navbar-toggler{border-color:#0000001a;color:#0000008c}.navbar-light .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(0, 0, 0, 0.55)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-light .navbar-text{color:#0000008c}.navbar-light .navbar-text a,.navbar-light .navbar-text a:focus,.navbar-light .navbar-text a:hover{color:#000000e6}.navbar-dark .navbar-brand,.navbar-dark .navbar-brand:focus,.navbar-dark .navbar-brand:hover{color:#fff}.navbar-dark .navbar-nav .nav-link{color:#ffffff8c}.navbar-dark .navbar-nav .nav-link:focus,.navbar-dark .navbar-nav .nav-link:hover{color:#ffffffbf}.navbar-dark .navbar-nav .nav-link.disabled{color:#ffffff40}.navbar-dark .navbar-nav .nav-link.active,.navbar-dark .navbar-nav .show>.nav-link{color:#fff}.navbar-dark .navbar-toggler{border-color:#ffffff1a;color:#ffffff8c}.navbar-dark .navbar-toggler-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3E%3Cpath stroke='rgba(255, 255, 255, 0.55)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E")}.navbar-dark .navbar-text{color:#ffffff8c}.navbar-dark .navbar-text a,.navbar-dark .navbar-text a:focus,.navbar-dark .navbar-text a:hover{color:#fff}.card{word-wrap:break-word;background-clip:initial;background-color:#fff;border:1px solid rgba(0,0,0,.125);border-radius:.25rem;display:flex;flex-direction:column;min-width:0;position:relative}.card>hr{margin-left:0;margin-right:0}.card>.list-group{border-bottom:inherit;border-top:inherit}.card>.list-group:first-child{border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px);border-top-width:0}.card>.list-group:last-child{border-bottom-left-radius:calc(.25rem - 1px);border-bottom-right-radius:calc(.25rem - 1px);border-bottom-width:0}.card>.card-header+.list-group,.card>.list-group+.card-footer{border-top:0}.card-body{flex:1 1 auto;padding:1rem}.card-title{margin-bottom:.5rem}.card-subtitle{margin-top:-.25rem}.card-subtitle,.card-text:last-child{margin-bottom:0}.card-link+.card-link{margin-left:1rem}.card-header{background-color:#00000008;border-bottom:1px solid rgba(0,0,0,.125);margin-bottom:0;padding:.5rem 1rem}.card-header:first-child{border-radius:calc(.25rem - 1px) calc(.25rem - 1px) 0 0}.card-footer{background-color:#00000008;border-top:1px solid rgba(0,0,0,.125);padding:.5rem 1rem}.card-footer:last-child{border-radius:0 0 calc(.25rem - 1px) calc(.25rem - 1px)}.card-header-tabs{border-bottom:0;margin-bottom:-.5rem}.card-header-pills,.card-header-tabs{margin-left:-.5rem;margin-right:-.5rem}.card-img-overlay{border-radius:calc(.25rem - 1px);bottom:0;left:0;padding:1rem;position:absolute;right:0;top:0}.card-img,.card-img-bottom,.card-img-top{width:100%}.card-img,.card-img-top{border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px)}.card-img,.card-img-bottom{border-bottom-left-radius:calc(.25rem - 1px);border-bottom-right-radius:calc(.25rem - 1px)}.card-group>.card{margin-bottom:.75rem}@media (min-width:576px){.card-group{display:flex;flex-flow:row wrap}.card-group>.card{flex:1 0;margin-bottom:0}.card-group>.card+.card{border-left:0;margin-left:0}.card-group>.card:not(:last-child){border-bottom-right-radius:0;border-top-right-radius:0}.card-group>.card:not(:last-child) .card-header,.card-group>.card:not(:last-child) .card-img-top{border-top-right-radius:0}.card-group>.card:not(:last-child) .card-footer,.card-group>.card:not(:last-child) .card-img-bottom{border-bottom-right-radius:0}.card-group>.card:not(:first-child){border-bottom-left-radius:0;border-top-left-radius:0}.card-group>.card:not(:first-child) .card-header,.card-group>.card:not(:first-child) .card-img-top{border-top-left-radius:0}.card-group>.card:not(:first-child) .card-footer,.card-group>.card:not(:first-child) .card-img-bottom{border-bottom-left-radius:0}}.accordion-button{align-items:center;background-color:#fff;border:0;border-radius:0;color:#212529;display:flex;font-size:1rem;overflow-anchor:none;padding:1rem 1.25rem;position:relative;text-align:left;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out,border-radius .15s ease;width:100%}@media (prefers-reduced-motion:reduce){.accordion-button{transition:none}}.accordion-button:not(.collapsed){background-color:#e7f1ff;box-shadow:inset 0 -1px 0 rgba(0,0,0,.125);color:#0c63e4}.accordion-button:not(.collapsed):after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%230c63e4'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");transform:rotate(-180deg)}.accordion-button:after{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23212529'%3E%3Cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:1.25rem;content:"";flex-shrink:0;height:1.25rem;margin-left:auto;transition:transform .2s ease-in-out;width:1.25rem}@media (prefers-reduced-motion:reduce){.accordion-button:after{transition:none}}.accordion-button:hover{z-index:2}.accordion-button:focus{border-color:#86b7fe;box-shadow:0 0 0 .25rem #0d6efd40;outline:0;z-index:3}.accordion-header{margin-bottom:0}.accordion-item{background-color:#fff;border:1px solid rgba(0,0,0,.125)}.accordion-item:first-of-type{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.accordion-item:first-of-type .accordion-button{border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px)}.accordion-item:not(:first-of-type){border-top:0}.accordion-item:last-of-type{border-bottom-left-radius:.25rem;border-bottom-right-radius:.25rem}.accordion-item:last-of-type .accordion-button.collapsed{border-bottom-left-radius:calc(.25rem - 1px);border-bottom-right-radius:calc(.25rem - 1px)}.accordion-item:last-of-type .accordion-collapse{border-bottom-left-radius:.25rem;border-bottom-right-radius:.25rem}.accordion-body{padding:1rem 1.25rem}.accordion-flush .accordion-collapse{border-width:0}.accordion-flush .accordion-item{border-left:0;border-radius:0;border-right:0}.accordion-flush .accordion-item:first-child{border-top:0}.accordion-flush .accordion-item:last-child{border-bottom:0}.accordion-flush .accordion-item .accordion-button{border-radius:0}.breadcrumb{display:flex;flex-wrap:wrap;list-style:none;margin-bottom:1rem;padding:0}.breadcrumb-item+.breadcrumb-item{padding-left:.5rem}.breadcrumb-item+.breadcrumb-item:before{color:#6c757d;content:"/";content:var(--bs-breadcrumb-divider,"/");float:left;padding-right:.5rem}.breadcrumb-item.active{color:#6c757d}.pagination{display:flex;list-style:none;padding-left:0}.page-link{background-color:#fff;border:1px solid #dee2e6;color:#0d6efd;display:block;position:relative;text-decoration:none;transition:color .15s ease-in-out,background-color .15s ease-in-out,border-color .15s ease-in-out,box-shadow .15s ease-in-out}@media (prefers-reduced-motion:reduce){.page-link{transition:none}}.page-link:hover{border-color:#dee2e6;z-index:2}.page-link:focus,.page-link:hover{background-color:#e9ecef;color:#0a58ca}.page-link:focus{box-shadow:0 0 0 .25rem #0d6efd40;outline:0;z-index:3}.page-item:not(:first-child) .page-link{margin-left:-1px}.page-item.active .page-link{background-color:#0d6efd;border-color:#0d6efd;color:#fff;z-index:3}.page-item.disabled .page-link{background-color:#fff;border-color:#dee2e6;color:#6c757d;pointer-events:none}.page-link{padding:.375rem .75rem}.page-item:first-child .page-link{border-bottom-left-radius:.25rem;border-top-left-radius:.25rem}.page-item:last-child .page-link{border-bottom-right-radius:.25rem;border-top-right-radius:.25rem}.pagination-lg .page-link{font-size:1.25rem;padding:.75rem 1.5rem}.pagination-lg .page-item:first-child .page-link{border-bottom-left-radius:.3rem;border-top-left-radius:.3rem}.pagination-lg .page-item:last-child .page-link{border-bottom-right-radius:.3rem;border-top-right-radius:.3rem}.pagination-sm .page-link{font-size:.875rem;padding:.25rem .5rem}.pagination-sm .page-item:first-child .page-link{border-bottom-left-radius:.2rem;border-top-left-radius:.2rem}.pagination-sm .page-item:last-child .page-link{border-bottom-right-radius:.2rem;border-top-right-radius:.2rem}.badge{border-radius:.25rem;color:#fff;display:inline-block;font-size:.75em;font-weight:700;line-height:1;padding:.35em .65em;text-align:center;vertical-align:initial;white-space:nowrap}.badge:empty{display:none}.btn .badge{position:relative;top:-1px}.alert{border:1px solid #0000;border-radius:.25rem;margin-bottom:1rem;padding:1rem;position:relative}.alert-heading{color:inherit}.alert-link{font-weight:700}.alert-dismissible{padding-right:3rem}.alert-dismissible .btn-close{padding:1.25rem 1rem;position:absolute;right:0;top:0;z-index:2}.alert-primary{background-color:#cfe2ff;border-color:#b6d4fe;color:#084298}.alert-primary .alert-link{color:#06357a}.alert-secondary{background-color:#e2e3e5;border-color:#d3d6d8;color:#41464b}.alert-secondary .alert-link{color:#34383c}.alert-success{background-color:#d1e7dd;border-color:#badbcc;color:#0f5132}.alert-success .alert-link{color:#0c4128}.alert-info{background-color:#cff4fc;border-color:#b6effb;color:#055160}.alert-info .alert-link{color:#04414d}.alert-warning{background-color:#fff3cd;border-color:#ffecb5;color:#664d03}.alert-warning .alert-link{color:#523e02}.alert-danger{background-color:#f8d7da;border-color:#f5c2c7;color:#842029}.alert-danger .alert-link{color:#6a1a21}.alert-light{background-color:#fefefe;border-color:#fdfdfe;color:#636464}.alert-light .alert-link{color:#4f5050}.alert-dark{background-color:#d3d3d4;border-color:#bcbebf;color:#141619}.alert-dark .alert-link{color:#101214}@keyframes progress-bar-stripes{0%{background-position-x:1rem}}.progress{background-color:#e9ecef;border-radius:.25rem;font-size:.75rem;height:1rem}.progress,.progress-bar{display:flex;overflow:hidden}.progress-bar{background-color:#0d6efd;color:#fff;flex-direction:column;justify-content:center;text-align:center;transition:width .6s ease;white-space:nowrap}@media (prefers-reduced-motion:reduce){.progress-bar{transition:none}}.progress-bar-striped{background-image:linear-gradient(45deg,#ffffff26 25%,#0000 0,#0000 50%,#ffffff26 0,#ffffff26 75%,#0000 0,#0000);background-size:1rem 1rem}.progress-bar-animated{animation:progress-bar-stripes 1s linear infinite}@media (prefers-reduced-motion:reduce){.progress-bar-animated{animation:none}}.list-group{border-radius:.25rem;display:flex;flex-direction:column;margin-bottom:0;padding-left:0}.list-group-numbered{counter-reset:section;list-style-type:none}.list-group-numbered>li:before{content:counters(section,".") ". ";counter-increment:section}.list-group-item-action{color:#495057;text-align:inherit;width:100%}.list-group-item-action:focus,.list-group-item-action:hover{background-color:#f8f9fa;color:#495057;text-decoration:none;z-index:1}.list-group-item-action:active{background-color:#e9ecef;color:#212529}.list-group-item{background-color:#fff;border:1px solid rgba(0,0,0,.125);color:#212529;display:block;padding:.5rem 1rem;position:relative;text-decoration:none}.list-group-item:first-child{border-top-left-radius:inherit;border-top-right-radius:inherit}.list-group-item:last-child{border-bottom-left-radius:inherit;border-bottom-right-radius:inherit}.list-group-item.disabled,.list-group-item:disabled{background-color:#fff;color:#6c757d;pointer-events:none}.list-group-item.active{background-color:#0d6efd;border-color:#0d6efd;color:#fff;z-index:2}.list-group-item+.list-group-item{border-top-width:0}.list-group-item+.list-group-item.active{border-top-width:1px;margin-top:-1px}.list-group-horizontal{flex-direction:row}.list-group-horizontal>.list-group-item:first-child{border-bottom-left-radius:.25rem;border-top-right-radius:0}.list-group-horizontal>.list-group-item:last-child{border-bottom-left-radius:0;border-top-right-radius:.25rem}.list-group-horizontal>.list-group-item.active{margin-top:0}.list-group-horizontal>.list-group-item+.list-group-item{border-left-width:0;border-top-width:1px}.list-group-horizontal>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}@media (min-width:576px){.list-group-horizontal-sm{flex-direction:row}.list-group-horizontal-sm>.list-group-item:first-child{border-bottom-left-radius:.25rem;border-top-right-radius:0}.list-group-horizontal-sm>.list-group-item:last-child{border-bottom-left-radius:0;border-top-right-radius:.25rem}.list-group-horizontal-sm>.list-group-item.active{margin-top:0}.list-group-horizontal-sm>.list-group-item+.list-group-item{border-left-width:0;border-top-width:1px}.list-group-horizontal-sm>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}@media (min-width:768px){.list-group-horizontal-md{flex-direction:row}.list-group-horizontal-md>.list-group-item:first-child{border-bottom-left-radius:.25rem;border-top-right-radius:0}.list-group-horizontal-md>.list-group-item:last-child{border-bottom-left-radius:0;border-top-right-radius:.25rem}.list-group-horizontal-md>.list-group-item.active{margin-top:0}.list-group-horizontal-md>.list-group-item+.list-group-item{border-left-width:0;border-top-width:1px}.list-group-horizontal-md>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}@media (min-width:992px){.list-group-horizontal-lg{flex-direction:row}.list-group-horizontal-lg>.list-group-item:first-child{border-bottom-left-radius:.25rem;border-top-right-radius:0}.list-group-horizontal-lg>.list-group-item:last-child{border-bottom-left-radius:0;border-top-right-radius:.25rem}.list-group-horizontal-lg>.list-group-item.active{margin-top:0}.list-group-horizontal-lg>.list-group-item+.list-group-item{border-left-width:0;border-top-width:1px}.list-group-horizontal-lg>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}@media (min-width:1200px){.list-group-horizontal-xl{flex-direction:row}.list-group-horizontal-xl>.list-group-item:first-child{border-bottom-left-radius:.25rem;border-top-right-radius:0}.list-group-horizontal-xl>.list-group-item:last-child{border-bottom-left-radius:0;border-top-right-radius:.25rem}.list-group-horizontal-xl>.list-group-item.active{margin-top:0}.list-group-horizontal-xl>.list-group-item+.list-group-item{border-left-width:0;border-top-width:1px}.list-group-horizontal-xl>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}@media (min-width:1400px){.list-group-horizontal-xxl{flex-direction:row}.list-group-horizontal-xxl>.list-group-item:first-child{border-bottom-left-radius:.25rem;border-top-right-radius:0}.list-group-horizontal-xxl>.list-group-item:last-child{border-bottom-left-radius:0;border-top-right-radius:.25rem}.list-group-horizontal-xxl>.list-group-item.active{margin-top:0}.list-group-horizontal-xxl>.list-group-item+.list-group-item{border-left-width:0;border-top-width:1px}.list-group-horizontal-xxl>.list-group-item+.list-group-item.active{border-left-width:1px;margin-left:-1px}}.list-group-flush{border-radius:0}.list-group-flush>.list-group-item{border-width:0 0 1px}.list-group-flush>.list-group-item:last-child{border-bottom-width:0}.list-group-item-primary{background-color:#cfe2ff;color:#084298}.list-group-item-primary.list-group-item-action:focus,.list-group-item-primary.list-group-item-action:hover{background-color:#bacbe6;color:#084298}.list-group-item-primary.list-group-item-action.active{background-color:#084298;border-color:#084298;color:#fff}.list-group-item-secondary{background-color:#e2e3e5;color:#41464b}.list-group-item-secondary.list-group-item-action:focus,.list-group-item-secondary.list-group-item-action:hover{background-color:#cbccce;color:#41464b}.list-group-item-secondary.list-group-item-action.active{background-color:#41464b;border-color:#41464b;color:#fff}.list-group-item-success{background-color:#d1e7dd;color:#0f5132}.list-group-item-success.list-group-item-action:focus,.list-group-item-success.list-group-item-action:hover{background-color:#bcd0c7;color:#0f5132}.list-group-item-success.list-group-item-action.active{background-color:#0f5132;border-color:#0f5132;color:#fff}.list-group-item-info{background-color:#cff4fc;color:#055160}.list-group-item-info.list-group-item-action:focus,.list-group-item-info.list-group-item-action:hover{background-color:#badce3;color:#055160}.list-group-item-info.list-group-item-action.active{background-color:#055160;border-color:#055160;color:#fff}.list-group-item-warning{background-color:#fff3cd;color:#664d03}.list-group-item-warning.list-group-item-action:focus,.list-group-item-warning.list-group-item-action:hover{background-color:#e6dbb9;color:#664d03}.list-group-item-warning.list-group-item-action.active{background-color:#664d03;border-color:#664d03;color:#fff}.list-group-item-danger{background-color:#f8d7da;color:#842029}.list-group-item-danger.list-group-item-action:focus,.list-group-item-danger.list-group-item-action:hover{background-color:#dfc2c4;color:#842029}.list-group-item-danger.list-group-item-action.active{background-color:#842029;border-color:#842029;color:#fff}.list-group-item-light{background-color:#fefefe;color:#636464}.list-group-item-light.list-group-item-action:focus,.list-group-item-light.list-group-item-action:hover{background-color:#e5e5e5;color:#636464}.list-group-item-light.list-group-item-action.active{background-color:#636464;border-color:#636464;color:#fff}.list-group-item-dark{background-color:#d3d3d4;color:#141619}.list-group-item-dark.list-group-item-action:focus,.list-group-item-dark.list-group-item-action:hover{background-color:#bebebf;color:#141619}.list-group-item-dark.list-group-item-action.active{background-color:#141619;border-color:#141619;color:#fff}.btn-close{background:#0000 url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3E%3C/svg%3E") 50%/1em auto no-repeat;border:0;border-radius:.25rem;box-sizing:initial;color:#000;height:1em;opacity:.5;padding:.25em;width:1em}.btn-close:hover{color:#000;opacity:.75;text-decoration:none}.btn-close:focus{box-shadow:0 0 0 .25rem #0d6efd40;opacity:1;outline:0}.btn-close.disabled,.btn-close:disabled{opacity:.25;pointer-events:none;-webkit-user-select:none;user-select:none}.btn-close-white{filter:invert(1) grayscale(100%) brightness(200%)}.toast{background-clip:padding-box;background-color:#ffffffd9;border:1px solid #0000001a;border-radius:.25rem;box-shadow:0 .5rem 1rem #00000026;font-size:.875rem;max-width:100%;pointer-events:auto;width:350px}.toast.showing{opacity:0}.toast:not(.show){display:none}.toast-container{max-width:100%;pointer-events:none;width:max-content}.toast-container>:not(:last-child){margin-bottom:.75rem}.toast-header{align-items:center;background-clip:padding-box;background-color:#ffffffd9;border-bottom:1px solid #0000000d;border-top-left-radius:calc(.25rem - 1px);border-top-right-radius:calc(.25rem - 1px);color:#6c757d;display:flex;padding:.5rem .75rem}.toast-header .btn-close{margin-left:.75rem;margin-right:-.375rem}.toast-body{word-wrap:break-word;padding:.75rem}.modal{display:none;height:100%;left:0;outline:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:0;width:100%;z-index:1055}.modal-dialog{margin:.5rem;pointer-events:none;position:relative;width:auto}.modal.fade .modal-dialog{transform:translateY(-50px);transition:transform .3s ease-out}@media (prefers-reduced-motion:reduce){.modal.fade .modal-dialog{transition:none}}.modal.show .modal-dialog{transform:none}.modal.modal-static .modal-dialog{transform:scale(1.02)}.modal-dialog-scrollable{height:calc(100% - 1rem)}.modal-dialog-scrollable .modal-content{max-height:100%;overflow:hidden}.modal-dialog-scrollable .modal-body{overflow-y:auto}.modal-dialog-centered{align-items:center;display:flex;min-height:calc(100% - 1rem)}.modal-content{background-clip:padding-box;background-color:#fff;border:1px solid #0003;border-radius:.3rem;display:flex;flex-direction:column;outline:0;pointer-events:auto;position:relative;width:100%}.modal-backdrop{background-color:#000;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:1050}.modal-backdrop.fade{opacity:0}.modal-backdrop.show{opacity:.5}.modal-header{align-items:center;border-bottom:1px solid #dee2e6;border-top-left-radius:calc(.3rem - 1px);border-top-right-radius:calc(.3rem - 1px);display:flex;flex-shrink:0;justify-content:space-between;padding:1rem}.modal-header .btn-close{margin:-.5rem -.5rem -.5rem auto;padding:.5rem}.modal-title{line-height:1.5;margin-bottom:0}.modal-body{flex:1 1 auto;padding:1rem;position:relative}.modal-footer{align-items:center;border-bottom-left-radius:calc(.3rem - 1px);border-bottom-right-radius:calc(.3rem - 1px);border-top:1px solid #dee2e6;display:flex;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end;padding:.75rem}.modal-footer>*{margin:.25rem}@media (min-width:576px){.modal-dialog{margin:1.75rem auto;max-width:500px}.modal-dialog-scrollable{height:calc(100% - 3.5rem)}.modal-dialog-centered{min-height:calc(100% - 3.5rem)}.modal-sm{max-width:300px}}@media (min-width:992px){.modal-lg,.modal-xl{max-width:800px}}@media (min-width:1200px){.modal-xl{max-width:1140px}}.modal-fullscreen{height:100%;margin:0;max-width:none;width:100vw}.modal-fullscreen .modal-content{border:0;border-radius:0;height:100%}.modal-fullscreen .modal-header{border-radius:0}.modal-fullscreen .modal-body{overflow-y:auto}.modal-fullscreen .modal-footer{border-radius:0}@media (max-width:575.98px){.modal-fullscreen-sm-down{height:100%;margin:0;max-width:none;width:100vw}.modal-fullscreen-sm-down .modal-content{border:0;border-radius:0;height:100%}.modal-fullscreen-sm-down .modal-header{border-radius:0}.modal-fullscreen-sm-down .modal-body{overflow-y:auto}.modal-fullscreen-sm-down .modal-footer{border-radius:0}}@media (max-width:767.98px){.modal-fullscreen-md-down{height:100%;margin:0;max-width:none;width:100vw}.modal-fullscreen-md-down .modal-content{border:0;border-radius:0;height:100%}.modal-fullscreen-md-down .modal-header{border-radius:0}.modal-fullscreen-md-down .modal-body{overflow-y:auto}.modal-fullscreen-md-down .modal-footer{border-radius:0}}@media (max-width:991.98px){.modal-fullscreen-lg-down{height:100%;margin:0;max-width:none;width:100vw}.modal-fullscreen-lg-down .modal-content{border:0;border-radius:0;height:100%}.modal-fullscreen-lg-down .modal-header{border-radius:0}.modal-fullscreen-lg-down .modal-body{overflow-y:auto}.modal-fullscreen-lg-down .modal-footer{border-radius:0}}@media (max-width:1199.98px){.modal-fullscreen-xl-down{height:100%;margin:0;max-width:none;width:100vw}.modal-fullscreen-xl-down .modal-content{border:0;border-radius:0;height:100%}.modal-fullscreen-xl-down .modal-header{border-radius:0}.modal-fullscreen-xl-down .modal-body{overflow-y:auto}.modal-fullscreen-xl-down .modal-footer{border-radius:0}}@media (max-width:1399.98px){.modal-fullscreen-xxl-down{height:100%;margin:0;max-width:none;width:100vw}.modal-fullscreen-xxl-down .modal-content{border:0;border-radius:0;height:100%}.modal-fullscreen-xxl-down .modal-header{border-radius:0}.modal-fullscreen-xxl-down .modal-body{overflow-y:auto}.modal-fullscreen-xxl-down .modal-footer{border-radius:0}}.tooltip{word-wrap:break-word;display:block;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-family:var(--bs-font-sans-serif);font-size:.875rem;font-style:normal;font-weight:400;letter-spacing:normal;line-break:auto;line-height:1.5;margin:0;opacity:0;position:absolute;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;white-space:normal;word-break:normal;word-spacing:normal;z-index:1080}.tooltip.show{opacity:.9}.tooltip .tooltip-arrow{display:block;height:.4rem;position:absolute;width:.8rem}.tooltip .tooltip-arrow:before{border-color:#0000;border-style:solid;content:"";position:absolute}.bs-tooltip-auto[data-popper-placement^=top],.bs-tooltip-top{padding:.4rem 0}.bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow,.bs-tooltip-top .tooltip-arrow{bottom:0}.bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow:before,.bs-tooltip-top .tooltip-arrow:before{border-top-color:#000;border-width:.4rem .4rem 0;top:-1px}.bs-tooltip-auto[data-popper-placement^=right],.bs-tooltip-end{padding:0 .4rem}.bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow,.bs-tooltip-end .tooltip-arrow{height:.8rem;left:0;width:.4rem}.bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow:before,.bs-tooltip-end .tooltip-arrow:before{border-right-color:#000;border-width:.4rem .4rem .4rem 0;right:-1px}.bs-tooltip-auto[data-popper-placement^=bottom],.bs-tooltip-bottom{padding:.4rem 0}.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow,.bs-tooltip-bottom .tooltip-arrow{top:0}.bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow:before,.bs-tooltip-bottom .tooltip-arrow:before{border-bottom-color:#000;border-width:0 .4rem .4rem;bottom:-1px}.bs-tooltip-auto[data-popper-placement^=left],.bs-tooltip-start{padding:0 .4rem}.bs-tooltip-auto[data-popper-placement^=left] .tooltip-arrow,.bs-tooltip-start .tooltip-arrow{height:.8rem;right:0;width:.4rem}.bs-tooltip-auto[data-popper-placement^=left] .tooltip-arrow:before,.bs-tooltip-start .tooltip-arrow:before{border-left-color:#000;border-width:.4rem 0 .4rem .4rem;left:-1px}.tooltip-inner{background-color:#000;border-radius:.25rem;color:#fff;max-width:200px;padding:.25rem .5rem;text-align:center}.popover{word-wrap:break-word;background-clip:padding-box;background-color:#fff;border:1px solid #0003;border-radius:.3rem;display:block;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Liberation Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-family:var(--bs-font-sans-serif);font-size:.875rem;font-style:normal;font-weight:400;left:0;letter-spacing:normal;line-break:auto;line-height:1.5;max-width:276px;position:absolute;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;top:0;white-space:normal;word-break:normal;word-spacing:normal;z-index:1070}.popover .popover-arrow{display:block;height:.5rem;position:absolute;width:1rem}.popover .popover-arrow:after,.popover .popover-arrow:before{border-color:#0000;border-style:solid;content:"";display:block;position:absolute}.bs-popover-auto[data-popper-placement^=top]>.popover-arrow,.bs-popover-top>.popover-arrow{bottom:calc(-.5rem - 1px)}.bs-popover-auto[data-popper-placement^=top]>.popover-arrow:before,.bs-popover-top>.popover-arrow:before{border-top-color:#00000040;border-width:.5rem .5rem 0;bottom:0}.bs-popover-auto[data-popper-placement^=top]>.popover-arrow:after,.bs-popover-top>.popover-arrow:after{border-top-color:#fff;border-width:.5rem .5rem 0;bottom:1px}.bs-popover-auto[data-popper-placement^=right]>.popover-arrow,.bs-popover-end>.popover-arrow{height:1rem;left:calc(-.5rem - 1px);width:.5rem}.bs-popover-auto[data-popper-placement^=right]>.popover-arrow:before,.bs-popover-end>.popover-arrow:before{border-right-color:#00000040;border-width:.5rem .5rem .5rem 0;left:0}.bs-popover-auto[data-popper-placement^=right]>.popover-arrow:after,.bs-popover-end>.popover-arrow:after{border-right-color:#fff;border-width:.5rem .5rem .5rem 0;left:1px}.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow,.bs-popover-bottom>.popover-arrow{top:calc(-.5rem - 1px)}.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow:before,.bs-popover-bottom>.popover-arrow:before{border-bottom-color:#00000040;border-width:0 .5rem .5rem;top:0}.bs-popover-auto[data-popper-placement^=bottom]>.popover-arrow:after,.bs-popover-bottom>.popover-arrow:after{border-bottom-color:#fff;border-width:0 .5rem .5rem;top:1px}.bs-popover-auto[data-popper-placement^=bottom] .popover-header:before,.bs-popover-bottom .popover-header:before{border-bottom:1px solid #f0f0f0;content:"";display:block;left:50%;margin-left:-.5rem;position:absolute;top:0;width:1rem}.bs-popover-auto[data-popper-placement^=left]>.popover-arrow,.bs-popover-start>.popover-arrow{height:1rem;right:calc(-.5rem - 1px);width:.5rem}.bs-popover-auto[data-popper-placement^=left]>.popover-arrow:before,.bs-popover-start>.popover-arrow:before{border-left-color:#00000040;border-width:.5rem 0 .5rem .5rem;right:0}.bs-popover-auto[data-popper-placement^=left]>.popover-arrow:after,.bs-popover-start>.popover-arrow:after{border-left-color:#fff;border-width:.5rem 0 .5rem .5rem;right:1px}.popover-header{background-color:#f0f0f0;border-bottom:1px solid #0003;border-top-left-radius:calc(.3rem - 1px);border-top-right-radius:calc(.3rem - 1px);font-size:1rem;margin-bottom:0;padding:.5rem 1rem}.popover-header:empty{display:none}.popover-body{color:#212529;padding:1rem}.carousel{position:relative}.carousel.pointer-event{touch-action:pan-y}.carousel-inner{overflow:hidden;position:relative;width:100%}.carousel-inner:after{clear:both;content:"";display:block}.carousel-item{backface-visibility:hidden;display:none;float:left;margin-right:-100%;position:relative;transition:transform .6s ease-in-out;width:100%}@media (prefers-reduced-motion:reduce){.carousel-item{transition:none}}.carousel-item-next,.carousel-item-prev,.carousel-item.active{display:block}.active.carousel-item-end,.carousel-item-next:not(.carousel-item-start){transform:translateX(100%)}.active.carousel-item-start,.carousel-item-prev:not(.carousel-item-end){transform:translateX(-100%)}.carousel-fade .carousel-item{opacity:0;transform:none;transition-property:opacity}.carousel-fade .carousel-item-next.carousel-item-start,.carousel-fade .carousel-item-prev.carousel-item-end,.carousel-fade .carousel-item.active{opacity:1;z-index:1}.carousel-fade .active.carousel-item-end,.carousel-fade .active.carousel-item-start{opacity:0;transition:opacity 0s .6s;z-index:0}@media (prefers-reduced-motion:reduce){.carousel-fade .active.carousel-item-end,.carousel-fade .active.carousel-item-start{transition:none}}.carousel-control-next,.carousel-control-prev{align-items:center;background:none;border:0;bottom:0;color:#fff;display:flex;justify-content:center;opacity:.5;padding:0;position:absolute;text-align:center;top:0;transition:opacity .15s ease;width:15%;z-index:1}@media (prefers-reduced-motion:reduce){.carousel-control-next,.carousel-control-prev{transition:none}}.carousel-control-next:focus,.carousel-control-next:hover,.carousel-control-prev:focus,.carousel-control-prev:hover{color:#fff;opacity:.9;outline:0;text-decoration:none}.carousel-control-prev{left:0}.carousel-control-next{right:0}.carousel-control-next-icon,.carousel-control-prev-icon{background-position:50%;background-repeat:no-repeat;background-size:100% 100%;display:inline-block;height:2rem;width:2rem}.carousel-control-prev-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3E%3Cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3E%3C/svg%3E")}.carousel-control-next-icon{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3E%3Cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3E%3C/svg%3E")}.carousel-indicators{bottom:0;display:flex;justify-content:center;left:0;list-style:none;margin-bottom:1rem;margin-left:15%;margin-right:15%;padding:0;position:absolute;right:0;z-index:2}.carousel-indicators [data-bs-target]{background-clip:padding-box;background-color:#fff;border:0;border-bottom:10px solid #0000;border-top:10px solid #0000;box-sizing:initial;cursor:pointer;flex:0 1 auto;height:3px;margin-left:3px;margin-right:3px;opacity:.5;padding:0;text-indent:-999px;transition:opacity .6s ease;width:30px}@media (prefers-reduced-motion:reduce){.carousel-indicators [data-bs-target]{transition:none}}.carousel-indicators .active{opacity:1}.carousel-caption{bottom:1.25rem;color:#fff;left:15%;padding-bottom:1.25rem;padding-top:1.25rem;position:absolute;right:15%;text-align:center}.carousel-dark .carousel-control-next-icon,.carousel-dark .carousel-control-prev-icon{filter:invert(1) grayscale(100)}.carousel-dark .carousel-indicators [data-bs-target]{background-color:#000}.carousel-dark .carousel-caption{color:#000}@keyframes spinner-border{to{transform:rotate(1turn)}}.spinner-border{animation:spinner-border .75s linear infinite;border:.25em solid;border-radius:50%;border-right:.25em solid #0000;display:inline-block;height:2rem;vertical-align:-.125em;width:2rem}.spinner-border-sm{border-width:.2em;height:1rem;width:1rem}@keyframes spinner-grow{0%{transform:scale(0)}50%{opacity:1;transform:none}}.spinner-grow{animation:spinner-grow .75s linear infinite;background-color:currentColor;border-radius:50%;display:inline-block;height:2rem;opacity:0;vertical-align:-.125em;width:2rem}.spinner-grow-sm{height:1rem;width:1rem}@media (prefers-reduced-motion:reduce){.spinner-border,.spinner-grow{animation-duration:1.5s}}.offcanvas{background-clip:padding-box;background-color:#fff;bottom:0;display:flex;flex-direction:column;max-width:100%;outline:0;position:fixed;transition:transform .3s ease-in-out;visibility:hidden;z-index:1045}@media (prefers-reduced-motion:reduce){.offcanvas{transition:none}}.offcanvas-backdrop{background-color:#000;height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:1040}.offcanvas-backdrop.fade{opacity:0}.offcanvas-backdrop.show{opacity:.5}.offcanvas-header{align-items:center;display:flex;justify-content:space-between;padding:1rem}.offcanvas-header .btn-close{margin-bottom:-.5rem;margin-right:-.5rem;margin-top:-.5rem;padding:.5rem}.offcanvas-title{line-height:1.5;margin-bottom:0}.offcanvas-body{flex-grow:1;overflow-y:auto;padding:1rem}.offcanvas-start{border-right:1px solid #0003;left:0;top:0;transform:translateX(-100%);width:400px}.offcanvas-end{border-left:1px solid #0003;right:0;top:0;transform:translateX(100%);width:400px}.offcanvas-top{border-bottom:1px solid #0003;top:0;transform:translateY(-100%)}.offcanvas-bottom,.offcanvas-top{height:30vh;left:0;max-height:100%;right:0}.offcanvas-bottom{border-top:1px solid #0003;transform:translateY(100%)}.offcanvas.show{transform:none}.placeholder{background-color:currentColor;cursor:wait;display:inline-block;min-height:1em;opacity:.5;vertical-align:middle}.placeholder.btn:before{content:"";display:inline-block}.placeholder-xs{min-height:.6em}.placeholder-sm{min-height:.8em}.placeholder-lg{min-height:1.2em}.placeholder-glow .placeholder{animation:placeholder-glow 2s ease-in-out infinite}@keyframes placeholder-glow{50%{opacity:.2}}.placeholder-wave{animation:placeholder-wave 2s linear infinite;-webkit-mask-image:linear-gradient(130deg,#000 55%,#000c 75%,#000 95%);mask-image:linear-gradient(130deg,#000 55%,#000c 75%,#000 95%);-webkit-mask-size:200% 100%;mask-size:200% 100%}@keyframes placeholder-wave{to{-webkit-mask-position:-200% 0;mask-position:-200% 0}}.clearfix:after{clear:both;content:"";display:block}.link-primary{color:#0d6efd}.link-primary:focus,.link-primary:hover{color:#0a58ca}.link-secondary{color:#6c757d}.link-secondary:focus,.link-secondary:hover{color:#565e64}.link-success{color:#198754}.link-success:focus,.link-success:hover{color:#146c43}.link-info{color:#0dcaf0}.link-info:focus,.link-info:hover{color:#3dd5f3}.link-warning{color:#ffc107}.link-warning:focus,.link-warning:hover{color:#ffcd39}.link-danger{color:#dc3545}.link-danger:focus,.link-danger:hover{color:#b02a37}.link-light{color:#f8f9fa}.link-light:focus,.link-light:hover{color:#f9fafb}.link-dark{color:#212529}.link-dark:focus,.link-dark:hover{color:#1a1e21}.ratio{position:relative;width:100%}.ratio:before{content:"";display:block;padding-top:var(--bs-aspect-ratio)}.ratio>*{height:100%;left:0;position:absolute;top:0;width:100%}.ratio-1x1{--bs-aspect-ratio:100%}.ratio-4x3{--bs-aspect-ratio:75%}.ratio-16x9{--bs-aspect-ratio:56.25%}.ratio-21x9{--bs-aspect-ratio:42.8571428571%}.fixed-top{top:0}.fixed-bottom,.fixed-top{left:0;position:fixed;right:0;z-index:1030}.fixed-bottom{bottom:0}.sticky-top{position:sticky;top:0;z-index:1020}@media (min-width:576px){.sticky-sm-top{position:sticky;top:0;z-index:1020}}@media (min-width:768px){.sticky-md-top{position:sticky;top:0;z-index:1020}}@media (min-width:992px){.sticky-lg-top{position:sticky;top:0;z-index:1020}}@media (min-width:1200px){.sticky-xl-top{position:sticky;top:0;z-index:1020}}@media (min-width:1400px){.sticky-xxl-top{position:sticky;top:0;z-index:1020}}.hstack{align-items:center;flex-direction:row}.hstack,.vstack{align-self:stretch;display:flex}.vstack{flex:1 1 auto;flex-direction:column}.visually-hidden,.visually-hidden-focusable:not(:focus):not(:focus-within){clip:rect(0,0,0,0)!important;border:0!important;height:1px!important;margin:-1px!important;overflow:hidden!important;padding:0!important;position:absolute!important;white-space:nowrap!important;width:1px!important}.stretched-link:after{bottom:0;content:"";left:0;position:absolute;right:0;top:0;z-index:1}.text-truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vr{align-self:stretch;background-color:currentColor;display:inline-block;min-height:1em;opacity:.25;width:1px}.align-baseline{vertical-align:initial!important}.align-top{vertical-align:top!important}.align-middle{vertical-align:middle!important}.align-bottom{vertical-align:bottom!important}.align-text-bottom{vertical-align:text-bottom!important}.align-text-top{vertical-align:text-top!important}.float-start{float:left!important}.float-end{float:right!important}.float-none{float:none!important}.opacity-0{opacity:0!important}.opacity-25{opacity:.25!important}.opacity-50{opacity:.5!important}.opacity-75{opacity:.75!important}.opacity-100{opacity:1!important}.overflow-auto{overflow:auto!important}.overflow-hidden{overflow:hidden!important}.overflow-visible{overflow:visible!important}.overflow-scroll{overflow:scroll!important}.d-inline{display:inline!important}.d-inline-block{display:inline-block!important}.d-block{display:block!important}.d-grid{display:grid!important}.d-table{display:table!important}.d-table-row{display:table-row!important}.d-table-cell{display:table-cell!important}.d-flex{display:flex!important}.d-inline-flex{display:inline-flex!important}.d-none{display:none!important}.shadow{box-shadow:0 .5rem 1rem #00000026!important}.shadow-sm{box-shadow:0 .125rem .25rem rgba(0,0,0,.075)!important}.shadow-lg{box-shadow:0 1rem 3rem rgba(0,0,0,.175)!important}.shadow-none{box-shadow:none!important}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-sticky{position:sticky!important}.top-0{top:0!important}.top-50{top:50%!important}.top-100{top:100%!important}.bottom-0{bottom:0!important}.bottom-50{bottom:50%!important}.bottom-100{bottom:100%!important}.start-0{left:0!important}.start-50{left:50%!important}.start-100{left:100%!important}.end-0{right:0!important}.end-50{right:50%!important}.end-100{right:100%!important}.translate-middle{transform:translate(-50%,-50%)!important}.translate-middle-x{transform:translateX(-50%)!important}.translate-middle-y{transform:translateY(-50%)!important}.border{border:1px solid #dee2e6!important}.border-0{border:0!important}.border-top{border-top:1px solid #dee2e6!important}.border-top-0{border-top:0!important}.border-end{border-right:1px solid #dee2e6!important}.border-end-0{border-right:0!important}.border-bottom{border-bottom:1px solid #dee2e6!important}.border-bottom-0{border-bottom:0!important}.border-start{border-left:1px solid #dee2e6!important}.border-start-0{border-left:0!important}.border-primary{border-color:#0d6efd!important}.border-secondary{border-color:#6c757d!important}.border-success{border-color:#198754!important}.border-info{border-color:#0dcaf0!important}.border-warning{border-color:#ffc107!important}.border-danger{border-color:#dc3545!important}.border-light{border-color:#f8f9fa!important}.border-dark{border-color:#212529!important}.border-white{border-color:#fff!important}.border-1{border-width:1px!important}.border-2{border-width:2px!important}.border-3{border-width:3px!important}.border-4{border-width:4px!important}.border-5{border-width:5px!important}.w-25{width:25%!important}.w-50{width:50%!important}.w-75{width:75%!important}.w-100{width:100%!important}.w-auto{width:auto!important}.mw-100{max-width:100%!important}.vw-100{width:100vw!important}.min-vw-100{min-width:100vw!important}.h-25{height:25%!important}.h-50{height:50%!important}.h-75{height:75%!important}.h-100{height:100%!important}.h-auto{height:auto!important}.mh-100{max-height:100%!important}.vh-100{height:100vh!important}.min-vh-100{min-height:100vh!important}.flex-fill{flex:1 1 auto!important}.flex-row{flex-direction:row!important}.flex-column{flex-direction:column!important}.flex-row-reverse{flex-direction:row-reverse!important}.flex-column-reverse{flex-direction:column-reverse!important}.flex-grow-0{flex-grow:0!important}.flex-grow-1{flex-grow:1!important}.flex-shrink-0{flex-shrink:0!important}.flex-shrink-1{flex-shrink:1!important}.flex-wrap{flex-wrap:wrap!important}.flex-nowrap{flex-wrap:nowrap!important}.flex-wrap-reverse{flex-wrap:wrap-reverse!important}.gap-0{gap:0!important}.gap-1{gap:.25rem!important}.gap-2{gap:.5rem!important}.gap-3{gap:1rem!important}.gap-4{gap:1.5rem!important}.gap-5{gap:3rem!important}.justify-content-start{justify-content:flex-start!important}.justify-content-end{justify-content:flex-end!important}.justify-content-center{justify-content:center!important}.justify-content-between{justify-content:space-between!important}.justify-content-around{justify-content:space-around!important}.justify-content-evenly{justify-content:space-evenly!important}.align-items-start{align-items:flex-start!important}.align-items-end{align-items:flex-end!important}.align-items-center{align-items:center!important}.align-items-baseline{align-items:baseline!important}.align-items-stretch{align-items:stretch!important}.align-content-start{align-content:flex-start!important}.align-content-end{align-content:flex-end!important}.align-content-center{align-content:center!important}.align-content-between{align-content:space-between!important}.align-content-around{align-content:space-around!important}.align-content-stretch{align-content:stretch!important}.align-self-auto{align-self:auto!important}.align-self-start{align-self:flex-start!important}.align-self-end{align-self:flex-end!important}.align-self-center{align-self:center!important}.align-self-baseline{align-self:baseline!important}.align-self-stretch{align-self:stretch!important}.order-first{order:-1!important}.order-0{order:0!important}.order-1{order:1!important}.order-2{order:2!important}.order-3{order:3!important}.order-4{order:4!important}.order-5{order:5!important}.order-last{order:6!important}.m-0{margin:0!important}.m-1{margin:.25rem!important}.m-2{margin:.5rem!important}.m-3{margin:1rem!important}.m-4{margin:1.5rem!important}.m-5{margin:3rem!important}.m-auto{margin:auto!important}.mx-0{margin-left:0!important;margin-right:0!important}.mx-1{margin-left:.25rem!important;margin-right:.25rem!important}.mx-2{margin-left:.5rem!important;margin-right:.5rem!important}.mx-3{margin-left:1rem!important;margin-right:1rem!important}.mx-4{margin-left:1.5rem!important;margin-right:1.5rem!important}.mx-5{margin-left:3rem!important;margin-right:3rem!important}.mx-auto{margin-left:auto!important;margin-right:auto!important}.my-0{margin-bottom:0!important;margin-top:0!important}.my-1{margin-bottom:.25rem!important;margin-top:.25rem!important}.my-2{margin-bottom:.5rem!important;margin-top:.5rem!important}.my-3{margin-bottom:1rem!important;margin-top:1rem!important}.my-4{margin-bottom:1.5rem!important;margin-top:1.5rem!important}.my-5{margin-bottom:3rem!important;margin-top:3rem!important}.my-auto{margin-bottom:auto!important;margin-top:auto!important}.mt-0{margin-top:0!important}.mt-1{margin-top:.25rem!important}.mt-2{margin-top:.5rem!important}.mt-3{margin-top:1rem!important}.mt-4{margin-top:1.5rem!important}.mt-5{margin-top:3rem!important}.mt-auto{margin-top:auto!important}.me-0{margin-right:0!important}.me-1{margin-right:.25rem!important}.me-2{margin-right:.5rem!important}.me-3{margin-right:1rem!important}.me-4{margin-right:1.5rem!important}.me-5{margin-right:3rem!important}.me-auto{margin-right:auto!important}.mb-0{margin-bottom:0!important}.mb-1{margin-bottom:.25rem!important}.mb-2{margin-bottom:.5rem!important}.mb-3{margin-bottom:1rem!important}.mb-4{margin-bottom:1.5rem!important}.mb-5{margin-bottom:3rem!important}.mb-auto{margin-bottom:auto!important}.ms-0{margin-left:0!important}.ms-1{margin-left:.25rem!important}.ms-2{margin-left:.5rem!important}.ms-3{margin-left:1rem!important}.ms-4{margin-left:1.5rem!important}.ms-5{margin-left:3rem!important}.ms-auto{margin-left:auto!important}.p-0{padding:0!important}.p-1{padding:.25rem!important}.p-2{padding:.5rem!important}.p-3{padding:1rem!important}.p-4{padding:1.5rem!important}.p-5{padding:3rem!important}.px-0{padding-left:0!important;padding-right:0!important}.px-1{padding-left:.25rem!important;padding-right:.25rem!important}.px-2{padding-left:.5rem!important;padding-right:.5rem!important}.px-3{padding-left:1rem!important;padding-right:1rem!important}.px-4{padding-left:1.5rem!important;padding-right:1.5rem!important}.px-5{padding-left:3rem!important;padding-right:3rem!important}.py-0{padding-bottom:0!important;padding-top:0!important}.py-1{padding-bottom:.25rem!important;padding-top:.25rem!important}.py-2{padding-bottom:.5rem!important;padding-top:.5rem!important}.py-3{padding-bottom:1rem!important;padding-top:1rem!important}.py-4{padding-bottom:1.5rem!important;padding-top:1.5rem!important}.py-5{padding-bottom:3rem!important;padding-top:3rem!important}.pt-0{padding-top:0!important}.pt-1{padding-top:.25rem!important}.pt-2{padding-top:.5rem!important}.pt-3{padding-top:1rem!important}.pt-4{padding-top:1.5rem!important}.pt-5{padding-top:3rem!important}.pe-0{padding-right:0!important}.pe-1{padding-right:.25rem!important}.pe-2{padding-right:.5rem!important}.pe-3{padding-right:1rem!important}.pe-4{padding-right:1.5rem!important}.pe-5{padding-right:3rem!important}.pb-0{padding-bottom:0!important}.pb-1{padding-bottom:.25rem!important}.pb-2{padding-bottom:.5rem!important}.pb-3{padding-bottom:1rem!important}.pb-4{padding-bottom:1.5rem!important}.pb-5{padding-bottom:3rem!important}.ps-0{padding-left:0!important}.ps-1{padding-left:.25rem!important}.ps-2{padding-left:.5rem!important}.ps-3{padding-left:1rem!important}.ps-4{padding-left:1.5rem!important}.ps-5{padding-left:3rem!important}.font-monospace{font-family:SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace!important;font-family:var(--bs-font-monospace)!important}.fs-1{font-size:calc(1.375rem + 1.5vw)!important}.fs-2{font-size:calc(1.325rem + .9vw)!important}.fs-3{font-size:calc(1.3rem + .6vw)!important}.fs-4{font-size:calc(1.275rem + .3vw)!important}.fs-5{font-size:1.25rem!important}.fs-6{font-size:1rem!important}.fst-italic{font-style:italic!important}.fst-normal{font-style:normal!important}.fw-light{font-weight:300!important}.fw-lighter{font-weight:lighter!important}.fw-normal{font-weight:400!important}.fw-bold{font-weight:700!important}.fw-bolder{font-weight:bolder!important}.lh-1{line-height:1!important}.lh-sm{line-height:1.25!important}.lh-base{line-height:1.5!important}.lh-lg{line-height:2!important}.text-start{text-align:left!important}.text-end{text-align:right!important}.text-center{text-align:center!important}.text-decoration-none{text-decoration:none!important}.text-decoration-underline{text-decoration:underline!important}.text-decoration-line-through{text-decoration:line-through!important}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.text-wrap{white-space:normal!important}.text-nowrap{white-space:nowrap!important}.text-break{word-wrap:break-word!important;word-break:break-word!important}.text-primary{--bs-text-opacity:1;color:rgba(13,110,253,var(--bs-text-opacity))!important;color:rgba(var(--bs-primary-rgb),var(--bs-text-opacity))!important}.text-secondary{--bs-text-opacity:1;color:rgba(108,117,125,var(--bs-text-opacity))!important;color:rgba(var(--bs-secondary-rgb),var(--bs-text-opacity))!important}.text-success{--bs-text-opacity:1;color:rgba(25,135,84,var(--bs-text-opacity))!important;color:rgba(var(--bs-success-rgb),var(--bs-text-opacity))!important}.text-info{--bs-text-opacity:1;color:rgba(13,202,240,var(--bs-text-opacity))!important;color:rgba(var(--bs-info-rgb),var(--bs-text-opacity))!important}.text-warning{--bs-text-opacity:1;color:rgba(255,193,7,var(--bs-text-opacity))!important;color:rgba(var(--bs-warning-rgb),var(--bs-text-opacity))!important}.text-danger{--bs-text-opacity:1;color:rgba(220,53,69,var(--bs-text-opacity))!important;color:rgba(var(--bs-danger-rgb),var(--bs-text-opacity))!important}.text-light{--bs-text-opacity:1;color:rgba(248,249,250,var(--bs-text-opacity))!important;color:rgba(var(--bs-light-rgb),var(--bs-text-opacity))!important}.text-dark{--bs-text-opacity:1;color:rgba(33,37,41,var(--bs-text-opacity))!important;color:rgba(var(--bs-dark-rgb),var(--bs-text-opacity))!important}.text-black{--bs-text-opacity:1;color:rgba(0,0,0,var(--bs-text-opacity))!important;color:rgba(var(--bs-black-rgb),var(--bs-text-opacity))!important}.text-white{--bs-text-opacity:1;color:rgba(255,255,255,var(--bs-text-opacity))!important;color:rgba(var(--bs-white-rgb),var(--bs-text-opacity))!important}.text-body{--bs-text-opacity:1;color:rgba(33,37,41,var(--bs-text-opacity))!important;color:rgba(var(--bs-body-color-rgb),var(--bs-text-opacity))!important}.text-muted{--bs-text-opacity:1;color:#6c757d!important}.text-black-50{--bs-text-opacity:1;color:#00000080!important}.text-white-50{--bs-text-opacity:1;color:#ffffff80!important}.text-reset{--bs-text-opacity:1;color:inherit!important}.text-opacity-25{--bs-text-opacity:0.25}.text-opacity-50{--bs-text-opacity:0.5}.text-opacity-75{--bs-text-opacity:0.75}.text-opacity-100{--bs-text-opacity:1}.bg-primary{--bs-bg-opacity:1;background-color:rgba(13,110,253,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-primary-rgb),var(--bs-bg-opacity))!important}.bg-secondary{--bs-bg-opacity:1;background-color:rgba(108,117,125,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-secondary-rgb),var(--bs-bg-opacity))!important}.bg-success{--bs-bg-opacity:1;background-color:rgba(25,135,84,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-success-rgb),var(--bs-bg-opacity))!important}.bg-info{--bs-bg-opacity:1;background-color:rgba(13,202,240,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-info-rgb),var(--bs-bg-opacity))!important}.bg-warning{--bs-bg-opacity:1;background-color:rgba(255,193,7,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-warning-rgb),var(--bs-bg-opacity))!important}.bg-danger{--bs-bg-opacity:1;background-color:rgba(220,53,69,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-danger-rgb),var(--bs-bg-opacity))!important}.bg-light{--bs-bg-opacity:1;background-color:rgba(248,249,250,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-light-rgb),var(--bs-bg-opacity))!important}.bg-dark{--bs-bg-opacity:1;background-color:rgba(33,37,41,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-dark-rgb),var(--bs-bg-opacity))!important}.bg-black{--bs-bg-opacity:1;background-color:rgba(0,0,0,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-black-rgb),var(--bs-bg-opacity))!important}.bg-white{--bs-bg-opacity:1;background-color:rgba(255,255,255,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-white-rgb),var(--bs-bg-opacity))!important}.bg-body{--bs-bg-opacity:1;background-color:rgba(255,255,255,var(--bs-bg-opacity))!important;background-color:rgba(var(--bs-body-bg-rgb),var(--bs-bg-opacity))!important}.bg-transparent{--bs-bg-opacity:1;background-color:initial!important}.bg-opacity-10{--bs-bg-opacity:0.1}.bg-opacity-25{--bs-bg-opacity:0.25}.bg-opacity-50{--bs-bg-opacity:0.5}.bg-opacity-75{--bs-bg-opacity:0.75}.bg-opacity-100{--bs-bg-opacity:1}.bg-gradient{background-image:linear-gradient(180deg,#ffffff26,#fff0)!important;background-image:var(--bs-gradient)!important}.user-select-all{-webkit-user-select:all!important;user-select:all!important}.user-select-auto{-webkit-user-select:auto!important;user-select:auto!important}.user-select-none{-webkit-user-select:none!important;user-select:none!important}.pe-none{pointer-events:none!important}.pe-auto{pointer-events:auto!important}.rounded{border-radius:.25rem!important}.rounded-0{border-radius:0!important}.rounded-1{border-radius:.2rem!important}.rounded-2{border-radius:.25rem!important}.rounded-3{border-radius:.3rem!important}.rounded-circle{border-radius:50%!important}.rounded-pill{border-radius:50rem!important}.rounded-top{border-top-left-radius:.25rem!important}.rounded-end,.rounded-top{border-top-right-radius:.25rem!important}.rounded-bottom,.rounded-end{border-bottom-right-radius:.25rem!important}.rounded-bottom,.rounded-start{border-bottom-left-radius:.25rem!important}.rounded-start{border-top-left-radius:.25rem!important}.visible{visibility:visible!important}.invisible{visibility:hidden!important}@media (min-width:576px){.float-sm-start{float:left!important}.float-sm-end{float:right!important}.float-sm-none{float:none!important}.d-sm-inline{display:inline!important}.d-sm-inline-block{display:inline-block!important}.d-sm-block{display:block!important}.d-sm-grid{display:grid!important}.d-sm-table{display:table!important}.d-sm-table-row{display:table-row!important}.d-sm-table-cell{display:table-cell!important}.d-sm-flex{display:flex!important}.d-sm-inline-flex{display:inline-flex!important}.d-sm-none{display:none!important}.flex-sm-fill{flex:1 1 auto!important}.flex-sm-row{flex-direction:row!important}.flex-sm-column{flex-direction:column!important}.flex-sm-row-reverse{flex-direction:row-reverse!important}.flex-sm-column-reverse{flex-direction:column-reverse!important}.flex-sm-grow-0{flex-grow:0!important}.flex-sm-grow-1{flex-grow:1!important}.flex-sm-shrink-0{flex-shrink:0!important}.flex-sm-shrink-1{flex-shrink:1!important}.flex-sm-wrap{flex-wrap:wrap!important}.flex-sm-nowrap{flex-wrap:nowrap!important}.flex-sm-wrap-reverse{flex-wrap:wrap-reverse!important}.gap-sm-0{gap:0!important}.gap-sm-1{gap:.25rem!important}.gap-sm-2{gap:.5rem!important}.gap-sm-3{gap:1rem!important}.gap-sm-4{gap:1.5rem!important}.gap-sm-5{gap:3rem!important}.justify-content-sm-start{justify-content:flex-start!important}.justify-content-sm-end{justify-content:flex-end!important}.justify-content-sm-center{justify-content:center!important}.justify-content-sm-between{justify-content:space-between!important}.justify-content-sm-around{justify-content:space-around!important}.justify-content-sm-evenly{justify-content:space-evenly!important}.align-items-sm-start{align-items:flex-start!important}.align-items-sm-end{align-items:flex-end!important}.align-items-sm-center{align-items:center!important}.align-items-sm-baseline{align-items:baseline!important}.align-items-sm-stretch{align-items:stretch!important}.align-content-sm-start{align-content:flex-start!important}.align-content-sm-end{align-content:flex-end!important}.align-content-sm-center{align-content:center!important}.align-content-sm-between{align-content:space-between!important}.align-content-sm-around{align-content:space-around!important}.align-content-sm-stretch{align-content:stretch!important}.align-self-sm-auto{align-self:auto!important}.align-self-sm-start{align-self:flex-start!important}.align-self-sm-end{align-self:flex-end!important}.align-self-sm-center{align-self:center!important}.align-self-sm-baseline{align-self:baseline!important}.align-self-sm-stretch{align-self:stretch!important}.order-sm-first{order:-1!important}.order-sm-0{order:0!important}.order-sm-1{order:1!important}.order-sm-2{order:2!important}.order-sm-3{order:3!important}.order-sm-4{order:4!important}.order-sm-5{order:5!important}.order-sm-last{order:6!important}.m-sm-0{margin:0!important}.m-sm-1{margin:.25rem!important}.m-sm-2{margin:.5rem!important}.m-sm-3{margin:1rem!important}.m-sm-4{margin:1.5rem!important}.m-sm-5{margin:3rem!important}.m-sm-auto{margin:auto!important}.mx-sm-0{margin-left:0!important;margin-right:0!important}.mx-sm-1{margin-left:.25rem!important;margin-right:.25rem!important}.mx-sm-2{margin-left:.5rem!important;margin-right:.5rem!important}.mx-sm-3{margin-left:1rem!important;margin-right:1rem!important}.mx-sm-4{margin-left:1.5rem!important;margin-right:1.5rem!important}.mx-sm-5{margin-left:3rem!important;margin-right:3rem!important}.mx-sm-auto{margin-left:auto!important;margin-right:auto!important}.my-sm-0{margin-bottom:0!important;margin-top:0!important}.my-sm-1{margin-bottom:.25rem!important;margin-top:.25rem!important}.my-sm-2{margin-bottom:.5rem!important;margin-top:.5rem!important}.my-sm-3{margin-bottom:1rem!important;margin-top:1rem!important}.my-sm-4{margin-bottom:1.5rem!important;margin-top:1.5rem!important}.my-sm-5{margin-bottom:3rem!important;margin-top:3rem!important}.my-sm-auto{margin-bottom:auto!important;margin-top:auto!important}.mt-sm-0{margin-top:0!important}.mt-sm-1{margin-top:.25rem!important}.mt-sm-2{margin-top:.5rem!important}.mt-sm-3{margin-top:1rem!important}.mt-sm-4{margin-top:1.5rem!important}.mt-sm-5{margin-top:3rem!important}.mt-sm-auto{margin-top:auto!important}.me-sm-0{margin-right:0!important}.me-sm-1{margin-right:.25rem!important}.me-sm-2{margin-right:.5rem!important}.me-sm-3{margin-right:1rem!important}.me-sm-4{margin-right:1.5rem!important}.me-sm-5{margin-right:3rem!important}.me-sm-auto{margin-right:auto!important}.mb-sm-0{margin-bottom:0!important}.mb-sm-1{margin-bottom:.25rem!important}.mb-sm-2{margin-bottom:.5rem!important}.mb-sm-3{margin-bottom:1rem!important}.mb-sm-4{margin-bottom:1.5rem!important}.mb-sm-5{margin-bottom:3rem!important}.mb-sm-auto{margin-bottom:auto!important}.ms-sm-0{margin-left:0!important}.ms-sm-1{margin-left:.25rem!important}.ms-sm-2{margin-left:.5rem!important}.ms-sm-3{margin-left:1rem!important}.ms-sm-4{margin-left:1.5rem!important}.ms-sm-5{margin-left:3rem!important}.ms-sm-auto{margin-left:auto!important}.p-sm-0{padding:0!important}.p-sm-1{padding:.25rem!important}.p-sm-2{padding:.5rem!important}.p-sm-3{padding:1rem!important}.p-sm-4{padding:1.5rem!important}.p-sm-5{padding:3rem!important}.px-sm-0{padding-left:0!important;padding-right:0!important}.px-sm-1{padding-left:.25rem!important;padding-right:.25rem!important}.px-sm-2{padding-left:.5rem!important;padding-right:.5rem!important}.px-sm-3{padding-left:1rem!important;padding-right:1rem!important}.px-sm-4{padding-left:1.5rem!important;padding-right:1.5rem!important}.px-sm-5{padding-left:3rem!important;padding-right:3rem!important}.py-sm-0{padding-bottom:0!important;padding-top:0!important}.py-sm-1{padding-bottom:.25rem!important;padding-top:.25rem!important}.py-sm-2{padding-bottom:.5rem!important;padding-top:.5rem!important}.py-sm-3{padding-bottom:1rem!important;padding-top:1rem!important}.py-sm-4{padding-bottom:1.5rem!important;padding-top:1.5rem!important}.py-sm-5{padding-bottom:3rem!important;padding-top:3rem!important}.pt-sm-0{padding-top:0!important}.pt-sm-1{padding-top:.25rem!important}.pt-sm-2{padding-top:.5rem!important}.pt-sm-3{padding-top:1rem!important}.pt-sm-4{padding-top:1.5rem!important}.pt-sm-5{padding-top:3rem!important}.pe-sm-0{padding-right:0!important}.pe-sm-1{padding-right:.25rem!important}.pe-sm-2{padding-right:.5rem!important}.pe-sm-3{padding-right:1rem!important}.pe-sm-4{padding-right:1.5rem!important}.pe-sm-5{padding-right:3rem!important}.pb-sm-0{padding-bottom:0!important}.pb-sm-1{padding-bottom:.25rem!important}.pb-sm-2{padding-bottom:.5rem!important}.pb-sm-3{padding-bottom:1rem!important}.pb-sm-4{padding-bottom:1.5rem!important}.pb-sm-5{padding-bottom:3rem!important}.ps-sm-0{padding-left:0!important}.ps-sm-1{padding-left:.25rem!important}.ps-sm-2{padding-left:.5rem!important}.ps-sm-3{padding-left:1rem!important}.ps-sm-4{padding-left:1.5rem!important}.ps-sm-5{padding-left:3rem!important}.text-sm-start{text-align:left!important}.text-sm-end{text-align:right!important}.text-sm-center{text-align:center!important}}@media (min-width:768px){.float-md-start{float:left!important}.float-md-end{float:right!important}.float-md-none{float:none!important}.d-md-inline{display:inline!important}.d-md-inline-block{display:inline-block!important}.d-md-block{display:block!important}.d-md-grid{display:grid!important}.d-md-table{display:table!important}.d-md-table-row{display:table-row!important}.d-md-table-cell{display:table-cell!important}.d-md-flex{display:flex!important}.d-md-inline-flex{display:inline-flex!important}.d-md-none{display:none!important}.flex-md-fill{flex:1 1 auto!important}.flex-md-row{flex-direction:row!important}.flex-md-column{flex-direction:column!important}.flex-md-row-reverse{flex-direction:row-reverse!important}.flex-md-column-reverse{flex-direction:column-reverse!important}.flex-md-grow-0{flex-grow:0!important}.flex-md-grow-1{flex-grow:1!important}.flex-md-shrink-0{flex-shrink:0!important}.flex-md-shrink-1{flex-shrink:1!important}.flex-md-wrap{flex-wrap:wrap!important}.flex-md-nowrap{flex-wrap:nowrap!important}.flex-md-wrap-reverse{flex-wrap:wrap-reverse!important}.gap-md-0{gap:0!important}.gap-md-1{gap:.25rem!important}.gap-md-2{gap:.5rem!important}.gap-md-3{gap:1rem!important}.gap-md-4{gap:1.5rem!important}.gap-md-5{gap:3rem!important}.justify-content-md-start{justify-content:flex-start!important}.justify-content-md-end{justify-content:flex-end!important}.justify-content-md-center{justify-content:center!important}.justify-content-md-between{justify-content:space-between!important}.justify-content-md-around{justify-content:space-around!important}.justify-content-md-evenly{justify-content:space-evenly!important}.align-items-md-start{align-items:flex-start!important}.align-items-md-end{align-items:flex-end!important}.align-items-md-center{align-items:center!important}.align-items-md-baseline{align-items:baseline!important}.align-items-md-stretch{align-items:stretch!important}.align-content-md-start{align-content:flex-start!important}.align-content-md-end{align-content:flex-end!important}.align-content-md-center{align-content:center!important}.align-content-md-between{align-content:space-between!important}.align-content-md-around{align-content:space-around!important}.align-content-md-stretch{align-content:stretch!important}.align-self-md-auto{align-self:auto!important}.align-self-md-start{align-self:flex-start!important}.align-self-md-end{align-self:flex-end!important}.align-self-md-center{align-self:center!important}.align-self-md-baseline{align-self:baseline!important}.align-self-md-stretch{align-self:stretch!important}.order-md-first{order:-1!important}.order-md-0{order:0!important}.order-md-1{order:1!important}.order-md-2{order:2!important}.order-md-3{order:3!important}.order-md-4{order:4!important}.order-md-5{order:5!important}.order-md-last{order:6!important}.m-md-0{margin:0!important}.m-md-1{margin:.25rem!important}.m-md-2{margin:.5rem!important}.m-md-3{margin:1rem!important}.m-md-4{margin:1.5rem!important}.m-md-5{margin:3rem!important}.m-md-auto{margin:auto!important}.mx-md-0{margin-left:0!important;margin-right:0!important}.mx-md-1{margin-left:.25rem!important;margin-right:.25rem!important}.mx-md-2{margin-left:.5rem!important;margin-right:.5rem!important}.mx-md-3{margin-left:1rem!important;margin-right:1rem!important}.mx-md-4{margin-left:1.5rem!important;margin-right:1.5rem!important}.mx-md-5{margin-left:3rem!important;margin-right:3rem!important}.mx-md-auto{margin-left:auto!important;margin-right:auto!important}.my-md-0{margin-bottom:0!important;margin-top:0!important}.my-md-1{margin-bottom:.25rem!important;margin-top:.25rem!important}.my-md-2{margin-bottom:.5rem!important;margin-top:.5rem!important}.my-md-3{margin-bottom:1rem!important;margin-top:1rem!important}.my-md-4{margin-bottom:1.5rem!important;margin-top:1.5rem!important}.my-md-5{margin-bottom:3rem!important;margin-top:3rem!important}.my-md-auto{margin-bottom:auto!important;margin-top:auto!important}.mt-md-0{margin-top:0!important}.mt-md-1{margin-top:.25rem!important}.mt-md-2{margin-top:.5rem!important}.mt-md-3{margin-top:1rem!important}.mt-md-4{margin-top:1.5rem!important}.mt-md-5{margin-top:3rem!important}.mt-md-auto{margin-top:auto!important}.me-md-0{margin-right:0!important}.me-md-1{margin-right:.25rem!important}.me-md-2{margin-right:.5rem!important}.me-md-3{margin-right:1rem!important}.me-md-4{margin-right:1.5rem!important}.me-md-5{margin-right:3rem!important}.me-md-auto{margin-right:auto!important}.mb-md-0{margin-bottom:0!important}.mb-md-1{margin-bottom:.25rem!important}.mb-md-2{margin-bottom:.5rem!important}.mb-md-3{margin-bottom:1rem!important}.mb-md-4{margin-bottom:1.5rem!important}.mb-md-5{margin-bottom:3rem!important}.mb-md-auto{margin-bottom:auto!important}.ms-md-0{margin-left:0!important}.ms-md-1{margin-left:.25rem!important}.ms-md-2{margin-left:.5rem!important}.ms-md-3{margin-left:1rem!important}.ms-md-4{margin-left:1.5rem!important}.ms-md-5{margin-left:3rem!important}.ms-md-auto{margin-left:auto!important}.p-md-0{padding:0!important}.p-md-1{padding:.25rem!important}.p-md-2{padding:.5rem!important}.p-md-3{padding:1rem!important}.p-md-4{padding:1.5rem!important}.p-md-5{padding:3rem!important}.px-md-0{padding-left:0!important;padding-right:0!important}.px-md-1{padding-left:.25rem!important;padding-right:.25rem!important}.px-md-2{padding-left:.5rem!important;padding-right:.5rem!important}.px-md-3{padding-left:1rem!important;padding-right:1rem!important}.px-md-4{padding-left:1.5rem!important;padding-right:1.5rem!important}.px-md-5{padding-left:3rem!important;padding-right:3rem!important}.py-md-0{padding-bottom:0!important;padding-top:0!important}.py-md-1{padding-bottom:.25rem!important;padding-top:.25rem!important}.py-md-2{padding-bottom:.5rem!important;padding-top:.5rem!important}.py-md-3{padding-bottom:1rem!important;padding-top:1rem!important}.py-md-4{padding-bottom:1.5rem!important;padding-top:1.5rem!important}.py-md-5{padding-bottom:3rem!important;padding-top:3rem!important}.pt-md-0{padding-top:0!important}.pt-md-1{padding-top:.25rem!important}.pt-md-2{padding-top:.5rem!important}.pt-md-3{padding-top:1rem!important}.pt-md-4{padding-top:1.5rem!important}.pt-md-5{padding-top:3rem!important}.pe-md-0{padding-right:0!important}.pe-md-1{padding-right:.25rem!important}.pe-md-2{padding-right:.5rem!important}.pe-md-3{padding-right:1rem!important}.pe-md-4{padding-right:1.5rem!important}.pe-md-5{padding-right:3rem!important}.pb-md-0{padding-bottom:0!important}.pb-md-1{padding-bottom:.25rem!important}.pb-md-2{padding-bottom:.5rem!important}.pb-md-3{padding-bottom:1rem!important}.pb-md-4{padding-bottom:1.5rem!important}.pb-md-5{padding-bottom:3rem!important}.ps-md-0{padding-left:0!important}.ps-md-1{padding-left:.25rem!important}.ps-md-2{padding-left:.5rem!important}.ps-md-3{padding-left:1rem!important}.ps-md-4{padding-left:1.5rem!important}.ps-md-5{padding-left:3rem!important}.text-md-start{text-align:left!important}.text-md-end{text-align:right!important}.text-md-center{text-align:center!important}}@media (min-width:992px){.float-lg-start{float:left!important}.float-lg-end{float:right!important}.float-lg-none{float:none!important}.d-lg-inline{display:inline!important}.d-lg-inline-block{display:inline-block!important}.d-lg-block{display:block!important}.d-lg-grid{display:grid!important}.d-lg-table{display:table!important}.d-lg-table-row{display:table-row!important}.d-lg-table-cell{display:table-cell!important}.d-lg-flex{display:flex!important}.d-lg-inline-flex{display:inline-flex!important}.d-lg-none{display:none!important}.flex-lg-fill{flex:1 1 auto!important}.flex-lg-row{flex-direction:row!important}.flex-lg-column{flex-direction:column!important}.flex-lg-row-reverse{flex-direction:row-reverse!important}.flex-lg-column-reverse{flex-direction:column-reverse!important}.flex-lg-grow-0{flex-grow:0!important}.flex-lg-grow-1{flex-grow:1!important}.flex-lg-shrink-0{flex-shrink:0!important}.flex-lg-shrink-1{flex-shrink:1!important}.flex-lg-wrap{flex-wrap:wrap!important}.flex-lg-nowrap{flex-wrap:nowrap!important}.flex-lg-wrap-reverse{flex-wrap:wrap-reverse!important}.gap-lg-0{gap:0!important}.gap-lg-1{gap:.25rem!important}.gap-lg-2{gap:.5rem!important}.gap-lg-3{gap:1rem!important}.gap-lg-4{gap:1.5rem!important}.gap-lg-5{gap:3rem!important}.justify-content-lg-start{justify-content:flex-start!important}.justify-content-lg-end{justify-content:flex-end!important}.justify-content-lg-center{justify-content:center!important}.justify-content-lg-between{justify-content:space-between!important}.justify-content-lg-around{justify-content:space-around!important}.justify-content-lg-evenly{justify-content:space-evenly!important}.align-items-lg-start{align-items:flex-start!important}.align-items-lg-end{align-items:flex-end!important}.align-items-lg-center{align-items:center!important}.align-items-lg-baseline{align-items:baseline!important}.align-items-lg-stretch{align-items:stretch!important}.align-content-lg-start{align-content:flex-start!important}.align-content-lg-end{align-content:flex-end!important}.align-content-lg-center{align-content:center!important}.align-content-lg-between{align-content:space-between!important}.align-content-lg-around{align-content:space-around!important}.align-content-lg-stretch{align-content:stretch!important}.align-self-lg-auto{align-self:auto!important}.align-self-lg-start{align-self:flex-start!important}.align-self-lg-end{align-self:flex-end!important}.align-self-lg-center{align-self:center!important}.align-self-lg-baseline{align-self:baseline!important}.align-self-lg-stretch{align-self:stretch!important}.order-lg-first{order:-1!important}.order-lg-0{order:0!important}.order-lg-1{order:1!important}.order-lg-2{order:2!important}.order-lg-3{order:3!important}.order-lg-4{order:4!important}.order-lg-5{order:5!important}.order-lg-last{order:6!important}.m-lg-0{margin:0!important}.m-lg-1{margin:.25rem!important}.m-lg-2{margin:.5rem!important}.m-lg-3{margin:1rem!important}.m-lg-4{margin:1.5rem!important}.m-lg-5{margin:3rem!important}.m-lg-auto{margin:auto!important}.mx-lg-0{margin-left:0!important;margin-right:0!important}.mx-lg-1{margin-left:.25rem!important;margin-right:.25rem!important}.mx-lg-2{margin-left:.5rem!important;margin-right:.5rem!important}.mx-lg-3{margin-left:1rem!important;margin-right:1rem!important}.mx-lg-4{margin-left:1.5rem!important;margin-right:1.5rem!important}.mx-lg-5{margin-left:3rem!important;margin-right:3rem!important}.mx-lg-auto{margin-left:auto!important;margin-right:auto!important}.my-lg-0{margin-bottom:0!important;margin-top:0!important}.my-lg-1{margin-bottom:.25rem!important;margin-top:.25rem!important}.my-lg-2{margin-bottom:.5rem!important;margin-top:.5rem!important}.my-lg-3{margin-bottom:1rem!important;margin-top:1rem!important}.my-lg-4{margin-bottom:1.5rem!important;margin-top:1.5rem!important}.my-lg-5{margin-bottom:3rem!important;margin-top:3rem!important}.my-lg-auto{margin-bottom:auto!important;margin-top:auto!important}.mt-lg-0{margin-top:0!important}.mt-lg-1{margin-top:.25rem!important}.mt-lg-2{margin-top:.5rem!important}.mt-lg-3{margin-top:1rem!important}.mt-lg-4{margin-top:1.5rem!important}.mt-lg-5{margin-top:3rem!important}.mt-lg-auto{margin-top:auto!important}.me-lg-0{margin-right:0!important}.me-lg-1{margin-right:.25rem!important}.me-lg-2{margin-right:.5rem!important}.me-lg-3{margin-right:1rem!important}.me-lg-4{margin-right:1.5rem!important}.me-lg-5{margin-right:3rem!important}.me-lg-auto{margin-right:auto!important}.mb-lg-0{margin-bottom:0!important}.mb-lg-1{margin-bottom:.25rem!important}.mb-lg-2{margin-bottom:.5rem!important}.mb-lg-3{margin-bottom:1rem!important}.mb-lg-4{margin-bottom:1.5rem!important}.mb-lg-5{margin-bottom:3rem!important}.mb-lg-auto{margin-bottom:auto!important}.ms-lg-0{margin-left:0!important}.ms-lg-1{margin-left:.25rem!important}.ms-lg-2{margin-left:.5rem!important}.ms-lg-3{margin-left:1rem!important}.ms-lg-4{margin-left:1.5rem!important}.ms-lg-5{margin-left:3rem!important}.ms-lg-auto{margin-left:auto!important}.p-lg-0{padding:0!important}.p-lg-1{padding:.25rem!important}.p-lg-2{padding:.5rem!important}.p-lg-3{padding:1rem!important}.p-lg-4{padding:1.5rem!important}.p-lg-5{padding:3rem!important}.px-lg-0{padding-left:0!important;padding-right:0!important}.px-lg-1{padding-left:.25rem!important;padding-right:.25rem!important}.px-lg-2{padding-left:.5rem!important;padding-right:.5rem!important}.px-lg-3{padding-left:1rem!important;padding-right:1rem!important}.px-lg-4{padding-left:1.5rem!important;padding-right:1.5rem!important}.px-lg-5{padding-left:3rem!important;padding-right:3rem!important}.py-lg-0{padding-bottom:0!important;padding-top:0!important}.py-lg-1{padding-bottom:.25rem!important;padding-top:.25rem!important}.py-lg-2{padding-bottom:.5rem!important;padding-top:.5rem!important}.py-lg-3{padding-bottom:1rem!important;padding-top:1rem!important}.py-lg-4{padding-bottom:1.5rem!important;padding-top:1.5rem!important}.py-lg-5{padding-bottom:3rem!important;padding-top:3rem!important}.pt-lg-0{padding-top:0!important}.pt-lg-1{padding-top:.25rem!important}.pt-lg-2{padding-top:.5rem!important}.pt-lg-3{padding-top:1rem!important}.pt-lg-4{padding-top:1.5rem!important}.pt-lg-5{padding-top:3rem!important}.pe-lg-0{padding-right:0!important}.pe-lg-1{padding-right:.25rem!important}.pe-lg-2{padding-right:.5rem!important}.pe-lg-3{padding-right:1rem!important}.pe-lg-4{padding-right:1.5rem!important}.pe-lg-5{padding-right:3rem!important}.pb-lg-0{padding-bottom:0!important}.pb-lg-1{padding-bottom:.25rem!important}.pb-lg-2{padding-bottom:.5rem!important}.pb-lg-3{padding-bottom:1rem!important}.pb-lg-4{padding-bottom:1.5rem!important}.pb-lg-5{padding-bottom:3rem!important}.ps-lg-0{padding-left:0!important}.ps-lg-1{padding-left:.25rem!important}.ps-lg-2{padding-left:.5rem!important}.ps-lg-3{padding-left:1rem!important}.ps-lg-4{padding-left:1.5rem!important}.ps-lg-5{padding-left:3rem!important}.text-lg-start{text-align:left!important}.text-lg-end{text-align:right!important}.text-lg-center{text-align:center!important}}@media (min-width:1200px){.float-xl-start{float:left!important}.float-xl-end{float:right!important}.float-xl-none{float:none!important}.d-xl-inline{display:inline!important}.d-xl-inline-block{display:inline-block!important}.d-xl-block{display:block!important}.d-xl-grid{display:grid!important}.d-xl-table{display:table!important}.d-xl-table-row{display:table-row!important}.d-xl-table-cell{display:table-cell!important}.d-xl-flex{display:flex!important}.d-xl-inline-flex{display:inline-flex!important}.d-xl-none{display:none!important}.flex-xl-fill{flex:1 1 auto!important}.flex-xl-row{flex-direction:row!important}.flex-xl-column{flex-direction:column!important}.flex-xl-row-reverse{flex-direction:row-reverse!important}.flex-xl-column-reverse{flex-direction:column-reverse!important}.flex-xl-grow-0{flex-grow:0!important}.flex-xl-grow-1{flex-grow:1!important}.flex-xl-shrink-0{flex-shrink:0!important}.flex-xl-shrink-1{flex-shrink:1!important}.flex-xl-wrap{flex-wrap:wrap!important}.flex-xl-nowrap{flex-wrap:nowrap!important}.flex-xl-wrap-reverse{flex-wrap:wrap-reverse!important}.gap-xl-0{gap:0!important}.gap-xl-1{gap:.25rem!important}.gap-xl-2{gap:.5rem!important}.gap-xl-3{gap:1rem!important}.gap-xl-4{gap:1.5rem!important}.gap-xl-5{gap:3rem!important}.justify-content-xl-start{justify-content:flex-start!important}.justify-content-xl-end{justify-content:flex-end!important}.justify-content-xl-center{justify-content:center!important}.justify-content-xl-between{justify-content:space-between!important}.justify-content-xl-around{justify-content:space-around!important}.justify-content-xl-evenly{justify-content:space-evenly!important}.align-items-xl-start{align-items:flex-start!important}.align-items-xl-end{align-items:flex-end!important}.align-items-xl-center{align-items:center!important}.align-items-xl-baseline{align-items:baseline!important}.align-items-xl-stretch{align-items:stretch!important}.align-content-xl-start{align-content:flex-start!important}.align-content-xl-end{align-content:flex-end!important}.align-content-xl-center{align-content:center!important}.align-content-xl-between{align-content:space-between!important}.align-content-xl-around{align-content:space-around!important}.align-content-xl-stretch{align-content:stretch!important}.align-self-xl-auto{align-self:auto!important}.align-self-xl-start{align-self:flex-start!important}.align-self-xl-end{align-self:flex-end!important}.align-self-xl-center{align-self:center!important}.align-self-xl-baseline{align-self:baseline!important}.align-self-xl-stretch{align-self:stretch!important}.order-xl-first{order:-1!important}.order-xl-0{order:0!important}.order-xl-1{order:1!important}.order-xl-2{order:2!important}.order-xl-3{order:3!important}.order-xl-4{order:4!important}.order-xl-5{order:5!important}.order-xl-last{order:6!important}.m-xl-0{margin:0!important}.m-xl-1{margin:.25rem!important}.m-xl-2{margin:.5rem!important}.m-xl-3{margin:1rem!important}.m-xl-4{margin:1.5rem!important}.m-xl-5{margin:3rem!important}.m-xl-auto{margin:auto!important}.mx-xl-0{margin-left:0!important;margin-right:0!important}.mx-xl-1{margin-left:.25rem!important;margin-right:.25rem!important}.mx-xl-2{margin-left:.5rem!important;margin-right:.5rem!important}.mx-xl-3{margin-left:1rem!important;margin-right:1rem!important}.mx-xl-4{margin-left:1.5rem!important;margin-right:1.5rem!important}.mx-xl-5{margin-left:3rem!important;margin-right:3rem!important}.mx-xl-auto{margin-left:auto!important;margin-right:auto!important}.my-xl-0{margin-bottom:0!important;margin-top:0!important}.my-xl-1{margin-bottom:.25rem!important;margin-top:.25rem!important}.my-xl-2{margin-bottom:.5rem!important;margin-top:.5rem!important}.my-xl-3{margin-bottom:1rem!important;margin-top:1rem!important}.my-xl-4{margin-bottom:1.5rem!important;margin-top:1.5rem!important}.my-xl-5{margin-bottom:3rem!important;margin-top:3rem!important}.my-xl-auto{margin-bottom:auto!important;margin-top:auto!important}.mt-xl-0{margin-top:0!important}.mt-xl-1{margin-top:.25rem!important}.mt-xl-2{margin-top:.5rem!important}.mt-xl-3{margin-top:1rem!important}.mt-xl-4{margin-top:1.5rem!important}.mt-xl-5{margin-top:3rem!important}.mt-xl-auto{margin-top:auto!important}.me-xl-0{margin-right:0!important}.me-xl-1{margin-right:.25rem!important}.me-xl-2{margin-right:.5rem!important}.me-xl-3{margin-right:1rem!important}.me-xl-4{margin-right:1.5rem!important}.me-xl-5{margin-right:3rem!important}.me-xl-auto{margin-right:auto!important}.mb-xl-0{margin-bottom:0!important}.mb-xl-1{margin-bottom:.25rem!important}.mb-xl-2{margin-bottom:.5rem!important}.mb-xl-3{margin-bottom:1rem!important}.mb-xl-4{margin-bottom:1.5rem!important}.mb-xl-5{margin-bottom:3rem!important}.mb-xl-auto{margin-bottom:auto!important}.ms-xl-0{margin-left:0!important}.ms-xl-1{margin-left:.25rem!important}.ms-xl-2{margin-left:.5rem!important}.ms-xl-3{margin-left:1rem!important}.ms-xl-4{margin-left:1.5rem!important}.ms-xl-5{margin-left:3rem!important}.ms-xl-auto{margin-left:auto!important}.p-xl-0{padding:0!important}.p-xl-1{padding:.25rem!important}.p-xl-2{padding:.5rem!important}.p-xl-3{padding:1rem!important}.p-xl-4{padding:1.5rem!important}.p-xl-5{padding:3rem!important}.px-xl-0{padding-left:0!important;padding-right:0!important}.px-xl-1{padding-left:.25rem!important;padding-right:.25rem!important}.px-xl-2{padding-left:.5rem!important;padding-right:.5rem!important}.px-xl-3{padding-left:1rem!important;padding-right:1rem!important}.px-xl-4{padding-left:1.5rem!important;padding-right:1.5rem!important}.px-xl-5{padding-left:3rem!important;padding-right:3rem!important}.py-xl-0{padding-bottom:0!important;padding-top:0!important}.py-xl-1{padding-bottom:.25rem!important;padding-top:.25rem!important}.py-xl-2{padding-bottom:.5rem!important;padding-top:.5rem!important}.py-xl-3{padding-bottom:1rem!important;padding-top:1rem!important}.py-xl-4{padding-bottom:1.5rem!important;padding-top:1.5rem!important}.py-xl-5{padding-bottom:3rem!important;padding-top:3rem!important}.pt-xl-0{padding-top:0!important}.pt-xl-1{padding-top:.25rem!important}.pt-xl-2{padding-top:.5rem!important}.pt-xl-3{padding-top:1rem!important}.pt-xl-4{padding-top:1.5rem!important}.pt-xl-5{padding-top:3rem!important}.pe-xl-0{padding-right:0!important}.pe-xl-1{padding-right:.25rem!important}.pe-xl-2{padding-right:.5rem!important}.pe-xl-3{padding-right:1rem!important}.pe-xl-4{padding-right:1.5rem!important}.pe-xl-5{padding-right:3rem!important}.pb-xl-0{padding-bottom:0!important}.pb-xl-1{padding-bottom:.25rem!important}.pb-xl-2{padding-bottom:.5rem!important}.pb-xl-3{padding-bottom:1rem!important}.pb-xl-4{padding-bottom:1.5rem!important}.pb-xl-5{padding-bottom:3rem!important}.ps-xl-0{padding-left:0!important}.ps-xl-1{padding-left:.25rem!important}.ps-xl-2{padding-left:.5rem!important}.ps-xl-3{padding-left:1rem!important}.ps-xl-4{padding-left:1.5rem!important}.ps-xl-5{padding-left:3rem!important}.text-xl-start{text-align:left!important}.text-xl-end{text-align:right!important}.text-xl-center{text-align:center!important}}@media (min-width:1400px){.float-xxl-start{float:left!important}.float-xxl-end{float:right!important}.float-xxl-none{float:none!important}.d-xxl-inline{display:inline!important}.d-xxl-inline-block{display:inline-block!important}.d-xxl-block{display:block!important}.d-xxl-grid{display:grid!important}.d-xxl-table{display:table!important}.d-xxl-table-row{display:table-row!important}.d-xxl-table-cell{display:table-cell!important}.d-xxl-flex{display:flex!important}.d-xxl-inline-flex{display:inline-flex!important}.d-xxl-none{display:none!important}.flex-xxl-fill{flex:1 1 auto!important}.flex-xxl-row{flex-direction:row!important}.flex-xxl-column{flex-direction:column!important}.flex-xxl-row-reverse{flex-direction:row-reverse!important}.flex-xxl-column-reverse{flex-direction:column-reverse!important}.flex-xxl-grow-0{flex-grow:0!important}.flex-xxl-grow-1{flex-grow:1!important}.flex-xxl-shrink-0{flex-shrink:0!important}.flex-xxl-shrink-1{flex-shrink:1!important}.flex-xxl-wrap{flex-wrap:wrap!important}.flex-xxl-nowrap{flex-wrap:nowrap!important}.flex-xxl-wrap-reverse{flex-wrap:wrap-reverse!important}.gap-xxl-0{gap:0!important}.gap-xxl-1{gap:.25rem!important}.gap-xxl-2{gap:.5rem!important}.gap-xxl-3{gap:1rem!important}.gap-xxl-4{gap:1.5rem!important}.gap-xxl-5{gap:3rem!important}.justify-content-xxl-start{justify-content:flex-start!important}.justify-content-xxl-end{justify-content:flex-end!important}.justify-content-xxl-center{justify-content:center!important}.justify-content-xxl-between{justify-content:space-between!important}.justify-content-xxl-around{justify-content:space-around!important}.justify-content-xxl-evenly{justify-content:space-evenly!important}.align-items-xxl-start{align-items:flex-start!important}.align-items-xxl-end{align-items:flex-end!important}.align-items-xxl-center{align-items:center!important}.align-items-xxl-baseline{align-items:baseline!important}.align-items-xxl-stretch{align-items:stretch!important}.align-content-xxl-start{align-content:flex-start!important}.align-content-xxl-end{align-content:flex-end!important}.align-content-xxl-center{align-content:center!important}.align-content-xxl-between{align-content:space-between!important}.align-content-xxl-around{align-content:space-around!important}.align-content-xxl-stretch{align-content:stretch!important}.align-self-xxl-auto{align-self:auto!important}.align-self-xxl-start{align-self:flex-start!important}.align-self-xxl-end{align-self:flex-end!important}.align-self-xxl-center{align-self:center!important}.align-self-xxl-baseline{align-self:baseline!important}.align-self-xxl-stretch{align-self:stretch!important}.order-xxl-first{order:-1!important}.order-xxl-0{order:0!important}.order-xxl-1{order:1!important}.order-xxl-2{order:2!important}.order-xxl-3{order:3!important}.order-xxl-4{order:4!important}.order-xxl-5{order:5!important}.order-xxl-last{order:6!important}.m-xxl-0{margin:0!important}.m-xxl-1{margin:.25rem!important}.m-xxl-2{margin:.5rem!important}.m-xxl-3{margin:1rem!important}.m-xxl-4{margin:1.5rem!important}.m-xxl-5{margin:3rem!important}.m-xxl-auto{margin:auto!important}.mx-xxl-0{margin-left:0!important;margin-right:0!important}.mx-xxl-1{margin-left:.25rem!important;margin-right:.25rem!important}.mx-xxl-2{margin-left:.5rem!important;margin-right:.5rem!important}.mx-xxl-3{margin-left:1rem!important;margin-right:1rem!important}.mx-xxl-4{margin-left:1.5rem!important;margin-right:1.5rem!important}.mx-xxl-5{margin-left:3rem!important;margin-right:3rem!important}.mx-xxl-auto{margin-left:auto!important;margin-right:auto!important}.my-xxl-0{margin-bottom:0!important;margin-top:0!important}.my-xxl-1{margin-bottom:.25rem!important;margin-top:.25rem!important}.my-xxl-2{margin-bottom:.5rem!important;margin-top:.5rem!important}.my-xxl-3{margin-bottom:1rem!important;margin-top:1rem!important}.my-xxl-4{margin-bottom:1.5rem!important;margin-top:1.5rem!important}.my-xxl-5{margin-bottom:3rem!important;margin-top:3rem!important}.my-xxl-auto{margin-bottom:auto!important;margin-top:auto!important}.mt-xxl-0{margin-top:0!important}.mt-xxl-1{margin-top:.25rem!important}.mt-xxl-2{margin-top:.5rem!important}.mt-xxl-3{margin-top:1rem!important}.mt-xxl-4{margin-top:1.5rem!important}.mt-xxl-5{margin-top:3rem!important}.mt-xxl-auto{margin-top:auto!important}.me-xxl-0{margin-right:0!important}.me-xxl-1{margin-right:.25rem!important}.me-xxl-2{margin-right:.5rem!important}.me-xxl-3{margin-right:1rem!important}.me-xxl-4{margin-right:1.5rem!important}.me-xxl-5{margin-right:3rem!important}.me-xxl-auto{margin-right:auto!important}.mb-xxl-0{margin-bottom:0!important}.mb-xxl-1{margin-bottom:.25rem!important}.mb-xxl-2{margin-bottom:.5rem!important}.mb-xxl-3{margin-bottom:1rem!important}.mb-xxl-4{margin-bottom:1.5rem!important}.mb-xxl-5{margin-bottom:3rem!important}.mb-xxl-auto{margin-bottom:auto!important}.ms-xxl-0{margin-left:0!important}.ms-xxl-1{margin-left:.25rem!important}.ms-xxl-2{margin-left:.5rem!important}.ms-xxl-3{margin-left:1rem!important}.ms-xxl-4{margin-left:1.5rem!important}.ms-xxl-5{margin-left:3rem!important}.ms-xxl-auto{margin-left:auto!important}.p-xxl-0{padding:0!important}.p-xxl-1{padding:.25rem!important}.p-xxl-2{padding:.5rem!important}.p-xxl-3{padding:1rem!important}.p-xxl-4{padding:1.5rem!important}.p-xxl-5{padding:3rem!important}.px-xxl-0{padding-left:0!important;padding-right:0!important}.px-xxl-1{padding-left:.25rem!important;padding-right:.25rem!important}.px-xxl-2{padding-left:.5rem!important;padding-right:.5rem!important}.px-xxl-3{padding-left:1rem!important;padding-right:1rem!important}.px-xxl-4{padding-left:1.5rem!important;padding-right:1.5rem!important}.px-xxl-5{padding-left:3rem!important;padding-right:3rem!important}.py-xxl-0{padding-bottom:0!important;padding-top:0!important}.py-xxl-1{padding-bottom:.25rem!important;padding-top:.25rem!important}.py-xxl-2{padding-bottom:.5rem!important;padding-top:.5rem!important}.py-xxl-3{padding-bottom:1rem!important;padding-top:1rem!important}.py-xxl-4{padding-bottom:1.5rem!important;padding-top:1.5rem!important}.py-xxl-5{padding-bottom:3rem!important;padding-top:3rem!important}.pt-xxl-0{padding-top:0!important}.pt-xxl-1{padding-top:.25rem!important}.pt-xxl-2{padding-top:.5rem!important}.pt-xxl-3{padding-top:1rem!important}.pt-xxl-4{padding-top:1.5rem!important}.pt-xxl-5{padding-top:3rem!important}.pe-xxl-0{padding-right:0!important}.pe-xxl-1{padding-right:.25rem!important}.pe-xxl-2{padding-right:.5rem!important}.pe-xxl-3{padding-right:1rem!important}.pe-xxl-4{padding-right:1.5rem!important}.pe-xxl-5{padding-right:3rem!important}.pb-xxl-0{padding-bottom:0!important}.pb-xxl-1{padding-bottom:.25rem!important}.pb-xxl-2{padding-bottom:.5rem!important}.pb-xxl-3{padding-bottom:1rem!important}.pb-xxl-4{padding-bottom:1.5rem!important}.pb-xxl-5{padding-bottom:3rem!important}.ps-xxl-0{padding-left:0!important}.ps-xxl-1{padding-left:.25rem!important}.ps-xxl-2{padding-left:.5rem!important}.ps-xxl-3{padding-left:1rem!important}.ps-xxl-4{padding-left:1.5rem!important}.ps-xxl-5{padding-left:3rem!important}.text-xxl-start{text-align:left!important}.text-xxl-end{text-align:right!important}.text-xxl-center{text-align:center!important}}@media (min-width:1200px){.fs-1{font-size:2.5rem!important}.fs-2{font-size:2rem!important}.fs-3{font-size:1.75rem!important}.fs-4{font-size:1.5rem!important}}@media print{.d-print-inline{display:inline!important}.d-print-inline-block{display:inline-block!important}.d-print-block{display:block!important}.d-print-grid{display:grid!important}.d-print-table{display:table!important}.d-print-table-row{display:table-row!important}.d-print-table-cell{display:table-cell!important}.d-print-flex{display:flex!important}.d-print-inline-flex{display:inline-flex!important}.d-print-none{display:none!important}} +/*# sourceMappingURL=main.266fc98c.css.map*/ \ No newline at end of file diff --git a/frontend/build/static/css/main.266fc98c.css.map b/frontend/build/static/css/main.266fc98c.css.map new file mode 100644 index 0000000..e3c7083 --- /dev/null +++ b/frontend/build/static/css/main.266fc98c.css.map @@ -0,0 +1 @@ +{"version":3,"file":"static/css/main.266fc98c.css","mappings":"AAoGE,gBC7FF,CCPA;;;;;ECAA,CCgDA,KAUE,uCAUF,CCOE,uFCtEA,cAIE,CCTJ,KAKE,kCAAmC,CACnC,iCAAkC,CAJlC,mIAKF,CAEA,KACE,uEAEF,CCZA,KACE,iBACF,CAEA,UACE,aAAc,CACd,mBACF,CAEA,8CACE,UACE,2CACF,CACF,CAEA,YAIE,kBAAmB,CAInB,wBAAyB,CADzB,UAAY,CALZ,YAAa,CACb,qBAAsB,CAGtB,4BAA6B,CAD7B,sBAAuB,CAJvB,gBAQF,CAEA,UACE,aACF,CAEA,yBACE,GACE,sBACF,CACA,GACE,uBACF,CACF,CAEA,kBAEI,WAAY,CADZ,KAEJ,CAEA,WACE,UAAW,CACX,oBACF,CAEA,UACI,gBAAiB,CACjB,iBACJ;ANpDA;;;;;EAAA,CCAA,MAQI,qPAIA,sMAIA,iKAIA,sNAGF,2BACA,qBACA,6BACA,6BAMA,yMACA,mGACA,sDAQA,gDACA,yBACA,0BACA,0BACA,wBAIA,iBMSF,CL5CA,iBAGE,qBK+CF,CLhCI,8CANJ,MAOM,sBKoCJ,CACF,CLvBA,KASE,6BAA8B,CAC9B,0CAFA,yDAFA,yCAJA,uNMmPI,cALI,CAKJ,kCALI,CN5OR,uDACA,uDAJA,QAAS,CAMT,oCK6BF,CLhBA,GAGE,6BAA8B,CAC9B,QAAS,CAFT,aO+kB4B,CPhlB5B,cAIA,WKmBF,CLhBA,eACE,UKmBF,CLTA,0CAKE,eOohB4B,CPnhB5B,eOohB4B,CPxhB5B,mBOohB4B,CPrhB5B,YKeF,CLNA,OMwMQ,gCD9LR,CC4BI,0BNtCJ,OM+MQ,gBDjMN,CACF,CLVA,OMmMQ,+BDrLR,CCmBI,0BNjCJ,OM0MQ,cDxLN,CACF,CLdA,OM8LQ,6BD5KR,CCUI,0BN5BJ,OMqMQ,iBD/KN,CACF,CLlBA,OMyLQ,+BDnKR,CCCI,0BNvBJ,OMgMQ,gBDtKN,CACF,CLtBA,OMgLM,iBDtJN,CLrBA,OM2KM,cDlJN,CLdA,EAEE,kBOkU0B,CPnU1B,YKkBF,CLNA,yCAGE,WAAY,CADZ,yEAAiC,CAEjC,mEKSF,CLHA,QAEE,iBAAkB,CAClB,mBAAoB,CAFpB,kBKQF,CLAA,MAEE,iBKGF,CLAA,SAIE,kBAAmB,CADnB,YKIF,CLAA,wBAIE,eKGF,CLAA,GACE,eKGF,CLEA,GACE,oBACA,aKCF,CLKA,WACE,eKFF,CLUA,SAEE,kBKPF,CLeA,aM4EM,gBDvFN,CLkBA,WAEE,wBOmc4B,CPpc5B,YKdF,CLwBA,QM0DM,eALI,CNjDR,aAAc,CAFd,iBAAkB,CAGlB,sBKrBF,CLwBA,IAAM,aKpBN,CLqBA,IAAM,SKjBN,CLsBA,EACE,aOpNQ,CPqNR,yBKnBF,CLqBE,QACE,aKnBJ,CL8BE,4DAEE,aAAc,CACd,oBK5BJ,CLmCA,kBAME,cAFA,sFO6S4B,CP7S5B,oCO6S4B,CD/RxB,aALI,CNNR,0BKhCF,CLuCA,IACE,aAAc,CMGV,gBALI,CNIR,kBAAmB,CADnB,YAAa,CAEb,aKnCF,CLwCE,SAEE,aAAc,CMPZ,iBALI,CNaN,iBKtCJ,CL0CA,KAGE,oBAAqB,CADrB,aO1QQ,CD4PJ,gBDxBN,CL0CE,OACE,aKxCJ,CL4CA,IAIE,wBO/SS,CCEP,oBR4SF,UOvTS,CD6RL,gBALI,CN6BR,mBKrCF,CL2CE,QM9BI,aALI,CNsCN,eO0Q0B,CP5Q1B,SKvCJ,CLkDA,OACE,eK/CF,CLqDA,QAEE,qBKlDF,CL0DA,MAEE,wBAAyB,CADzB,mBKtDF,CL0DA,QAGE,aO1VS,CPyVT,oBOuU4B,CPxU5B,iBOwU4B,CPrU5B,eKvDF,CL8DA,GAEE,kBAAmB,CACnB,+BK5DF,CL+DA,2BAQE,cAAe,CAFf,oBK1DF,CLoEA,MACE,oBKjEF,CLuEA,OAEE,eKrEF,CL6EA,iCACE,SK1EF,CL+EA,sCAME,mBAAoB,CM9HhB,iBALI,CNqIR,mBAAoB,CAHpB,QKzEF,CLgFA,cAEE,mBK7EF,CLkFA,cACE,cK/EF,CLkFA,OAGE,gBKjFF,CLoFE,gBACE,SKlFJ,CLyFA,0CACE,YKtFF,CL8FA,gDAIE,yBK3FF,CL8FI,4GACE,cKzFN,CLgGA,mBAEE,iBAAkB,CADlB,SK5FF,CLkGA,SACE,eK/FF,CLyGA,SAIE,QAAS,CADT,QAAS,CAFT,WAAY,CACZ,SKpGF,CL8GA,OACE,UAAW,CMhNL,gCNsNN,mBAAoB,CAHpB,mBO6J4B,CP9J5B,SAAU,CADV,UKvGF,CC5QI,0BNiXJ,OMxMQ,gBDuGN,CACF,CLyGE,SACE,UKvGJ,CL8GA,+OAOE,SK3GF,CL8GA,4BACE,WK3GF,CLoHA,cAEE,4BAA6B,CAD7B,mBKhHF,CLoIA,4BACE,uBKzHF,CL8HA,+BACE,SK3HF,CLiIA,uBACE,YK9HF,CLoIA,6BAEE,yBAA0B,CAD1B,YKhIF,CLsIA,OACE,oBKnIF,CLwIA,OACE,QKrIF,CL4IA,QAEE,cAAe,CADf,iBKxIF,CLiJA,SACE,sBK9IF,CLsJA,SACE,sBKnJF,CThcA,MUyQM,iBALI,CVlQR,eSmcF,CT9bE,WUsQM,iCVpQJ,eW0lBkB,CXzlBlB,eSicJ,CChWI,0BVpGF,WU6QM,cD2LN,CACF,CTzcE,WUsQM,iCVpQJ,eW0lBkB,CXzlBlB,eS4cJ,CC3WI,0BVpGF,WU6QM,gBDsMN,CACF,CTpdE,WUsQM,iCVpQJ,eW0lBkB,CXzlBlB,eSudJ,CCtXI,0BVpGF,WU6QM,cDiNN,CACF,CT/dE,WUsQM,iCVpQJ,eW0lBkB,CXzlBlB,eSkeJ,CCjYI,0BVpGF,WU6QM,gBD4NN,CACF,CT1eE,WUsQM,iCVpQJ,eW0lBkB,CXzlBlB,eS6eJ,CC5YI,0BVpGF,WU6QM,cDuON,CACF,CTrfE,WUsQM,iCVpQJ,eW0lBkB,CXzlBlB,eSwfJ,CCvZI,0BVpGF,WU6QM,gBDkPN,CACF,CTreA,4BazDE,eAAgB,CADhB,cJyiBF,CT5eA,kBACE,oBS+eF,CT7eE,mCACE,kBS+eJ,CTreA,YUsNM,gBALI,CV/MR,wBSweF,CTpeA,YUgNM,iBALI,CV1MR,kBSweF,CTreE,wBACE,eSueJ,CTneA,mBAIE,aWpFS,CDuRL,gBALI,CVhMR,kBWsRO,CXvRP,gBSyeF,CTpeE,0BACE,YSseJ,CR9jBA,0BaCE,WAAY,CAHZ,cL8kBF,CR5kBA,eAEE,qBUPS,CVQT,yBWGE,qBXLF,cQ2kBF,CR7jBA,QAEE,oBQ+jBF,CR5jBA,YAEE,aAAc,CADd,mBQgkBF,CR5jBA,gBAEE,aU1BS,CDuRL,gBDkUN,CMjmBE,mGCCA,gBAAiB,CADjB,iBAAkB,CADlB,2DADA,6DADA,UPknBF,CQtjBI,yBF5CE,yBACE,eNsmBN,CACF,CQ5jBI,yBF5CE,uCACE,eN2mBN,CACF,CQjkBI,yBF5CE,qDACE,eNgnBN,CACF,CQtkBI,0BF5CE,mEACE,gBNqnBN,CACF,CQ3kBI,0BF5CE,kFACE,gBN0nBN,CACF,CS1oBE,KCAA,qBACA,gBACA,YAAa,CACb,cAAe,CAIf,yCADA,0CADA,sCV8oBF,CShpBI,OCaF,aAAc,CAKd,8BAHA,cAAe,CAEf,yCADA,0CAFA,UV0oBF,CUvlBM,KACE,QV0lBR,CUvlBM,iBApCJ,aAAc,CACd,UV+nBF,CUjnBE,cACE,aAAc,CACd,UVonBJ,CUtnBE,cACE,aAAc,CACd,SVynBJ,CU3nBE,cACE,aAAc,CACd,oBV8nBJ,CUhoBE,cACE,aAAc,CACd,SVmoBJ,CUroBE,cACE,aAAc,CACd,SVwoBJ,CU1oBE,cACE,aAAc,CACd,oBV6oBJ,CU9mBM,UAhDJ,aAAc,CACd,UVkqBF,CU7mBU,OAhEN,aAAc,CACd,iBVirBJ,CUlnBU,OAhEN,aAAc,CACd,kBVsrBJ,CUvnBU,OAhEN,aAAc,CACd,SV2rBJ,CU5nBU,OAhEN,aAAc,CACd,kBVgsBJ,CUjoBU,OAhEN,aAAc,CACd,kBVqsBJ,CUtoBU,OAhEN,aAAc,CACd,SV0sBJ,CU3oBU,OAhEN,aAAc,CACd,kBV+sBJ,CUhpBU,OAhEN,aAAc,CACd,kBVotBJ,CUrpBU,OAhEN,aAAc,CACd,SVytBJ,CU1pBU,QAhEN,aAAc,CACd,kBV8tBJ,CU/pBU,QAhEN,aAAc,CACd,kBVmuBJ,CUpqBU,QAhEN,aAAc,CACd,UVwuBJ,CUjqBY,UAxDV,uBV6tBF,CUrqBY,UAxDV,wBViuBF,CUzqBY,UAxDV,eVquBF,CU7qBY,UAxDV,wBVyuBF,CUjrBY,UAxDV,wBV6uBF,CUrrBY,UAxDV,eVivBF,CUzrBY,UAxDV,wBVqvBF,CU7rBY,UAxDV,wBVyvBF,CUjsBY,UAxDV,eV6vBF,CUrsBY,WAxDV,wBViwBF,CUzsBY,WAxDV,wBVqwBF,CUlsBQ,WAEE,eVqsBV,CUlsBQ,WAEE,eVqsBV,CU5sBQ,WAEE,qBV+sBV,CU5sBQ,WAEE,qBV+sBV,CUttBQ,WAEE,oBVytBV,CUttBQ,WAEE,oBVytBV,CUhuBQ,WAEE,kBVmuBV,CUhuBQ,WAEE,kBVmuBV,CU1uBQ,WAEE,oBV6uBV,CU1uBQ,WAEE,oBV6uBV,CUpvBQ,WAEE,kBVuvBV,CUpvBQ,WAEE,kBVuvBV,CQjzBI,yBEUE,QACE,QV2yBN,CUxyBI,oBApCJ,aAAc,CACd,UVg1BA,CUl0BA,iBACE,aAAc,CACd,UVq0BF,CUv0BA,iBACE,aAAc,CACd,SV00BF,CU50BA,iBACE,aAAc,CACd,oBV+0BF,CUj1BA,iBACE,aAAc,CACd,SVo1BF,CUt1BA,iBACE,aAAc,CACd,SVy1BF,CU31BA,iBACE,aAAc,CACd,oBV81BF,CU/zBI,aAhDJ,aAAc,CACd,UVm3BA,CU9zBQ,UAhEN,aAAc,CACd,iBVk4BF,CUn0BQ,UAhEN,aAAc,CACd,kBVu4BF,CUx0BQ,UAhEN,aAAc,CACd,SV44BF,CU70BQ,UAhEN,aAAc,CACd,kBVi5BF,CUl1BQ,UAhEN,aAAc,CACd,kBVs5BF,CUv1BQ,UAhEN,aAAc,CACd,SV25BF,CU51BQ,UAhEN,aAAc,CACd,kBVg6BF,CUj2BQ,UAhEN,aAAc,CACd,kBVq6BF,CUt2BQ,UAhEN,aAAc,CACd,SV06BF,CU32BQ,WAhEN,aAAc,CACd,kBV+6BF,CUh3BQ,WAhEN,aAAc,CACd,kBVo7BF,CUr3BQ,WAhEN,aAAc,CACd,UVy7BF,CUl3BU,aAxDV,aV86BA,CUt3BU,aAxDV,uBVk7BA,CU13BU,aAxDV,wBVs7BA,CU93BU,aAxDV,eV07BA,CUl4BU,aAxDV,wBV87BA,CUt4BU,aAxDV,wBVk8BA,CU14BU,aAxDV,eVs8BA,CU94BU,aAxDV,wBV08BA,CUl5BU,aAxDV,wBV88BA,CUt5BU,aAxDV,eVk9BA,CU15BU,cAxDV,wBVs9BA,CU95BU,cAxDV,wBV09BA,CUv5BM,iBAEE,eV05BR,CUv5BM,iBAEE,eV05BR,CUj6BM,iBAEE,qBVo6BR,CUj6BM,iBAEE,qBVo6BR,CU36BM,iBAEE,oBV86BR,CU36BM,iBAEE,oBV86BR,CUr7BM,iBAEE,kBVw7BR,CUr7BM,iBAEE,kBVw7BR,CU/7BM,iBAEE,oBVk8BR,CU/7BM,iBAEE,oBVk8BR,CUz8BM,iBAEE,kBV48BR,CUz8BM,iBAEE,kBV48BR,CACF,CQvgCI,yBEUE,QACE,QVggCN,CU7/BI,oBApCJ,aAAc,CACd,UVqiCA,CUvhCA,iBACE,aAAc,CACd,UV0hCF,CU5hCA,iBACE,aAAc,CACd,SV+hCF,CUjiCA,iBACE,aAAc,CACd,oBVoiCF,CUtiCA,iBACE,aAAc,CACd,SVyiCF,CU3iCA,iBACE,aAAc,CACd,SV8iCF,CUhjCA,iBACE,aAAc,CACd,oBVmjCF,CUphCI,aAhDJ,aAAc,CACd,UVwkCA,CUnhCQ,UAhEN,aAAc,CACd,iBVulCF,CUxhCQ,UAhEN,aAAc,CACd,kBV4lCF,CU7hCQ,UAhEN,aAAc,CACd,SVimCF,CUliCQ,UAhEN,aAAc,CACd,kBVsmCF,CUviCQ,UAhEN,aAAc,CACd,kBV2mCF,CU5iCQ,UAhEN,aAAc,CACd,SVgnCF,CUjjCQ,UAhEN,aAAc,CACd,kBVqnCF,CUtjCQ,UAhEN,aAAc,CACd,kBV0nCF,CU3jCQ,UAhEN,aAAc,CACd,SV+nCF,CUhkCQ,WAhEN,aAAc,CACd,kBVooCF,CUrkCQ,WAhEN,aAAc,CACd,kBVyoCF,CU1kCQ,WAhEN,aAAc,CACd,UV8oCF,CUvkCU,aAxDV,aVmoCA,CU3kCU,aAxDV,uBVuoCA,CU/kCU,aAxDV,wBV2oCA,CUnlCU,aAxDV,eV+oCA,CUvlCU,aAxDV,wBVmpCA,CU3lCU,aAxDV,wBVupCA,CU/lCU,aAxDV,eV2pCA,CUnmCU,aAxDV,wBV+pCA,CUvmCU,aAxDV,wBVmqCA,CU3mCU,aAxDV,eVuqCA,CU/mCU,cAxDV,wBV2qCA,CUnnCU,cAxDV,wBV+qCA,CU5mCM,iBAEE,eV+mCR,CU5mCM,iBAEE,eV+mCR,CUtnCM,iBAEE,qBVynCR,CUtnCM,iBAEE,qBVynCR,CUhoCM,iBAEE,oBVmoCR,CUhoCM,iBAEE,oBVmoCR,CU1oCM,iBAEE,kBV6oCR,CU1oCM,iBAEE,kBV6oCR,CUppCM,iBAEE,oBVupCR,CUppCM,iBAEE,oBVupCR,CU9pCM,iBAEE,kBViqCR,CU9pCM,iBAEE,kBViqCR,CACF,CQ5tCI,yBEUE,QACE,QVqtCN,CUltCI,oBApCJ,aAAc,CACd,UV0vCA,CU5uCA,iBACE,aAAc,CACd,UV+uCF,CUjvCA,iBACE,aAAc,CACd,SVovCF,CUtvCA,iBACE,aAAc,CACd,oBVyvCF,CU3vCA,iBACE,aAAc,CACd,SV8vCF,CUhwCA,iBACE,aAAc,CACd,SVmwCF,CUrwCA,iBACE,aAAc,CACd,oBVwwCF,CUzuCI,aAhDJ,aAAc,CACd,UV6xCA,CUxuCQ,UAhEN,aAAc,CACd,iBV4yCF,CU7uCQ,UAhEN,aAAc,CACd,kBVizCF,CUlvCQ,UAhEN,aAAc,CACd,SVszCF,CUvvCQ,UAhEN,aAAc,CACd,kBV2zCF,CU5vCQ,UAhEN,aAAc,CACd,kBVg0CF,CUjwCQ,UAhEN,aAAc,CACd,SVq0CF,CUtwCQ,UAhEN,aAAc,CACd,kBV00CF,CU3wCQ,UAhEN,aAAc,CACd,kBV+0CF,CUhxCQ,UAhEN,aAAc,CACd,SVo1CF,CUrxCQ,WAhEN,aAAc,CACd,kBVy1CF,CU1xCQ,WAhEN,aAAc,CACd,kBV81CF,CU/xCQ,WAhEN,aAAc,CACd,UVm2CF,CU5xCU,aAxDV,aVw1CA,CUhyCU,aAxDV,uBV41CA,CUpyCU,aAxDV,wBVg2CA,CUxyCU,aAxDV,eVo2CA,CU5yCU,aAxDV,wBVw2CA,CUhzCU,aAxDV,wBV42CA,CUpzCU,aAxDV,eVg3CA,CUxzCU,aAxDV,wBVo3CA,CU5zCU,aAxDV,wBVw3CA,CUh0CU,aAxDV,eV43CA,CUp0CU,cAxDV,wBVg4CA,CUx0CU,cAxDV,wBVo4CA,CUj0CM,iBAEE,eVo0CR,CUj0CM,iBAEE,eVo0CR,CU30CM,iBAEE,qBV80CR,CU30CM,iBAEE,qBV80CR,CUr1CM,iBAEE,oBVw1CR,CUr1CM,iBAEE,oBVw1CR,CU/1CM,iBAEE,kBVk2CR,CU/1CM,iBAEE,kBVk2CR,CUz2CM,iBAEE,oBV42CR,CUz2CM,iBAEE,oBV42CR,CUn3CM,iBAEE,kBVs3CR,CUn3CM,iBAEE,kBVs3CR,CACF,CQj7CI,0BEUE,QACE,QV06CN,CUv6CI,oBApCJ,aAAc,CACd,UV+8CA,CUj8CA,iBACE,aAAc,CACd,UVo8CF,CUt8CA,iBACE,aAAc,CACd,SVy8CF,CU38CA,iBACE,aAAc,CACd,oBV88CF,CUh9CA,iBACE,aAAc,CACd,SVm9CF,CUr9CA,iBACE,aAAc,CACd,SVw9CF,CU19CA,iBACE,aAAc,CACd,oBV69CF,CU97CI,aAhDJ,aAAc,CACd,UVk/CA,CU77CQ,UAhEN,aAAc,CACd,iBVigDF,CUl8CQ,UAhEN,aAAc,CACd,kBVsgDF,CUv8CQ,UAhEN,aAAc,CACd,SV2gDF,CU58CQ,UAhEN,aAAc,CACd,kBVghDF,CUj9CQ,UAhEN,aAAc,CACd,kBVqhDF,CUt9CQ,UAhEN,aAAc,CACd,SV0hDF,CU39CQ,UAhEN,aAAc,CACd,kBV+hDF,CUh+CQ,UAhEN,aAAc,CACd,kBVoiDF,CUr+CQ,UAhEN,aAAc,CACd,SVyiDF,CU1+CQ,WAhEN,aAAc,CACd,kBV8iDF,CU/+CQ,WAhEN,aAAc,CACd,kBVmjDF,CUp/CQ,WAhEN,aAAc,CACd,UVwjDF,CUj/CU,aAxDV,aV6iDA,CUr/CU,aAxDV,uBVijDA,CUz/CU,aAxDV,wBVqjDA,CU7/CU,aAxDV,eVyjDA,CUjgDU,aAxDV,wBV6jDA,CUrgDU,aAxDV,wBVikDA,CUzgDU,aAxDV,eVqkDA,CU7gDU,aAxDV,wBVykDA,CUjhDU,aAxDV,wBV6kDA,CUrhDU,aAxDV,eVilDA,CUzhDU,cAxDV,wBVqlDA,CU7hDU,cAxDV,wBVylDA,CUthDM,iBAEE,eVyhDR,CUthDM,iBAEE,eVyhDR,CUhiDM,iBAEE,qBVmiDR,CUhiDM,iBAEE,qBVmiDR,CU1iDM,iBAEE,oBV6iDR,CU1iDM,iBAEE,oBV6iDR,CUpjDM,iBAEE,kBVujDR,CUpjDM,iBAEE,kBVujDR,CU9jDM,iBAEE,oBVikDR,CU9jDM,iBAEE,oBVikDR,CUxkDM,iBAEE,kBV2kDR,CUxkDM,iBAEE,kBV2kDR,CACF,CQtoDI,0BEUE,SACE,QV+nDN,CU5nDI,qBApCJ,aAAc,CACd,UVoqDA,CUtpDA,kBACE,aAAc,CACd,UVypDF,CU3pDA,kBACE,aAAc,CACd,SV8pDF,CUhqDA,kBACE,aAAc,CACd,oBVmqDF,CUrqDA,kBACE,aAAc,CACd,SVwqDF,CU1qDA,kBACE,aAAc,CACd,SV6qDF,CU/qDA,kBACE,aAAc,CACd,oBVkrDF,CUnpDI,cAhDJ,aAAc,CACd,UVusDA,CUlpDQ,WAhEN,aAAc,CACd,iBVstDF,CUvpDQ,WAhEN,aAAc,CACd,kBV2tDF,CU5pDQ,WAhEN,aAAc,CACd,SVguDF,CUjqDQ,WAhEN,aAAc,CACd,kBVquDF,CUtqDQ,WAhEN,aAAc,CACd,kBV0uDF,CU3qDQ,WAhEN,aAAc,CACd,SV+uDF,CUhrDQ,WAhEN,aAAc,CACd,kBVovDF,CUrrDQ,WAhEN,aAAc,CACd,kBVyvDF,CU1rDQ,WAhEN,aAAc,CACd,SV8vDF,CU/rDQ,YAhEN,aAAc,CACd,kBVmwDF,CUpsDQ,YAhEN,aAAc,CACd,kBVwwDF,CUzsDQ,YAhEN,aAAc,CACd,UV6wDF,CUtsDU,cAxDV,aVkwDA,CU1sDU,cAxDV,uBVswDA,CU9sDU,cAxDV,wBV0wDA,CUltDU,cAxDV,eV8wDA,CUttDU,cAxDV,wBVkxDA,CU1tDU,cAxDV,wBVsxDA,CU9tDU,cAxDV,eV0xDA,CUluDU,cAxDV,wBV8xDA,CUtuDU,cAxDV,wBVkyDA,CU1uDU,cAxDV,eVsyDA,CU9uDU,eAxDV,wBV0yDA,CUlvDU,eAxDV,wBV8yDA,CU3uDM,mBAEE,eV8uDR,CU3uDM,mBAEE,eV8uDR,CUrvDM,mBAEE,qBVwvDR,CUrvDM,mBAEE,qBVwvDR,CU/vDM,mBAEE,oBVkwDR,CU/vDM,mBAEE,oBVkwDR,CUzwDM,mBAEE,kBV4wDR,CUzwDM,mBAEE,kBV4wDR,CUnxDM,mBAEE,oBVsxDR,CUnxDM,mBAEE,oBVsxDR,CU7xDM,mBAEE,kBVgyDR,CU7xDM,mBAEE,kBVgyDR,CACF,CWt5DA,OACE,oBACA,2BACA,iCACA,gCACA,gCACA,+BACA,+BACA,qCAMA,oBTPS,CSKT,aTCS,CSFT,kBTuWO,CSrWP,kBTkqB4B,CSrqB5B,UX25DF,CWh5DE,yBAEE,oCACA,uBTye0B,CSxe1B,wDAHA,aXq5DJ,CW/4DE,aACE,sBXi5DJ,CW94DE,aACE,qBXg5DJ,CW54DE,0BACE,oBX84DJ,CWr4DA,aACE,gBXw4DF,CW93DE,4BACE,cXi4DJ,CWl3DE,gCACE,kBXq3DJ,CWl3DI,kCACE,kBXo3DN,CW72DE,oCACE,qBXg3DJ,CW72DE,qCACE,kBX+2DJ,CWt2DE,2CACE,gDACA,mCXy2DJ,CWj2DA,cACE,+CACA,kCXo2DF,CW51DE,8BACE,8CACA,iCX+1DJ,CY39DE,eAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZy9DJ,CYv+DE,iBAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZq+DJ,CYn/DE,eAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZi/DJ,CY//DE,YAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZ6/DJ,CY3gEE,eAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZygEJ,CYvhEE,cAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZqhEJ,CYniEE,aAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZiiEJ,CY/iEE,YAME,sBACA,8BACA,8BACA,6BACA,6BACA,4BACA,4BAGA,qBADA,UZ6iEJ,CWx6DI,kBAEE,gCAAiC,CADjC,eX46DN,CQt/DI,4BGyEA,qBAEE,gCAAiC,CADjC,eXk7DJ,CACF,CQ7/DI,4BGyEA,qBAEE,gCAAiC,CADjC,eXw7DJ,CACF,CQngEI,4BGyEA,qBAEE,gCAAiC,CADjC,eX87DJ,CACF,CQzgEI,6BGyEA,qBAEE,gCAAiC,CADjC,eXo8DJ,CACF,CQ/gEI,6BGyEA,sBAEE,gCAAiC,CADjC,eX08DJ,CACF,Ca7lEA,YACE,mBb+lEF,CatlEA,gBZuRM,iBALI,CY3QR,eXgkB4B,CWpkB5B,eAAgB,CADhB,mCADA,+Bb6lEF,CanlEA,mBZ4QM,iBALI,CYrQR,iCADA,6BbwlEF,CanlEA,mBZsQM,iBALI,CY/PR,kCADA,8BbwlEF,CcpnEA,WAKE,aZKS,CDuRL,gBALI,Ca3RR,iBdynEF,Ce1nEA,cAYE,uCAAgB,CAFhB,2BAA4B,CAD5B,qBbLS,CaOT,yBZIE,qBYPF,abKS,CaZT,aAAc,CdgSV,cALI,CctRR,ebqkB4B,CapkB5B,eb0kB4B,Ca9kB5B,uBCSI,oEDMJ,CAhBA,UfwoEF,CgB1nEM,uCDhBN,cCiBQ,ehB6nEN,CACF,Ce3nEE,yBACE,ef6nEJ,Ce3nEI,wDACE,cf6nEN,CexnEE,oBAEE,qBb3BO,Ca4BP,oBb8zBoC,CaxzBlC,iCbusB0B,Ca/sB5B,abjBO,CaoBP,Sf2nEJ,Ce/mEE,2CAEE,YfgnEJ,Ce5mEE,2BACE,ab1CO,Ca4CP,Sf6mEJ,CermEE,+CAEE,wBb1DO,Ca6DP,SfomEJ,CehmEE,oCEvEA,wBfMS,Ca0EP,cAAe,CAFf,oBAAqB,CAGrB,2Bbgb0B,Ca/a1B,eAAgB,CAPhB,ab9DO,Ca4DP,wBACA,wBb0pB0B,Ca5pB1B,uBAKA,mBAAoB,CCjElB,6HhByqEN,CgBrqEM,uCDuDJ,oCCtDM,ehBwqEN,CACF,CepmEE,yEACE,wBfsmEJ,CenmEE,0CE1FA,wBfMS,Ca6FP,cAAe,CAFf,oBAAqB,CAGrB,2Bb6Z0B,Ca5Z1B,eAAgB,CAPhB,abjFO,Ca+EP,wBACA,wBbuoB0B,CazoB1B,uBAKA,mBAAoB,CCpFlB,qID0FF,CC1FE,6HhB+rEN,CgB3rEM,uCD0EJ,0CCzEM,uChB8rEN,CACF,CevmEE,+EACE,wBfymEJ,CehmEA,wBAOE,wBAA6B,CAE7B,sCAHA,ab5GS,CauGT,aAAc,CAId,ebyd4B,Ca1d5B,eAAgB,CADhB,kBADA,Uf0mEF,CejmEE,gFAGE,cAAe,CADf,efmmEJ,CevlEA,iBZ7HI,oBFkRE,iBALI,Cc/IR,oCbguBsC,Ca/tBtC,oBf4lEF,CexlEE,uCAEE,sBACA,uBb2lB0B,Ca7lB1B,oBf4lEJ,CevlEE,6CAEE,sBACA,uBbqlB0B,CavlB1B,oBf2lEJ,CerlEA,iBZhJI,oBFkRE,iBALI,Cc5HR,mCb8sBsC,Ca7sBtC,kBf0lEF,CetlEE,uCAEE,oBACA,sBb4kB0B,Ca9kB1B,kBf0lEJ,CerlEE,6CAEE,oBACA,sBbskB0B,CaxkB1B,kBfylEJ,Ce/kEE,sBACE,qCfklEJ,Ce/kEE,yBACE,oCfilEJ,Ce9kEE,yBACE,mCfglEJ,Ce3kEA,oBAEE,WAAY,CACZ,eb4hB4B,Ca9hB5B,UfglEF,Ce5kEE,mDACE,cf8kEJ,Ce3kEE,uCZ9LE,qBY+LA,Yf8kEJ,Ce1kEE,0CZnME,qBYoMA,Yf6kEJ,CkB/xEA,aAKE,sCAeA,uCAAgB,CAThB,qBhBRS,CgBST,+PAEA,uChBg7BkC,CgBj7BlC,2BAA4B,CAE5B,yBhBg7BkC,CgB/6BlC,yBfFE,qBeJF,ahBES,CgBXT,aAAc,CjB+RV,cALI,CiBnRR,ehBkkB4B,CgBjkB5B,ehBukB4B,CgB7kB5B,uCFQI,oEEQJ,CAjBA,UlBizEF,CgBpyEM,uCEfN,aFgBQ,ehBuyEN,CACF,CkBlyEE,mBACE,oBhBs0BoC,CgBh0BlC,iChBi7B4B,CgBt7B9B,SlBqyEJ,CkB5xEE,0DAGE,qBAAsB,CADtB,oBlB8xEJ,CkB1xEE,sBAEE,wBlB2xEJ,CkBtxEE,4BACE,WAAkB,CAClB,yBlBwxEJ,CkBpxEA,gBftCI,oBFkRE,iBALI,CiBrOR,qBhBwrB4B,CgBvrB5B,kBhBwrB4B,CgB1rB5B,kBlB2xEF,CkBpxEA,gBf9CI,oBFkRE,iBALI,CiB7NR,oBhBorB4B,CgBnrB5B,iBhBorB4B,CgBtrB5B,iBlB2xEF,CmBz1EA,YACE,aAAc,CAGd,qBjBq3BwC,CiBv3BxC,iBjBq3BwC,CiBp3BxC,kBnB61EF,CmB11EE,8BACE,UAAW,CACX,kBnB41EJ,CmBx1EA,kBAWE,kBAAmB,CADnB,uCAAgB,CALhB,qBjBbS,CiBeT,uBAA2B,CAD3B,2BAA4B,CAE5B,uBAAwB,CACxB,0BjB42BwC,CiBn3BxC,UjBw2BwC,CiBv2BxC,iBAQA,iCAPA,kBAAmB,CAHnB,SnBq2EF,CmBx1EE,iChBXE,mBHs2EJ,CmBv1EE,8BAEE,iBnBw1EJ,CmBr1EE,yBACE,sBnBu1EJ,CmBp1EE,wBACE,oBjBszBoC,CiBpzBpC,iCjBmsB4B,CiBpsB5B,SnBu1EJ,CmBn1EE,0BACE,wBjBZM,CiBaN,oBnBq1EJ,CmBn1EI,yCAII,4PnBk1ER,CmB90EI,sCAII,oKnB60ER,CmBx0EE,+CACE,wBjBjCM,CiBuCJ,uPALF,oBnB20EJ,CmBl0EE,2BAEE,WAAY,CACZ,UjBk0BuC,CiBp0BvC,mBnBs0EJ,CmB7zEI,2FACE,UnB+zEN,CmBjzEA,aACE,kBnBozEF,CmBlzEE,+BAGE,kLACA,qBAAgC,ChB9FhC,kBgB4FA,mBH/FE,+CGmGF,CALA,SnByzEJ,CgBn5EM,uCGyFJ,+BHxFM,ehBs5EN,CACF,CmBvzEI,qCACE,uKnByzEN,CmBtzEI,uCAMI,qKALF,wBnByzEN,CmB9yEA,mBACE,oBAAqB,CACrB,iBnBizEF,CmB9yEA,WAEE,kBAAsB,CACtB,mBAAoB,CAFpB,iBnBmzEF,CmB7yEI,mDAEE,WAAY,CACZ,WjBqoBwB,CiBvoBxB,mBnBizEN,CoB77EA,YAKE,uCAAgB,CADhB,wBAA6B,CAF7B,cACA,SAAU,CAFV,UpBo8EF,CoB97EE,kBACE,SpBg8EJ,CoB57EI,wCAA0B,gDpB+7E9B,CoB97EI,oCAA0B,gDpBi8E9B,CoB97EE,8BACE,QpBg8EJ,CoB77EE,kCASE,uCAAgB,CH/BlB,wBfkCQ,CkBPN,QlB88BuC,CC19BvC,mBiBSA,WlB88BuC,CkB78BvC,mBJbE,8GIkBF,CJlBE,sGIkBF,CAPA,UpBs8EJ,CgB78EM,uCIMJ,kCJLM,uChBg9EN,CACF,CoBj8EI,yCHjCF,wBjBq+EF,CoB/7EE,2CAKE,wBlBpCO,CkBqCP,kBAAyB,CjB7BzB,mBiB0BA,WAAkB,CAClB,clBu7B8B,CkBz7B9B,YlBw7B8B,CkBz7B9B,UpBu8EJ,CoB77EE,8BAQE,eAAgB,CHzDlB,wBfkCQ,CkBmBN,QlBo7BuC,CC19BvC,mBiBoCA,WlBm7BuC,Cc19BrC,2GI4CF,CJ5CE,sGI4CF,CANA,UpBq8EJ,CgBv+EM,uCIiCJ,8BJhCM,oChB0+EN,CACF,CoBj8EI,qCH3DF,wBjB+/EF,CoB/7EE,8BAKE,wBlB9DO,CkB+DP,kBAAyB,CjBvDzB,mBiBoDA,WAAkB,CAClB,clB65B8B,CkB/5B9B,YlB85B8B,CkB/5B9B,UpBu8EJ,CoB77EE,qBACE,mBpB+7EJ,CoB77EI,2CACE,wBpB+7EN,CoB57EI,uCACE,wBpB87EN,CqBrhFA,eACE,iBrBwhFF,CqBthFE,yDAEE,yBnBy/B8B,CmBx/B9B,gBrBwhFJ,CqBrhFE,qBAOE,uBAHA,WAAY,CADZ,MAAO,CAEP,oBACA,mBAAoB,CALpB,iBAAkB,CAClB,KAAM,CAMN,oBAAqB,CLDnB,4DhByhFN,CgBrhFM,uCKXJ,qBLYM,ehBwhFN,CACF,CqBxhFE,6BACE,mBrB0hFJ,CqBxhFI,0CACE,WrB0hFN,CqBvhFI,wFAGE,sBnBm+B4B,CmBp+B5B,oBrByhFN,CqBrhFI,8CAEE,sBnB89B4B,CmB/9B5B,oBrBwhFN,CqBnhFE,4BAEE,sBnBw9B8B,CmBz9B9B,oBrBshFJ,CqB/gFI,sIACE,WnBk9B4B,CmBj9B5B,0DrBmhFN,CqB9gFI,oDACE,WnB28B4B,CmB18B5B,0DrBghFN,CsBtkFA,aAIE,mBAAoB,CAFpB,YAAa,CACb,cAAe,CAFf,iBAAkB,CAIlB,UtBykFF,CsBvkFE,qDAGE,aAAc,CAEd,WAAY,CAHZ,iBAAkB,CAElB,QtB0kFJ,CsBrkFE,iEAEE,StBukFJ,CsBjkFE,kBACE,iBAAkB,CAClB,StBmkFJ,CsBjkFI,wBACE,StBmkFN,CsBxjFA,kBAEE,kBAAmB,CAQnB,wBpB5CS,CoB6CT,yBnBpCE,qBmBgCF,apBlCS,CoB4BT,YAAa,CrBwPT,cALI,CqB/OR,epB8hB4B,CoB7hB5B,epBmiB4B,CoBtiB5B,uBAKA,iBAAkB,CAClB,kBtB8jFF,CsBljFA,kHnB9CI,oBFkRE,iBALI,CqB3NR,kBtBujFF,CsBljFA,kHnBvDI,oBFkRE,iBALI,CqBlNR,oBtBujFF,CsBljFA,0DAEE,kBtBqjFF,CsBjiFI,iUnBrEA,6BADA,yBHknFJ,CsBjiFE,0InBlEE,4BADA,yBmBoEA,gBtBqiFJ,CuBjoFE,gBAME,arB0/BqB,CqB//BrB,YAAa,CtB2QX,gBALI,CsBpQN,iBrByxBoC,CqB1xBpC,UvBuoFJ,CuBhoFE,eAWE,0BAvBiB,CpBHjB,qBoByBA,UAvBc,CAiBd,YAAa,CtB+PX,iBALI,CsBvPN,iBAFA,cAAe,CACf,qBALA,iBAAkB,CAClB,QAAS,CACT,SvB2oFJ,CuB9nFI,8HAEE,avBmoFN,CuBjrFI,0DAwDI,yQAEA,yDADA,2BAA4B,CAE5B,4DAPF,oBrB+9BmB,CqB59BjB,kCvBmoFR,CuB5nFM,sEACE,oBrBo9BiB,CqBn9BjB,iCvB8nFR,CuB9rFI,0EA0EI,8EADA,kCvB0nFR,CuBnsFI,wDAiFE,oBvBsnFN,CuBnnFQ,4NAGE,ufACA,6DACA,sEAHA,sBvBunFV,CuBhnFM,oEACE,oBrBq7BiB,CqBp7BjB,iCvBknFR,CuBjtFI,kEAsGE,oBvB+mFN,CuB7mFM,kFACE,wBvB+mFR,CuB5mFM,8EACE,iCvB8mFR,CuB3mFM,sGACE,avB6mFR,CuBxmFI,qDACE,gBvB2mFN,CuBluFI,sKA+HI,SvBymFR,CuBrmFM,8LACE,SvBymFR,CuB1tFE,kBAME,arB0/BqB,CqB//BrB,YAAa,CtB2QX,gBALI,CsBpQN,iBrByxBoC,CqB1xBpC,UvBguFJ,CuBztFE,iBAWE,0BAvBiB,CpBHjB,qBoByBA,UAvBc,CAiBd,YAAa,CtB+PX,iBALI,CsBvPN,iBAFA,cAAe,CACf,qBALA,iBAAkB,CAClB,QAAS,CACT,SvBouFJ,CuBvtFI,8IAEE,avB4tFN,CuB1wFI,8DAwDI,sUAEA,yDADA,2BAA4B,CAE5B,4DAPF,oBrB+9BmB,CqB59BjB,kCvB4tFR,CuBrtFM,0EACE,oBrBo9BiB,CqBn9BjB,iCvButFR,CuBvxFI,8EA0EI,8EADA,kCvBmtFR,CuB5xFI,4DAiFE,oBvB+sFN,CuB5sFQ,oOAGE,ojBACA,6DACA,sEAHA,sBvBgtFV,CuBzsFM,wEACE,oBrBq7BiB,CqBp7BjB,iCvB2sFR,CuB1yFI,sEAsGE,oBvBwsFN,CuBtsFM,sFACE,wBvBwsFR,CuBrsFM,kFACE,iCvBusFR,CuBpsFM,0GACE,avBssFR,CuBjsFI,uDACE,gBvBosFN,CuB3zFI,8KAiII,SvBgsFR,CuB9rFM,sMACE,SvBksFR,CwBx0FA,KAYE,wBAA6B,CAC7B,uBrBEE,qBqBVF,atBQS,CsBHT,eATA,oBAAqB,CvBgSjB,cALI,CuBzRR,etBwkB4B,CsBvkB5B,etB6kB4B,CuBtd5B,uBDrHA,iBAAkB,CAClB,qBRKI,6HQGJ,CAJA,yCAAiB,CAFjB,qBxBi1FF,CgB10FM,uCQhBN,KRiBQ,ehB60FN,CACF,CwB90FE,WACE,axBg1FJ,CwB50FE,iCAGE,iCtBotB4B,CsBrtB5B,SxB80FJ,CwB/zFE,mDAIE,WtB0uB0B,CsB3uB1B,mBxBg0FJ,CwBnzFE,aPvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzBg2FF,CyBr1FE,oER3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzBq2FJ,CyBh2FE,iDASI,iCzBu1FN,CyBn1FE,0IAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzBm1FJ,CyB70FI,wKAKI,iCzB20FR,CyBt0FE,4CAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzBy0FJ,CwBj1FE,ePvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzB83FF,CyBn3FE,0ER3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzBm4FJ,CyB93FE,qDASI,iCzBq3FN,CyBj3FE,oJAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzBi3FJ,CyB32FI,kLAKI,iCzBy2FR,CyBp2FE,gDAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzBu2FJ,CwB/2FE,aPvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzB45FF,CyBj5FE,oER3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzBi6FJ,CyB55FE,iDASI,iCzBm5FN,CyB/4FE,0IAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzB+4FJ,CyBz4FI,wKAKI,iCzBu4FR,CyBl4FE,4CAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzBq4FJ,CwB74FE,UPvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzB07FF,CyB/6FE,2DR3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzB+7FJ,CyB17FE,2CASI,iCzBi7FN,CyB76FE,2HAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzB66FJ,CyBv6FI,yJAKI,iCzBq6FR,CyBh6FE,sCAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzBm6FJ,CwB36FE,aPvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzBw9FF,CyB78FE,oER3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzB69FJ,CyBx9FE,iDASI,iCzB+8FN,CyB38FE,0IAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzB28FJ,CyBr8FI,wKAKI,iCzBm8FR,CyB97FE,4CAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzBi8FJ,CwBz8FE,YPvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzBs/FF,CyB3+FE,iER3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzB2/FJ,CyBt/FE,+CASI,iCzB6+FN,CyBz+FE,qIAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzBy+FJ,CyBn+FI,mKAKI,iCzBi+FR,CyB59FE,0CAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzB+9FJ,CwBv+FE,WPvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzBohGF,CyBzgGE,8DR3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzByhGJ,CyBphGE,6CASI,iCzB2gGN,CyBvgGE,gIAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzBugGJ,CyBjgGI,8JAKI,iCzB+/FR,CyB1/FE,wCAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzB6/FJ,CwBrgGE,UPvDA,wBf4Ea,CuB1Db,oBvB0Da,CuB5Db,UzBkjGF,CyBviGE,2DR3BA,wBQMmB,CAkBjB,oBAjBa,CAeb,UzBujGJ,CyBljGE,2CASI,iCzByiGN,CyBriGE,2HAME,wBArCkB,CAwClB,oBAvCc,CAmCd,UzBqiGJ,CyB/hGI,yJAKI,iCzB6hGR,CyBxhGE,sCAGE,wBvBYW,CuBTX,oBvBSW,CuBbX,UzB2hGJ,CwB7hGE,qBCoBA,oBvBLa,CuBIb,azB+gGF,CyB5gGE,2BAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzBghGJ,CyB3gGE,iEAEE,iCzB4gGJ,CyBzgGE,iLAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzBygGJ,CyBrgGI,+MAKI,iCzBmgGR,CyB9/FE,4DAGE,wBAA6B,CAD7B,azBggGJ,CwBtjGE,uBCoBA,oBvBLa,CuBIb,azBwiGF,CyBriGE,6BAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzByiGJ,CyBpiGE,qEAEE,iCzBqiGJ,CyBliGE,2LAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzBkiGJ,CyB9hGI,yNAKI,iCzB4hGR,CyBvhGE,gEAGE,wBAA6B,CAD7B,azByhGJ,CwB/kGE,qBCoBA,oBvBLa,CuBIb,azBikGF,CyB9jGE,2BAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzBkkGJ,CyB7jGE,iEAEE,iCzB8jGJ,CyB3jGE,iLAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzB2jGJ,CyBvjGI,+MAKI,iCzBqjGR,CyBhjGE,4DAGE,wBAA6B,CAD7B,azBkjGJ,CwBxmGE,kBCoBA,oBvBLa,CuBIb,azB0lGF,CyBvlGE,wBAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzB2lGJ,CyBtlGE,2DAEE,iCzBulGJ,CyBplGE,kKAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzBolGJ,CyBhlGI,gMAKI,iCzB8kGR,CyBzkGE,sDAGE,wBAA6B,CAD7B,azB2kGJ,CwBjoGE,qBCoBA,oBvBLa,CuBIb,azBmnGF,CyBhnGE,2BAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzBonGJ,CyB/mGE,iEAEE,iCzBgnGJ,CyB7mGE,iLAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzB6mGJ,CyBzmGI,+MAKI,iCzBumGR,CyBlmGE,4DAGE,wBAA6B,CAD7B,azBomGJ,CwB1pGE,oBCoBA,oBvBLa,CuBIb,azB4oGF,CyBzoGE,0BAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzB6oGJ,CyBxoGE,+DAEE,iCzByoGJ,CyBtoGE,4KAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzBsoGJ,CyBloGI,0MAKI,iCzBgoGR,CyB3nGE,0DAGE,wBAA6B,CAD7B,azB6nGJ,CwBnrGE,mBCoBA,oBvBLa,CuBIb,azBqqGF,CyBlqGE,yBAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzBsqGJ,CyBjqGE,6DAEE,iCzBkqGJ,CyB/pGE,uKAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzB+pGJ,CyB3pGI,qMAKI,iCzBypGR,CyBppGE,wDAGE,wBAA6B,CAD7B,azBspGJ,CwB5sGE,kBCoBA,oBvBLa,CuBIb,azB8rGF,CyB3rGE,wBAEE,wBvBTW,CuBUX,oBvBVW,CuBQX,UzB+rGJ,CyB1rGE,2DAEE,iCzB2rGJ,CyBxrGE,kKAME,wBvBxBW,CuByBX,oBvBzBW,CuBuBX,UzBwrGJ,CyBprGI,gMAKI,iCzBkrGR,CyB7qGE,sDAGE,wBAA6B,CAD7B,azB+qGJ,CwBztGA,UAEE,atBzCQ,CsBwCR,etBigB4B,CsB/f5B,yBxB4tGF,CwB1tGE,gBACE,axB4tGJ,CwBptGE,sCAEE,axBqtGJ,CwB1sGA,2BrBrFI,oBFkRE,iBALI,CwBjKR,kBzByrGF,CwB5sGA,2BrBzFI,oBFkRE,iBALI,CwBjKR,oBzB+rGF,C0B9zGA,MVgBM,8BhBkzGN,CgB9yGM,uCUpBN,MVqBQ,ehBizGN,CACF,C0Bp0GE,iBACE,S1Bs0GJ,C0Bh0GE,qBACE,Y1Bm0GJ,C0B/zGA,YACE,QAAS,CACT,eAAgB,CVDZ,2BhBo0GN,CgBh0GM,uCULN,YVMQ,ehBm0GN,CACF,C0Br0GE,gCAEE,WAAY,CVNV,0BUOF,CAFA,O1By0GJ,CgB10GM,uCUAJ,gCVCM,ehB60GN,CACF,C2Bl2GA,sCAIE,iB3Bq2GF,C2Bl2GA,iBACE,kB3Bq2GF,C4Bh1GI,uBA1BF,eAAgB,CAChB,6BAFA,8BADA,sBAgCI,UAAW,CAHX,oBAAqB,CACrB,kB1BqgBwB,C0BpgBxB,qB5Bu1GN,C4B9zGI,6BACE,a5Bg0GN,C2B32GA,eAYE,2BAA4B,CAD5B,qBzBnBS,CyBqBT,2BxBVE,qBwBKF,azBPS,CyBET,YAAa,C1BkRT,cALI,C0BtQR,eAAgB,CAJhB,QAAS,CAFT,ezB+mCkC,CyB9mClC,gBAJA,iBAAkB,CAQlB,eAAgB,CAPhB,Y3B03GF,C2B32GE,+BAEE,MAAO,CACP,kBzBkmCgC,CyBpmChC,Q3B+2GJ,C2Bj2GI,qBACE,mB3Bo2GN,C2Bl2GM,qCAEE,MAAO,CADP,U3Bq2GR,C2Bh2GI,mBACE,iB3Bm2GN,C2Bj2GM,mCAEE,SAAU,CADV,O3Bo2GR,CQl2GI,yBmBfA,wBACE,mB3Bq3GJ,C2Bn3GI,wCAEE,MAAO,CADP,U3Bs3GN,C2Bj3GE,sBACE,iB3Bo3GJ,C2Bl3GI,sCAEE,SAAU,CADV,O3Bq3GN,CACF,CQp3GI,yBmBfA,wBACE,mB3Bs4GJ,C2Bp4GI,wCAEE,MAAO,CADP,U3Bu4GN,C2Bl4GE,sBACE,iB3Bq4GJ,C2Bn4GI,sCAEE,SAAU,CADV,O3Bs4GN,CACF,CQr4GI,yBmBfA,wBACE,mB3Bu5GJ,C2Br5GI,wCAEE,MAAO,CADP,U3Bw5GN,C2Bn5GE,sBACE,iB3Bs5GJ,C2Bp5GI,sCAEE,SAAU,CADV,O3Bu5GN,CACF,CQt5GI,0BmBfA,wBACE,mB3Bw6GJ,C2Bt6GI,wCAEE,MAAO,CADP,U3By6GN,C2Bp6GE,sBACE,iB3Bu6GJ,C2Br6GI,sCAEE,SAAU,CADV,O3Bw6GN,CACF,CQv6GI,0BmBfA,yBACE,mB3By7GJ,C2Bv7GI,yCAEE,MAAO,CADP,U3B07GN,C2Br7GE,uBACE,iB3Bw7GJ,C2Bt7GI,uCAEE,SAAU,CADV,O3By7GN,CACF,C2B/6GE,uCAEE,WAAY,CAEZ,qBzB0jCgC,CyB3jChC,YAAa,CAFb,Q3Bo7GJ,C4B/9GI,+BAnBF,yBACA,6BAFA,8BADA,YAAa,CAyBT,UAAW,CAHX,oBAAqB,CACrB,kB1BqgBwB,C0BpgBxB,qB5Bs+GN,C4B78GI,qCACE,a5B+8GN,C2Br7GE,wCAGE,SAAU,CAEV,mBzB4iCgC,CyB7iChC,YAAa,CAFb,UAAW,CADX,K3B47GJ,C4Bp/GI,gCAZF,+BACA,uBAFA,cAAe,CADf,4BAkBI,UAAW,CAHX,oBAAqB,CACrB,kB1BqgBwB,C0BpgBxB,qB5B2/GN,C4Bl+GI,sCACE,a5Bo+GN,C2Bh8GI,gCACE,gB3Bk8GN,C2B57GE,0CAGE,SAAU,CAEV,oBzB2hCgC,CyB5hChC,YAAa,CAFb,UAAW,CADX,K3Bm8GJ,C4B5gHI,kCAIE,UAAW,CAHX,oBAAqB,CAenB,YAAa,CAdf,kB1BqgBwB,C0BpgBxB,qB5B+gHN,C4B//GM,mCAxBJ,+BADA,wBADA,4BA8BM,UAAW,CAHX,oBAAqB,CACrB,mB1BkfsB,C0BjftB,qB5BwgHR,C4BlgHI,wCACE,a5BogHN,C2B/8GI,mCACE,gB3Bi9GN,C2B18GA,kBAIE,+BAHA,QAAS,CACT,eACA,e3B88GF,C2Bv8GA,eAUE,wBAA6B,CAC7B,QAAS,CAPT,UAAW,CAEX,azBvHS,CyBkHT,aAAc,CAId,ezBwc4B,CyB1c5B,oBAIA,kBAAmB,CACnB,qBACA,kBAAmB,CAPnB,U3Bm9GF,C2B57GE,0CVvJA,wBfMS,CyBmJP,a3B87GJ,C2Bz7GE,4CV9JA,wBfkCQ,CyB8HN,UzB5JO,CyB6JP,oB3B27GJ,C2Bv7GE,gDAIE,wBAA6B,CAF7B,azB9JO,CyB+JP,mB3By7GJ,C2Bl7GA,oBACE,a3Bq7GF,C2Bj7GA,iBAKE,azB/KS,CyB2KT,aAAc,C1B4GV,iBALI,C0BrGR,eAAgB,CADhB,kBzBq+BkC,CyBj+BlC,kB3Bo7GF,C2Bh7GA,oBAGE,azBpLS,CyBkLT,aAAc,CACd,mB3Bo7GF,C2B/6GA,oBAEE,wBzB3LS,CyB4LT,sBzB87BkC,CyBh8BlC,a3Bo7GF,C2B/6GE,mCACE,a3Bi7GJ,C2B/6GI,kFV9MF,0BfsqCkC,CyBt9B9B,U3Bi7GN,C2B76GI,oFVpNF,wBfkCQ,CyBoLJ,U3B+6GN,C2B36GI,wFAEE,a3B46GN,C2Bx6GE,sCACE,sB3B06GJ,C2Bv6GE,wCACE,a3By6GJ,C2Bt6GE,qCACE,a3Bw6GJ,C6BppHA,+BAGE,mBAAoB,CADpB,iBAAkB,CAElB,qB7BupHF,C6BrpHE,yCAEE,aAAc,CADd,iB7BypHJ,C6BnpHE,kXAME,S7B2pHJ,C6BtpHA,aACE,YAAa,CACb,cAAe,CACf,0B7BypHF,C6BvpHE,0BACE,U7BypHJ,C6BnpHE,0EAEE,gB7BspHJ,C6BlpHE,mG1BPE,6BADA,yBH+pHJ,C6B9oHE,6G1BFE,4BADA,wBHupHJ,C6BjoHA,uBAEE,sBADA,sB7BqoHF,C6BloHE,wGAGE,a7BkoHJ,C6B/nHE,yCACE,c7BioHJ,C6B7nHA,yEAEE,qBADA,qB7BioHF,C6B7nHA,yEAEE,oBADA,oB7BioHF,C6B5mHA,oBAEE,sBAAuB,CADvB,qBAAsB,CAEtB,sB7B+mHF,C6B7mHE,wDAEE,U7B+mHJ,C6B5mHE,4FAEE,e7B8mHJ,C6B1mHE,qH1BtFE,4BADA,4BHssHJ,C6B1mHE,oF1B1GE,yBACA,yBHwtHJ,C8BhvHA,KACE,YAAa,CACb,cAAe,CAGf,eAAgB,CADhB,eAAgB,CADhB,c9BqvHF,C8BhvHA,UAKE,a5BoBQ,C4BxBR,aAAc,CACd,mBAIA,qBdHI,iGhBqvHN,CgBjvHM,uCcPN,UdQQ,ehBovHN,CACF,C8BpvHE,gCAEE,a9BqvHJ,C8BhvHE,mBACE,a5BhBO,C4BkBP,cAAe,CADf,mB9BmvHJ,C8B1uHA,UACE,+B9B6uHF,C8B3uHE,oBAEE,eAAgB,CAChB,uB3BlBA,8BACA,+B2BeA,kB9BivHJ,C8B5uHI,oDAEE,oC5BmhC8B,C4BjhC9B,iB9B4uHN,C8BzuHI,6BAEE,wBAA6B,CAC7B,kBAAyB,CAFzB,a9B6uHN,C8BvuHE,8DAGE,qB5B1DO,C4B2DP,iC5BsgCgC,C4BxgChC,a9B2uHJ,C8BtuHE,yB3B1CE,yBACA,0B2B2CA,e9ByuHJ,C8B7tHE,qBACE,eAAgB,CAChB,QAAS,C3BnET,oBHoyHJ,C8B7tHE,uDbtFA,wBfkCQ,C4BsDN,U9BguHJ,C8BrtHE,wCAEE,aAAc,CACd,iB9BwtHJ,C8BntHE,kDAEE,YAAa,CACb,WAAY,CACZ,iB9BstHJ,C8BhtHE,iEACE,U9BotHJ,C8B1sHE,uBACE,Y9B6sHJ,C8B3sHE,qBACE,a9B6sHJ,C+Br0HA,QAIE,kBAAmB,CAFnB,YAAa,CACb,cAAe,CAEf,6BAA8B,CAG9B,oB7B4jCkC,C6B9jClC,iB7B8jCkC,C6BnkClC,iB/B80HF,C+Bh0HE,2JAGE,kBAAmB,CAFnB,YAAa,CACb,iBAAkB,CAElB,6B/Bw0HJ,C+BpzHA,c9B8OM,iBALI,C8BtOR,iB7BoiCkC,C6BriClC,uB7BoiCkC,C6BriClC,oB7BqiCkC,C6BjiClC,qBACA,kB/BszHF,C+BzyHA,YACE,YAAa,CACb,qBAAsB,CAGtB,eAAgB,CADhB,eAAgB,CADhB,c/B6yHF,C+BzyHE,sBAEE,cAAe,CADf,e/B4yHJ,C+BxyHE,2BACE,e/B0yHJ,C+BjyHA,aAEE,oB7Bw9BkC,C6Bz9BlC,iB/BqyHF,C+BxxHA,iBAKE,kBAAmB,CAJnB,eAAgB,CAChB,W/B4xHF,C+BrxHA,gBAIE,wBAA6B,CAC7B,uB5BzGE,qBFkRE,iBALI,C8BtKR,aAAc,CAFd,sBfxGI,sChBs4HN,CgBl4HM,uCemGN,gBflGQ,ehBq4HN,CACF,C+B3xHE,sBACE,oB/B6xHJ,C+B1xHE,sBAGE,wBADA,SAAU,CADV,oB/B8xHJ,C+BtxHA,qBAME,uBAA2B,CAD3B,2BAA4B,CAE5B,oBAAqB,CANrB,oBAAqB,CAErB,YAAa,CACb,qBAAsB,CAFtB,W/B8xHF,C+BtxHA,mBACE,wDACA,e/ByxHF,CQn3HI,yBuBsGA,kBAEI,gBAAiB,CACjB,0B/BgxHN,C+B9wHM,8BACE,kB/BgxHR,C+B9wHQ,6CACE,iB/BgxHV,C+B7wHQ,wCAEE,kB7Bo6BwB,C6Br6BxB,mB/BgxHV,C+B3wHM,qCACE,gB/B6wHR,C+B1wHM,mCACE,sBAAwB,CACxB,e/B4wHR,C+BrwHM,sEACE,Y/B0wHR,C+BvwHM,6BAME,wBAA6B,CAE7B,aAAc,CADd,cAAe,CALf,QAAS,CAET,WAAY,CAHZ,gBAAiB,CASjB,cAAe,CflMnB,eeiMI,CAJA,4BAA8B,CAF9B,Y/BgxHR,C+BvwHM,qEAIE,eAAgB,CADhB,YAAa,CADb,W/B2wHR,C+BtwHM,kCACE,YAAa,CACb,WAAY,CAEZ,kBAAmB,CADnB,S/BywHR,CACF,CQz6HI,yBuBsGA,kBAEI,gBAAiB,CACjB,0B/Bq0HN,C+Bn0HM,8BACE,kB/Bq0HR,C+Bn0HQ,6CACE,iB/Bq0HV,C+Bl0HQ,wCAEE,kB7Bo6BwB,C6Br6BxB,mB/Bq0HV,C+Bh0HM,qCACE,gB/Bk0HR,C+B/zHM,mCACE,sBAAwB,CACxB,e/Bi0HR,C+B1zHM,sEACE,Y/B+zHR,C+B5zHM,6BAME,wBAA6B,CAE7B,aAAc,CADd,cAAe,CALf,QAAS,CAET,WAAY,CAHZ,gBAAiB,CASjB,cAAe,CflMnB,eeiMI,CAJA,4BAA8B,CAF9B,Y/Bq0HR,C+B5zHM,qEAIE,eAAgB,CADhB,YAAa,CADb,W/Bg0HR,C+B3zHM,kCACE,YAAa,CACb,WAAY,CAEZ,kBAAmB,CADnB,S/B8zHR,CACF,CQ99HI,yBuBsGA,kBAEI,gBAAiB,CACjB,0B/B03HN,C+Bx3HM,8BACE,kB/B03HR,C+Bx3HQ,6CACE,iB/B03HV,C+Bv3HQ,wCAEE,kB7Bo6BwB,C6Br6BxB,mB/B03HV,C+Br3HM,qCACE,gB/Bu3HR,C+Bp3HM,mCACE,sBAAwB,CACxB,e/Bs3HR,C+B/2HM,sEACE,Y/Bo3HR,C+Bj3HM,6BAME,wBAA6B,CAE7B,aAAc,CADd,cAAe,CALf,QAAS,CAET,WAAY,CAHZ,gBAAiB,CASjB,cAAe,CflMnB,eeiMI,CAJA,4BAA8B,CAF9B,Y/B03HR,C+Bj3HM,qEAIE,eAAgB,CADhB,YAAa,CADb,W/Bq3HR,C+Bh3HM,kCACE,YAAa,CACb,WAAY,CAEZ,kBAAmB,CADnB,S/Bm3HR,CACF,CQnhII,0BuBsGA,kBAEI,gBAAiB,CACjB,0B/B+6HN,C+B76HM,8BACE,kB/B+6HR,C+B76HQ,6CACE,iB/B+6HV,C+B56HQ,wCAEE,kB7Bo6BwB,C6Br6BxB,mB/B+6HV,C+B16HM,qCACE,gB/B46HR,C+Bz6HM,mCACE,sBAAwB,CACxB,e/B26HR,C+Bp6HM,sEACE,Y/By6HR,C+Bt6HM,6BAME,wBAA6B,CAE7B,aAAc,CADd,cAAe,CALf,QAAS,CAET,WAAY,CAHZ,gBAAiB,CASjB,cAAe,CflMnB,eeiMI,CAJA,4BAA8B,CAF9B,Y/B+6HR,C+Bt6HM,qEAIE,eAAgB,CADhB,YAAa,CADb,W/B06HR,C+Br6HM,kCACE,YAAa,CACb,WAAY,CAEZ,kBAAmB,CADnB,S/Bw6HR,CACF,CQxkII,0BuBsGA,mBAEI,gBAAiB,CACjB,0B/Bo+HN,C+Bl+HM,+BACE,kB/Bo+HR,C+Bl+HQ,8CACE,iB/Bo+HV,C+Bj+HQ,yCAEE,kB7Bo6BwB,C6Br6BxB,mB/Bo+HV,C+B/9HM,sCACE,gB/Bi+HR,C+B99HM,oCACE,sBAAwB,CACxB,e/Bg+HR,C+Bz9HM,wEACE,Y/B89HR,C+B39HM,8BAME,wBAA6B,CAE7B,aAAc,CADd,cAAe,CALf,QAAS,CAET,WAAY,CAHZ,gBAAiB,CASjB,cAAe,CflMnB,eeiMI,CAJA,4BAA8B,CAF9B,Y/Bo+HR,C+B39HM,uEAIE,eAAgB,CADhB,YAAa,CADb,W/B+9HR,C+B19HM,mCACE,YAAa,CACb,WAAY,CAEZ,kBAAmB,CADnB,S/B69HR,CACF,C+BvhII,eAEI,gBAAiB,CACjB,0B/BwhIR,C+BthIQ,2BACE,kB/BwhIV,C+BthIU,0CACE,iB/BwhIZ,C+BrhIU,qCAEE,kB7Bo6BwB,C6Br6BxB,mB/BwhIZ,C+BnhIQ,kCACE,gB/BqhIV,C+BlhIQ,gCACE,sBAAwB,CACxB,e/BohIV,C+B7gIQ,gEACE,Y/BkhIV,C+B/gIQ,0BAME,wBAA6B,CAE7B,aAAc,CADd,cAAe,CALf,QAAS,CAET,WAAY,CAHZ,gBAAiB,CASjB,cAAe,CflMnB,eeiMI,CAJA,4BAA8B,CAF9B,Y/BwhIV,C+B/gIQ,+DAIE,eAAgB,CADhB,YAAa,CADb,W/BmhIV,C+B9gIQ,+BACE,YAAa,CACb,WAAY,CAEZ,kBAAmB,CADnB,S/BihIV,C+B//HI,gGAEE,e/BogIN,C+B//HI,oCACE,e/BigIN,C+B//HM,oFAEE,e/BggIR,C+B7/HM,6CACE,e/B+/HR,C+B3/HI,qFAEE,e/B6/HN,C+Bz/HE,8BAEE,sB7By2BgC,C6B12BhC,e/B4/HJ,C+Bx/HE,mCACE,sQ/B0/HJ,C+Bv/HE,2BACE,e/By/HJ,C+Bv/HI,mGAGE,e/By/HN,C+B/+HI,6FAEE,U/Bo/HN,C+B/+HI,mCACE,e/Bi/HN,C+B/+HM,kFAEE,e/Bg/HR,C+B7+HM,4CACE,e/B++HR,C+B3+HI,mFAEE,U/B6+HN,C+Bz+HE,6BAEE,sB7B+yBgC,C6BhzBhC,e/B4+HJ,C+Bx+HE,kCACE,4Q/B0+HJ,C+Bv+HE,0BACE,e/By+HJ,C+Bx+HI,gGAGE,U/B0+HN,CgCjzIA,MAME,oBAAqB,CAErB,uBAA2B,CAD3B,qB9BHS,C8BKT,kC7BME,qB6BbF,YAAa,CACb,qBAAsB,CACtB,WAAY,CAHZ,iBhC4zIF,CgChzIE,SAEE,aAAc,CADd,chCmzIJ,CgC/yIE,kBAEE,qBAAsB,CADtB,kBhCkzIJ,CgC/yII,8B7BEA,0CACA,2C6BFE,kBhCmzIN,CgC/yII,6B7BYA,6CADA,8C6BVE,qBhCmzIN,CgC5yIE,8DAEE,YhC8yIJ,CgC1yIA,WAGE,aAAc,CACd,YhC2yIF,CgCvyIA,YACE,mBhC0yIF,CgCvyIA,eACE,kBhC2yIF,CgCvyIA,qCAHE,ehC8yIF,CgClyIE,sBACE,gBhCqyIJ,CgC7xIA,aAIE,0B9B2pCkC,C8B1pClC,yCAHA,eAAgB,CADhB,kBhCmyIF,CgC7xIE,yB7BpEE,uDHo2IJ,CgC3xIA,aAGE,0B9BgpCkC,C8B/oClC,sCAHA,kBhCgyIF,CgC3xIE,wB7B/EE,uDH62IJ,CgCpxIA,kBAIE,eAAgB,CAFhB,oBhCyxIF,CgC7wIA,qCAXE,mBAFA,mBhC+xIF,CgC5wIA,kB7B7GI,iC6BiHF,QAAS,CACT,MAAO,CACP,Y9BgPO,C8BrPP,iBAAkB,CAElB,OAAQ,CADR,KhCoxIF,CgC5wIA,yCAGE,UhC+wIF,CgC5wIA,wB7BpHI,0CACA,0CHq4IJ,CgC7wIA,2B7B1GI,6CADA,6CH83IJ,CgCtwIE,kBACE,oBhCywIJ,CQ72II,yBwBgGJ,YAQI,YAAa,CACb,kBhCywIF,CgCtwIE,kBAEE,QAAS,CACT,ehCuwIJ,CgCrwII,wBAEE,aAAc,CADd,ahCwwIN,CgClwIM,mC7BnJJ,6BADA,yBH05IF,CgCnwIQ,iGAGE,yBhCowIV,CgClwIQ,oGAGE,4BhCmwIV,CgC/vIM,oC7BpJJ,4BADA,wBHw5IF,CgChwIQ,mGAGE,wBhCiwIV,CgC/vIQ,sGAGE,2BhCgwIV,CACF,CiC98IA,kBAGE,kBAAmB,CAMnB,qB/BLS,C+BMT,QAAS,C9BKP,gB8BRF,a/BMS,C+BXT,YAAa,ChC+RT,cALI,CgChRR,oBAAqB,CAPrB,qBAJA,iBAAkB,CAOlB,eAAgB,CjBIZ,qJiBCJ,CATA,UjC09IF,CgB98IM,uCiBhBN,kBjBiBQ,ehBi9IN,CACF,CiCp9IE,kCAEE,wB/BuvCsC,C+BtvCtC,2CAFA,ajCw9IJ,CiCp9II,wCACE,+SACA,yBjCs9IN,CiCj9IE,wBAME,+SACA,2BAA4B,CAC5B,uB/B2uCsC,C+B9uCtC,UAAW,CAJX,aAAc,CAEd,c/BgvCsC,C+B/uCtC,gBAAiB,CjBnBf,oCiBwBF,CAPA,ajC09IJ,CgBv+IM,uCiBWJ,wBjBVM,ehB0+IN,CACF,CiCr9IE,wBACE,SjCu9IJ,CiCp9IE,wBAEE,oB/BizBoC,C+B/yBpC,iC/B8rB4B,C+B/rB5B,SAAU,CAFV,SjCy9IJ,CiCl9IA,kBACE,ejCq9IF,CiCl9IA,gBACE,qB/BpDS,C+BqDT,iCjCq9IF,CiCn9IE,8B9BnCE,8BACA,8BHy/IJ,CiCp9II,gD9BtCA,0CACA,0CH6/IJ,CiCn9IE,oCACE,YjCq9IJ,CiCj9IE,6B9BjCE,iCADA,iCHu/IJ,CiCj9IM,yD9BrCF,6CADA,6CH2/IJ,CiCh9II,iD9B1CA,iCADA,iCH+/IJ,CiC98IA,gBACE,oBjCi9IF,CiCx8IE,qCACE,cjC28IJ,CiCx8IE,iCAEE,aAAc,C9BxFd,gB8BuFA,cjC48IJ,CiCx8II,6CAAgB,YjC28IpB,CiC18II,4CAAe,ejC68InB,CiC38II,mD9B9FA,eH4iJJ,CkC/jJA,YACE,YAAa,CACb,cAAe,CAIf,eAAgB,CAFhB,kBhCw/CkC,CgCz/ClC,SlCokJF,CkC1jJE,kCACE,kBlC6jJJ,CkC3jJI,yCAGE,ahCLK,CgCML,qDAHA,UAAW,CACX,mBlC+jJN,CkCzjJE,wBACE,alC2jJJ,CmCplJA,YACE,YAAa,C/BIb,eAAgB,CADhB,cJslJF,CmCrlJA,WAKE,qBjCFS,CiCGT,yBAHA,ajC8BQ,CiC/BR,aAAc,CADd,iBAAkB,CAGlB,qBnBOI,6HhBolJN,CgBhlJM,uCmBfN,WnBgBQ,ehBmlJN,CACF,CmC3lJE,iBAKE,oBjCRO,CiCIP,SnCgmJJ,CmCzlJE,kCAJE,wBjCRO,CiCMP,anCsmJJ,CmChmJE,iBAKE,iCjCstB4B,CiCvtB5B,SjC4qCgC,CiC/qChC,SnC+lJJ,CmCtlJE,wCACE,gBnCylJJ,CmCtlJE,6BlBhCA,wBfkCQ,CiCEN,oBjCFM,CiCAN,UjC9BO,CiC6BP,SnC2lJJ,CmCrlJE,+BAGE,qBjCtCO,CiCuCP,oBjCpCO,CiCiCP,ajC9BO,CiC+BP,mBnCylJJ,CoCloJE,WACE,sBpCqoJJ,CoC9nJQ,kCjCsCJ,iCADA,6BH8lJJ,CoC7nJQ,iCjCkBJ,kCADA,8BHgnJJ,CoC/oJE,0BnCiSI,iBALI,CmC3RN,qBpCmpJJ,CoC5oJQ,iDjCsCJ,gCADA,4BH2mJJ,CoC1oJQ,gDjCkBJ,iCADA,6BH6nJJ,CoC5pJE,0BnCiSI,iBALI,CmC3RN,oBpCgqJJ,CoCzpJQ,iDjCsCJ,gCADA,4BHwnJJ,CoCvpJQ,gDjCkBJ,iCADA,6BH0oJJ,CqCxqJA,OlCcI,qBkCRF,UnCHS,CmCFT,oBAAqB,CpC+RjB,eALI,CoCvRR,enCukB4B,CmCtkB5B,aAAc,CAHd,oBAKA,iBAAkB,CAElB,sBAAwB,CADxB,kBrC6qJF,CqCvqJE,aACE,YrCyqJJ,CqCpqJA,YACE,iBAAkB,CAClB,QrCuqJF,CsC9rJA,OAIE,uBnCWE,qBmCZF,kBpCk6C8B,CoCn6C9B,aADA,iBtCqsJF,CsC7rJA,eAEE,atC+rJF,CsC3rJA,YACE,etC8rJF,CsCtrJA,mBACE,kBtCyrJF,CsCtrJE,8BAKE,qBAJA,iBAAkB,CAElB,OAAQ,CADR,KAAM,CAEN,StCyrJJ,CsCzqJE,erBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avCiuJF,CuC7tJE,2BACE,avC+tJJ,CsClrJE,iBrBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avC0uJF,CuCtuJE,6BACE,avCwuJJ,CsC3rJE,erBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avCmvJF,CuC/uJE,2BACE,avCivJJ,CsCpsJE,YrBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avC4vJF,CuCxvJE,wBACE,avC0vJJ,CsC7sJE,erBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avCqwJF,CuCjwJE,2BACE,avCmwJJ,CsCttJE,crBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avC8wJF,CuC1wJE,0BACE,avC4wJJ,CsC/tJE,arBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avCuxJF,CuCnxJE,yBACE,avCqxJJ,CsCxuJE,YrBhDA,wBqB0CmB,CC1CnB,oBD2Ce,CC7Cf,avCgyJF,CuC5xJE,wBACE,avC8xJJ,CwCjyJE,gCACE,GAAK,0BxCqyJP,CACF,CwCjyJA,UAKE,wBtCLS,CCSP,qBFkRE,gBALI,CuCpRR,WxCuyJF,CwC/xJA,wBATE,YAAa,CAEb,exCkzJF,CwC3yJA,cAQE,wBtCUQ,CsCbR,UtCjBS,CsCcT,qBAAsB,CACtB,sBAAuB,CAGvB,iBAAkB,CxBVd,yBwBaJ,CAFA,kBxCoyJF,CgB3yJM,uCwBAN,cxBCQ,ehB8yJN,CACF,CwCpyJA,sBvBYE,gHuBVA,yBxCuyJF,CwCnyJE,uBACE,iDxCsyJJ,CwCnyJM,uCAJJ,uBAKM,cxCsyJN,CACF,CyC90JA,YtCeI,qBsCdF,YAAa,CACb,qBAAsB,CAItB,eAAgB,CADhB,czCi1JF,CyC50JA,qBAEE,qBAAsB,CADtB,oBzCg1JF,CyC70JE,+BAEE,kCAAoC,CACpC,yBzC80JJ,CyCp0JA,wBAEE,avClBS,CuCmBT,kBAAmB,CAFnB,UzCy0JF,CyCp0JE,4DAKE,wBvCjCO,CuC+BP,avCzBO,CuC0BP,oBAAqB,CAFrB,SzCw0JJ,CyCl0JE,+BAEE,wBvCrCO,CuCoCP,azCq0JJ,CyC3zJA,iBAME,qBvCtDS,CuCuDT,kCAHA,avC3CS,CuCyCT,aAAc,CACd,mBAFA,iBAAkB,CAIlB,oBzCg0JF,CyC5zJE,6BtCrCE,+BACA,+BHo2JJ,CyC5zJE,4BtC1BE,kCADA,kCH21JJ,CyC5zJE,oDAIE,qBvCrEO,CuCmEP,avC7DO,CuC8DP,mBzC8zJJ,CyCzzJE,wBAGE,wBvC9CM,CuC+CN,oBvC/CM,CuC6CN,UvC3EO,CuC0EP,SzC8zJJ,CyCxzJE,kCACE,kBzC0zJJ,CyCxzJI,yCAEE,oBvCwawB,CuCzaxB,ezC2zJN,CyC5yJI,uBACE,kBzC+yJN,CyC5yJQ,oDtCrCJ,iCAZA,yBHi2JJ,CyC3yJQ,mDtC1CJ,4BAZA,8BHq2JJ,CyC1yJQ,+CACE,YzC4yJV,CyCzyJQ,yDAEE,mBAAoB,CADpB,oBzC4yJV,CyCzyJU,gEAEE,qBvCkYkB,CuCnYlB,gBzC4yJZ,CQ/2JI,yBiC4CA,0BACE,kBzCu0JJ,CyCp0JM,uDtCrCJ,iCAZA,yBHy3JF,CyCn0JM,sDtC1CJ,4BAZA,8BH63JF,CyCl0JM,kDACE,YzCo0JR,CyCj0JM,4DAEE,mBAAoB,CADpB,oBzCo0JR,CyCj0JQ,mEAEE,qBvCkYkB,CuCnYlB,gBzCo0JV,CACF,CQx4JI,yBiC4CA,0BACE,kBzC+1JJ,CyC51JM,uDtCrCJ,iCAZA,yBHi5JF,CyC31JM,sDtC1CJ,4BAZA,8BHq5JF,CyC11JM,kDACE,YzC41JR,CyCz1JM,4DAEE,mBAAoB,CADpB,oBzC41JR,CyCz1JQ,mEAEE,qBvCkYkB,CuCnYlB,gBzC41JV,CACF,CQh6JI,yBiC4CA,0BACE,kBzCu3JJ,CyCp3JM,uDtCrCJ,iCAZA,yBHy6JF,CyCn3JM,sDtC1CJ,4BAZA,8BH66JF,CyCl3JM,kDACE,YzCo3JR,CyCj3JM,4DAEE,mBAAoB,CADpB,oBzCo3JR,CyCj3JQ,mEAEE,qBvCkYkB,CuCnYlB,gBzCo3JV,CACF,CQx7JI,0BiC4CA,0BACE,kBzC+4JJ,CyC54JM,uDtCrCJ,iCAZA,yBHi8JF,CyC34JM,sDtC1CJ,4BAZA,8BHq8JF,CyC14JM,kDACE,YzC44JR,CyCz4JM,4DAEE,mBAAoB,CADpB,oBzC44JR,CyCz4JQ,mEAEE,qBvCkYkB,CuCnYlB,gBzC44JV,CACF,CQh9JI,0BiC4CA,2BACE,kBzCu6JJ,CyCp6JM,wDtCrCJ,iCAZA,yBHy9JF,CyCn6JM,uDtC1CJ,4BAZA,8BH69JF,CyCl6JM,mDACE,YzCo6JR,CyCj6JM,6DAEE,mBAAoB,CADpB,oBzCo6JR,CyCj6JQ,oEAEE,qBvCkYkB,CuCnYlB,gBzCo6JV,CACF,CyCt5JA,kBtC9HI,eHuhKJ,CyCt5JE,mCACE,oBzCw5JJ,CyCt5JI,8CACE,qBzCw5JN,C0C5iKE,yBAEE,wBD+JsB,CChKtB,a1CgjKJ,C0C5iKM,4GAGE,yBADA,a1C8iKR,C0C1iKM,uDAEE,wBDqJqB,CCpJrB,oBDoJqB,CCtJrB,U1C8iKR,C0C1jKE,2BAEE,wBD+JsB,CChKtB,a1C8jKJ,C0C1jKM,gHAGE,yBADA,a1C4jKR,C0CxjKM,yDAEE,wBDqJqB,CCpJrB,oBDoJqB,CCtJrB,U1C4jKR,C0CxkKE,yBAEE,wBD+JsB,CChKtB,a1C4kKJ,C0CxkKM,4GAGE,yBADA,a1C0kKR,C0CtkKM,uDAEE,wBDqJqB,CCpJrB,oBDoJqB,CCtJrB,U1C0kKR,C0CtlKE,sBAEE,wBD+JsB,CChKtB,a1C0lKJ,C0CtlKM,sGAGE,yBADA,a1CwlKR,C0CplKM,oDAEE,wBDuJuB,CCtJvB,oBDsJuB,CCxJvB,U1CwlKR,C0CpmKE,yBAEE,wBD+JsB,CChKtB,a1CwmKJ,C0CpmKM,4GAGE,yBADA,a1CsmKR,C0ClmKM,uDAEE,wBDuJuB,CCtJvB,oBDsJuB,CCxJvB,U1CsmKR,C0ClnKE,wBAEE,wBD+JsB,CChKtB,a1CsnKJ,C0ClnKM,0GAGE,yBADA,a1ConKR,C0ChnKM,sDAEE,wBDqJqB,CCpJrB,oBDoJqB,CCtJrB,U1ConKR,C0ChoKE,uBAEE,wBD+JsB,CChKtB,a1CooKJ,C0ChoKM,wGAGE,yBADA,a1CkoKR,C0C9nKM,qDAEE,wBDuJuB,CCtJvB,oBDsJuB,CCxJvB,U1CkoKR,C0C9oKE,sBAEE,wBD+JsB,CChKtB,a1CkpKJ,C0C9oKM,sGAGE,yBADA,a1CgpKR,C0C5oKM,oDAEE,wBDqJqB,CCpJrB,oBDoJqB,CCtJrB,U1CgpKR,C2C3pKA,WAME,0WACA,QAAS,CxCOP,qBwCbF,kBAAuB,CAIvB,UzCQS,CyCVT,UzCojD2B,CyC9iD3B,UzCqjD2B,CyC1jD3B,cAFA,S3CqqKF,C2C3pKE,iBACE,WAEA,WzCgjDyB,CyCjjDzB,oB3C8pKJ,C2C1pKE,iBAEE,iCzCwtB4B,CyCvtB5B,SzC2iDyB,CyC7iDzB,S3C8pKJ,C2CzpKE,wCAIE,WzCqiDyB,CyCviDzB,mBAAoB,CACpB,yC3C2pKJ,C2CtpKA,iBACE,iD3CypKF,C4C/rKA,OAOE,2BAA4B,CAD5B,0B1Cw1CkC,C0Ct1ClC,2BzCWE,qByCVF,iC1CghB4B,CDpPxB,iBALI,C2C9RR,cAAe,CAGf,mBAAoB,CAJpB,W5C0sKF,C4C/rKE,eACE,S5CisKJ,C4C9rKE,kBACE,Y5CgsKJ,C4C5rKA,iBAEE,cAAe,CACf,mBAAoB,CAFpB,iB5CisKF,C4C7rKE,mCACE,oB5C+rKJ,C4C3rKA,cAEE,kBAAmB,CAInB,2BAA4B,CAD5B,0B1Ck0CkC,C0Ch0ClC,kCzCVE,0CACA,2CyCMF,a1CrBS,C0CkBT,YAAa,CAEb,oB5CosKF,C4C7rKE,yBAEE,kB1C+yCgC,C0ChzChC,qB5CgsKJ,C4C3rKA,YAEE,oBAAqB,CADrB,c5C+rKF,C6CxuKA,OAKE,YAAa,CAEb,WAAY,CAJZ,MAAO,CASP,SAAU,CAJV,iBAAkB,CAClB,eAAgB,CARhB,cAAe,CACf,KAAM,CAIN,UAAW,CAFX,Y7CivKF,C6CluKA,cAGE,Y3Ci2CkC,C2C/1ClC,mBAAoB,CAJpB,iBAAkB,CAClB,U7CuuKF,C6CjuKE,0BAEE,2B3Cu3CgC,Cc34C9B,iChBuvKN,CgBnvKM,uC6BcJ,0B7BbM,ehBsvKN,CACF,C6CtuKE,0BACE,c7CwuKJ,C6CpuKE,kCACE,qB7CsuKJ,C6CluKA,yBACE,wB7CquKF,C6CnuKE,wCACE,eAAgB,CAChB,e7CquKJ,C6CluKE,qCACE,e7CouKJ,C6ChuKA,uBAEE,kBAAmB,CADnB,YAAa,CAEb,4B7CmuKF,C6C/tKA,eASE,2BAA4B,CAD5B,qB3CpES,C2CsET,uB1C3DE,oB0CmDF,YAAa,CACb,qBAAsB,CAWtB,SAAU,CAPV,mBAAoB,CANpB,iBAAkB,CAGlB,U7CwuKF,C6C1tKA,gBC9EE,qB5CUS,C4CXT,YAAa,CAHb,MAAO,CAFP,cAAe,CACf,KAAM,CAGN,WAAY,CADZ,Y9CqzKF,C8C/yKE,qBAAS,S9CkzKX,C8CjzKE,qBAAS,U9CozKX,C6CpuKA,cAGE,kBAAmB,CAGnB,gC1CtEE,yCACA,0C0CgEF,YAAa,CACb,aAAc,CAEd,6BAA8B,CAC9B,Y7C0uKF,C6CtuKE,yBAEE,iCADA,a7CyuKJ,C6CnuKA,aAEE,e3Cue4B,C2Cxe5B,e7CuuKF,C6CjuKA,YAIE,aAAc,CACd,Y3C8PO,C2ClQP,iB7CsuKF,C6C9tKA,cAIE,kBAAmB,C1CrFjB,4CADA,6C0CyFF,6BANA,YAAa,CAEb,aAAc,CADd,cAAe,CAGf,wBAAyB,CACzB,c7CouKF,C6C7tKE,gBACE,a7C+tKJ,CQ1yKI,yBqCkFF,cAEE,oBADA,e7C6tKF,C6CztKA,yBACE,0B7C4tKF,C6CztKA,uBACE,8B7C4tKF,C6CrtKA,UAAY,e7CytKZ,CACF,CQ7zKI,yBqCuGF,oBAEE,e7CytKF,CACF,CQn0KI,0BqC8GF,UAAY,gB7CytKZ,CACF,C6CjtKI,kBAGE,WAAY,CACZ,QAAS,CAFT,cAAe,CADf,W7CstKN,C6CjtKM,iCAEE,QAAS,C1C3Kb,gB0C0KI,W7CqtKR,C6ChtKM,gC1C/KF,eHk4KJ,C6C/sKM,8BACE,e7CitKR,C6C9sKM,gC1CvLF,eHw4KJ,CQ/0KI,4BqC0GA,0BAGE,WAAY,CACZ,QAAS,CAFT,cAAe,CADf,W7C4uKJ,C6CvuKI,yCAEE,QAAS,C1C3Kb,gB0C0KI,W7C2uKN,C6CtuKI,wC1C/KF,eHw5KF,C6CruKI,sCACE,e7CuuKN,C6CpuKI,wC1CvLF,eH85KF,CACF,CQt2KI,4BqC0GA,0BAGE,WAAY,CACZ,QAAS,CAFT,cAAe,CADf,W7CkwKJ,C6C7vKI,yCAEE,QAAS,C1C3Kb,gB0C0KI,W7CiwKN,C6C5vKI,wC1C/KF,eH86KF,C6C3vKI,sCACE,e7C6vKN,C6C1vKI,wC1CvLF,eHo7KF,CACF,CQ53KI,4BqC0GA,0BAGE,WAAY,CACZ,QAAS,CAFT,cAAe,CADf,W7CwxKJ,C6CnxKI,yCAEE,QAAS,C1C3Kb,gB0C0KI,W7CuxKN,C6ClxKI,wC1C/KF,eHo8KF,C6CjxKI,sCACE,e7CmxKN,C6ChxKI,wC1CvLF,eH08KF,CACF,CQl5KI,6BqC0GA,0BAGE,WAAY,CACZ,QAAS,CAFT,cAAe,CADf,W7C8yKJ,C6CzyKI,yCAEE,QAAS,C1C3Kb,gB0C0KI,W7C6yKN,C6CxyKI,wC1C/KF,eH09KF,C6CvyKI,sCACE,e7CyyKN,C6CtyKI,wC1CvLF,eHg+KF,CACF,CQx6KI,6BqC0GA,2BAGE,WAAY,CACZ,QAAS,CAFT,cAAe,CADf,W7Co0KJ,C6C/zKI,0CAEE,QAAS,C1C3Kb,gB0C0KI,W7Cm0KN,C6C9zKI,yC1C/KF,eHg/KF,C6C7zKI,uCACE,e7C+zKN,C6C5zKI,yC1CvLF,eHs/KF,CACF,C+CzgLA,SAUE,oBAAqB,CAPrB,aAAc,CCHd,+K9CkkB4B,C8ClkB5B,qC9CkkB4B,CD9RxB,iBALI,C+C7RR,iBAAkB,CAClB,e9C2kB4B,C8CpkB5B,qBAAsB,CAItB,eAAgB,CAVhB,e9CglB4B,C6ChlB5B,Q7CkyCkC,C6C3xClC,SAAU,CAVV,iBAAkB,CCIlB,eAAgB,CAChB,gBAAiB,CACjB,oBAAqB,CACrB,gBAAiB,CACjB,mBAAoB,CAIpB,kBAAmB,CAFnB,iBAAkB,CAClB,mBAAoB,CDVpB,Y/C8hLF,C+CnhLE,cAAS,U/CshLX,C+CphLE,wBAEE,aAAc,CAEd,Y7CsxCgC,C6CzxChC,iBAAkB,CAElB,W/CuhLJ,C+CphLI,+BAGE,kBAAyB,CACzB,kBAAmB,CAFnB,UAAW,CADX,iB/CyhLN,C+CjhLA,6DACE,e/CohLF,C+ClhLE,2FACE,Q/CohLJ,C+ClhLI,yGAGE,qB7CtBK,C6CqBL,2BADA,Q/CshLN,C+C/gLA,+DACE,e/CkhLF,C+ChhLE,6FAGE,Y7CsvCgC,C6CxvChC,MAAO,CACP,W/CmhLJ,C+ChhLI,2GAGE,uB7CtCK,C6CqCL,iCADA,U/CohLN,C+C7gLA,mEACE,e/CghLF,C+C9gLE,iGACE,K/CghLJ,C+C9gLI,+GAGE,wB7CpDK,C6CmDL,2BADA,W/CkhLN,C+C3gLA,gEACE,e/C8gLF,C+C5gLE,8FAGE,Y7CwtCgC,C6C1tChC,OAAQ,CACR,W/C+gLJ,C+C5gLI,4GAGE,sB7CpEK,C6CmEL,iCADA,S/CghLN,C+Cz/KA,eAKE,qB7C9FS,CCCP,qB4C2FF,U7CtGS,C6CoGT,e7CorCkC,C6CnrClC,qBAEA,iB/C8/KF,CiD7mLA,SAYE,oBAAqB,CAErB,2BAA4B,CAD5B,qB/CLS,C+COT,uB9CIE,oB8CdF,aAAc,CDJd,+K9CkkB4B,C8ClkB5B,qC9CkkB4B,CD9RxB,iBALI,C+C7RR,iBAAkB,CAClB,e9C2kB4B,C+C5kB5B,ODQA,qBAAsB,CAItB,eAAgB,CAVhB,e9CglB4B,C+C/kB5B,e/CwzCkC,C+C7zClC,iBAAkB,CDKlB,eAAgB,CAChB,gBAAiB,CACjB,oBAAqB,CACrB,gBAAiB,CACjB,mBAAoB,CCRpB,KAAM,CDYN,kBAAmB,CAFnB,iBAAkB,CAClB,mBAAoB,CCTpB,YjDsoLF,CiDvnLE,wBAEE,aAAc,CAEd,Y/CwzCgC,C+C3zChC,iBAAkB,CAElB,UjD0nLJ,CiDvnLI,6DAKE,kBAAyB,CACzB,kBAAmB,CAFnB,UAAW,CADX,aAAc,CADd,iBjD4nLN,CiDlnLE,2FACE,yBjDqnLJ,CiDnnLI,yGAGE,0B/CuyC8B,C+CxyC9B,2BADA,QjDunLN,CiDlnLI,uGAGE,qB/CzCK,C+CwCL,2BADA,UjDsnLN,CiD9mLE,6FAGE,W/CoxCgC,C+CtxChC,wBACA,WjDknLJ,CiD/mLI,2GAGE,4B/CmxC8B,C+CpxC9B,iCADA,MjDmnLN,CiD9mLI,yGAGE,uB/C7DK,C+C4DL,iCADA,QjDknLN,CiD1mLE,iGACE,sBjD6mLJ,CiD3mLI,+GAGE,6B/CiwC8B,C+ClwC9B,2BADA,KjD+mLN,CiD1mLI,6GAGE,wB/C/EK,C+C8EL,2BADA,OjD8mLN,CiDvmLE,iHAQE,gCADA,UAAW,CAHX,aAAc,CADd,QAAS,CAGT,mBALA,iBAAkB,CAClB,KAAM,CAGN,UjD4mLJ,CiDpmLE,8FAGE,W/CkuCgC,C+CpuChC,yBACA,WjDwmLJ,CiDrmLI,4GAGE,2B/CiuC8B,C+CluC9B,iCADA,OjDymLN,CiDpmLI,0GAGE,sB/C/GK,C+C8GL,iCADA,SjDwmLN,CiDjlLA,gBAKE,wB/CorCkC,C+CnrClC,8B9CtHE,yCACA,0CFwQE,cALI,CgDlJR,eAAgB,CADhB,kBjD0lLF,CiDllLE,sBACE,YjDolLJ,CiDhlLA,cAEE,a/C3IS,C+C0IT,YjDolLF,CkDluLA,UACE,iBlDquLF,CkDluLA,wBACE,kBlDquLF,CkDluLA,gBAGE,eAAgB,CAFhB,iBAAkB,CAClB,UlDsuLF,CmD3vLE,sBAEE,UAAW,CACX,UAAW,CAFX,anD+vLJ,CkDtuLA,eAME,0BAA2B,CAJ3B,YAAa,CACb,UAAW,CAEX,kBAAmB,CAJnB,iBAAkB,ClCbd,oCkCmBJ,CAHA,UlD4uLF,CgBxvLM,uCkCQN,elCPQ,ehB2vLN,CACF,CkD3uLA,8DAGE,alD8uLF,CkD1uLA,wEAEE,0BlD8uLF,CkD3uLA,wEAEE,2BlD8uLF,CkDnuLE,8BACE,SAAU,CAEV,cAAe,CADf,2BlDwuLJ,CkDpuLE,iJAIE,SAAU,CADV,SlDuuLJ,CkDnuLE,oFAGE,SAAU,ClC/DR,yBkCgEF,CAFA,SlDuuLJ,CgBjyLM,uCkCwDJ,oFlCvDM,ehBqyLN,CACF,CkDluLA,8CAQE,kBAAmB,CAMnB,eAAgB,CAChB,QAAS,CAXT,QAAS,CAQT,UhD7FS,CgDwFT,YAAa,CAEb,sBAAuB,CAOvB,UhDi6CmC,CgDt6CnC,SAAU,CATV,iBAAkB,CAWlB,iBAAkB,CAVlB,KAAM,ClC5EF,4BkC0FJ,CAPA,ShDs6CmC,CgD36CnC,SlDgvLF,CgB1zLM,uCkCqEN,8ClCpEQ,ehB8zLN,CACF,CkDvuLE,oHAEE,UhDvGO,CgD0GP,UhDy5CiC,CgD15CjC,SAAU,CADV,oBlD4uLJ,CkDvuLA,uBACE,MlD0uLF,CkDvuLA,uBACE,OlD0uLF,CkDruLA,wDAME,uBAAwB,CADxB,2BAA4B,CAE5B,yBAA0B,CAL1B,oBAAqB,CAErB,WhDy5CmC,CgD15CnC,UlD4uLF,CkD7tLA,4BACE,sRlDwuLF,CkDtuLA,4BACE,uRlDyuLF,CkDjuLA,qBAGE,QAAS,CAGT,YAAa,CACb,sBAAuB,CAHvB,MAAO,CASP,eAAgB,CAFhB,kBAAmB,CACnB,ehDg2CmC,CgDl2CnC,gBhDk2CmC,CgDp2CnC,SAAU,CAPV,iBAAkB,CAClB,OAAQ,CAGR,SlD2uLF,CkDjuLE,sCAWE,2BAA4B,CAD5B,qBhD9KO,CgDgLP,QAAS,CAGT,+BADA,4BAbA,kBAAuB,CAQvB,cAAe,CAPf,aAAc,CAEd,UhD+1CiC,CgD51CjC,ehD81CiC,CgD/1CjC,gBhD+1CiC,CgDr1CjC,UhDs1CiC,CgDj2CjC,SAAU,CAGV,kBAAmB,ClCpKjB,2BkC6KF,CAdA,UlDgvLJ,CgB34LM,uCkCwJJ,sClCvJM,ehB84LN,CACF,CkDpuLE,6BACE,SlDsuLJ,CkD7tLA,kBAGE,chD60CmC,CgDz0CnC,UhDzMS,CgDsMT,SAEA,sBhDy0CmC,CgD10CnC,mBhD00CmC,CgD90CnC,iBAAkB,CAClB,UAMA,iBlDguLF,CkD1tLE,sFAEE,+BlD6tLJ,CkD1tLE,qDACE,qBlD4tLJ,CkDztLE,iCACE,UlD2tLJ,CoDx7LA,0BACE,GAAK,uBpD47LL,CACF,CoDz7LA,gBASE,8CAHA,kBAA+B,CAE/B,iBAAkB,CAFlB,8BAA+B,CAL/B,oBAAqB,CAErB,WlDgiDwB,CkD/hDxB,sBlDiiDwB,CkDniDxB,UpDi8LF,CoDv7LA,mBAGE,iBlD4hDwB,CkD7hDxB,WlD2hDwB,CkD5hDxB,UpD47LF,CoDl7LA,wBACE,GACE,kBpDq7LF,CoDn7LA,IACE,SAAU,CACV,cpDq7LF,CACF,CoDj7LA,cASE,4CAJA,6BAA8B,CAE9B,iBAAkB,CANlB,oBAAqB,CAErB,WlD8/CwB,CkDz/CxB,SAAU,CAJV,sBlD+/CwB,CkDjgDxB,UpDy7LF,CoD/6LA,iBAEE,WlDy/CwB,CkD1/CxB,UpDm7LF,CoD96LE,uCACE,8BAEE,uBpDi7LJ,CACF,CJn/LA,WAUE,2BAA4B,CAD5B,qBMDS,CNNT,QAAS,CAET,YAAa,CACb,qBAAsB,CACtB,cAAe,CAKf,SAAU,CAVV,cAAe,CoBeX,oCpBHJ,CALA,iBAAkB,CALlB,YI6/LF,CgB5+LM,uCpBpBN,WoBqBQ,ehB++LN,CACF,CJr/LA,oBkDRE,qB5CUS,C4CXT,YAAa,CAHb,MAAO,CAFP,cAAe,CACf,KAAM,CAGN,WAAY,CADZ,Y9C0gMF,C8CpgME,yBAAS,S9CugMX,C8CtgME,yBAAS,U9CygMX,CJjgMA,kBAEE,kBAAmB,CADnB,YAAa,CAEb,6BAA8B,CAC9B,YIogMF,CJlgME,6BAIE,qBADA,oBADA,kBADA,aIugMJ,CJhgMA,iBAEE,eMijB4B,CNljB5B,eIogMF,CJhgMA,gBACE,WAAY,CAEZ,eAAgB,CADhB,YIogMF,CJhgMA,iBAIE,6BAFA,MAAO,CADP,KAAM,CAIN,2BAA4B,CAF5B,WIqgMF,CJhgMA,eAIE,4BAFA,OAAQ,CADR,KAAM,CAIN,0BAA2B,CAF3B,WIqgMF,CJhgMA,eAME,8BALA,KAAM,CAMN,2BImgMF,CJhgMA,iCANE,WMghDkC,CNjhDlC,MAAO,CAEP,eAAgB,CAHhB,OIihMF,CJzgMA,kBAKE,2BACA,0BImgMF,CJhgMA,gBACE,cImgMF,CHplMA,aAKE,6BAA8B,CAD9B,WAAY,CAHZ,oBAAqB,CACrB,cAAe,CAIf,UKwtCkC,CL3tClC,qBG0lMF,CHrlME,wBAEE,UAAW,CADX,oBGwlMJ,CHllMA,gBACE,eGqlMF,CHllMA,gBACE,eGqlMF,CHllMA,gBACE,gBGqlMF,CHhlME,+BACE,kDGmlMJ,CH/kMA,4BACE,IACE,UGklMF,CACF,CH/kMA,kBAGE,6CAA8C,CAF9C,sIACA,+CGklMF,CH9kMA,4BACE,GACE,mDGilMF,CACF,CmDhoME,gBAEE,UAAW,CACX,UAAW,CAFX,anDooMJ,CqDtoME,cACE,arDyoMJ,CqDtoMM,wCAEE,arDuoMR,CqD7oME,gBACE,arDgpMJ,CqD7oMM,4CAEE,arD8oMR,CqDppME,cACE,arDupMJ,CqDppMM,wCAEE,arDqpMR,CqD3pME,WACE,arD8pMJ,CqD3pMM,kCAEE,arD4pMR,CqDlqME,cACE,arDqqMJ,CqDlqMM,wCAEE,arDmqMR,CqDzqME,aACE,arD4qMJ,CqDzqMM,sCAEE,arD0qMR,CqDhrME,YACE,arDmrMJ,CqDhrMM,oCAEE,arDirMR,CqDvrME,WACE,arD0rMJ,CqDvrMM,kCAEE,arDwrMR,CsD7rMA,OACE,iBAAkB,CAClB,UtDgsMF,CsD9rME,cAGE,UAAW,CAFX,aAAc,CACd,kCtDisMJ,CsD7rME,SAKE,WAAY,CAFZ,MAAO,CAFP,iBAAkB,CAClB,KAAM,CAEN,UtDgsMJ,CsD1rME,WACE,sBtD6rMJ,CsD9rME,WACE,qBtDisMJ,CsDlsME,YACE,wBtDqsMJ,CsDtsME,YACE,gCtDysMJ,CuD9tMA,WAEE,KvDouMF,CuD9tMA,yBAJE,MAAO,CAHP,cAAe,CAEf,OAAQ,CAER,YvDyuMF,CuDtuMA,cAGE,QvDmuMF,CuDztMI,YACE,eAAgB,CAChB,KAAM,CACN,YvD4tMN,CQvrMI,yB+CxCA,eACE,eAAgB,CAChB,KAAM,CACN,YvDmuMJ,CACF,CQ/rMI,yB+CxCA,eACE,eAAgB,CAChB,KAAM,CACN,YvD0uMJ,CACF,CQtsMI,yB+CxCA,eACE,eAAgB,CAChB,KAAM,CACN,YvDivMJ,CACF,CQ7sMI,0B+CxCA,eACE,eAAgB,CAChB,KAAM,CACN,YvDwvMJ,CACF,CQptMI,0B+CxCA,gBACE,eAAgB,CAChB,KAAM,CACN,YvD+vMJ,CACF,CwDzxMA,QAGE,kBAAmB,CADnB,kBxD6xMF,CwDxxMA,gBAHE,kBAAmB,CAHnB,YxDqyMF,CwD/xMA,QAEE,aAAc,CACd,qBxD4xMF,CyDnyMA,2ECUE,4BAAiC,CAEjC,kBAAoB,CANpB,oBAAsB,CAEtB,qBAAuB,CACvB,yBAA2B,CAF3B,mBAAqB,CAHrB,2BAA6B,CAO7B,4BAA8B,CAN9B,mB1D2yMF,C2D/yME,sBAIE,QAAS,CAGT,UAAW,CAFX,MAAO,CAJP,iBAAkB,CAElB,OAAQ,CADR,KAAM,CAIN,S3DmzMJ,C4D1zMA,eCAE,eAAgB,CAChB,sBAAuB,CACvB,kB7D8zMF,C8Dp0MA,IAEE,kBAAmB,CAGnB,6BAA8B,CAJ9B,oBAAqB,CAGrB,cAAe,CAEf,W5DipB4B,C4DppB5B,S9D00MF,C+D9wMQ,gBAOI,gC/D2wMZ,C+DlxMQ,WAOI,4B/D+wMZ,C+DtxMQ,cAOI,+B/DmxMZ,C+D1xMQ,cAOI,+B/DuxMZ,C+D9xMQ,mBAOI,oC/D2xMZ,C+DlyMQ,gBAOI,iC/D+xMZ,C+DtyMQ,aAOI,oB/DmyMZ,C+D1yMQ,WAOI,qB/DuyMZ,C+D9yMQ,YAOI,oB/D2yMZ,C+DlzMQ,WAOI,mB/D+yMZ,C+DtzMQ,YAOI,qB/DmzMZ,C+D1zMQ,YAOI,oB/DuzMZ,C+D9zMQ,YAOI,qB/D2zMZ,C+Dl0MQ,aAOI,mB/D+zMZ,C+Dt0MQ,eAOI,uB/Dm0MZ,C+D10MQ,iBAOI,yB/Du0MZ,C+D90MQ,kBAOI,0B/D20MZ,C+Dl1MQ,iBAOI,yB/D+0MZ,C+Dt1MQ,UAOI,wB/Dm1MZ,C+D11MQ,gBAOI,8B/Du1MZ,C+D91MQ,SAOI,uB/D21MZ,C+Dl2MQ,QAOI,sB/D+1MZ,C+Dt2MQ,SAOI,uB/Dm2MZ,C+D12MQ,aAOI,2B/Du2MZ,C+D92MQ,cAOI,4B/D22MZ,C+Dl3MQ,QAOI,sB/D+2MZ,C+Dt3MQ,eAOI,6B/Dm3MZ,C+D13MQ,QAOI,sB/Du3MZ,C+D93MQ,QAOI,2C/D23MZ,C+Dl4MQ,WAOI,sD/D+3MZ,C+Dt4MQ,WAOI,iD/Dm4MZ,C+D14MQ,aAOI,yB/Du4MZ,C+D94MQ,iBAOI,yB/D24MZ,C+Dl5MQ,mBAOI,2B/D+4MZ,C+Dt5MQ,mBAOI,2B/Dm5MZ,C+D15MQ,gBAOI,wB/Du5MZ,C+D95MQ,iBAOI,yB/D25MZ,C+Dl6MQ,OAOI,e/D+5MZ,C+Dt6MQ,QAOI,iB/Dm6MZ,C+D16MQ,SAOI,kB/Du6MZ,C+D96MQ,UAOI,kB/D26MZ,C+Dl7MQ,WAOI,oB/D+6MZ,C+Dt7MQ,YAOI,qB/Dm7MZ,C+D17MQ,SAOI,gB/Du7MZ,C+D97MQ,UAOI,kB/D27MZ,C+Dl8MQ,WAOI,mB/D+7MZ,C+Dt8MQ,OAOI,iB/Dm8MZ,C+D18MQ,QAOI,mB/Du8MZ,C+D98MQ,SAOI,oB/D28MZ,C+Dl9MQ,kBAOI,wC/D+8MZ,C+Dt9MQ,oBAOI,oC/Dm9MZ,C+D19MQ,oBAOI,oC/Du9MZ,C+D99MQ,QAOI,kC/D29MZ,C+Dl+MQ,UAOI,kB/D+9MZ,C+Dt+MQ,YAOI,sC/Dm+MZ,C+D1+MQ,cAOI,sB/Du+MZ,C+D9+MQ,YAOI,wC/D2+MZ,C+Dl/MQ,cAOI,wB/D++MZ,C+Dt/MQ,eAOI,yC/Dm/MZ,C+D1/MQ,iBAOI,yB/Du/MZ,C+D9/MQ,cAOI,uC/D2/MZ,C+DlgNQ,gBAOI,uB/D+/MZ,C+DtgNQ,gBAOI,8B/DmgNZ,C+D1gNQ,kBAOI,8B/DugNZ,C+D9gNQ,gBAOI,8B/D2gNZ,C+DlhNQ,aAOI,8B/D+gNZ,C+DthNQ,gBAOI,8B/DmhNZ,C+D1hNQ,eAOI,8B/DuhNZ,C+D9hNQ,cAOI,8B/D2hNZ,C+DliNQ,aAOI,8B/D+hNZ,C+DtiNQ,cAOI,2B/DmiNZ,C+D1iNQ,UAOI,0B/DuiNZ,C+D9iNQ,UAOI,0B/D2iNZ,C+DljNQ,UAOI,0B/D+iNZ,C+DtjNQ,UAOI,0B/DmjNZ,C+D1jNQ,UAOI,0B/DujNZ,C+D9jNQ,MAOI,mB/D2jNZ,C+DlkNQ,MAOI,mB/D+jNZ,C+DtkNQ,MAOI,mB/DmkNZ,C+D1kNQ,OAOI,oB/DukNZ,C+D9kNQ,QAOI,oB/D2kNZ,C+DllNQ,QAOI,wB/D+kNZ,C+DtlNQ,QAOI,qB/DmlNZ,C+D1lNQ,YAOI,yB/DulNZ,C+D9lNQ,MAOI,oB/D2lNZ,C+DlmNQ,MAOI,oB/D+lNZ,C+DtmNQ,MAOI,oB/DmmNZ,C+D1mNQ,OAOI,qB/DumNZ,C+D9mNQ,QAOI,qB/D2mNZ,C+DlnNQ,QAOI,yB/D+mNZ,C+DtnNQ,QAOI,sB/DmnNZ,C+D1nNQ,YAOI,0B/DunNZ,C+D9nNQ,WAOI,uB/D2nNZ,C+DloNQ,UAOI,4B/D+nNZ,C+DtoNQ,aAOI,+B/DmoNZ,C+D1oNQ,kBAOI,oC/DuoNZ,C+D9oNQ,qBAOI,uC/D2oNZ,C+DlpNQ,aAOI,qB/D+oNZ,C+DtpNQ,aAOI,qB/DmpNZ,C+D1pNQ,eAOI,uB/DupNZ,C+D9pNQ,eAOI,uB/D2pNZ,C+DlqNQ,WAOI,wB/D+pNZ,C+DtqNQ,aAOI,0B/DmqNZ,C+D1qNQ,mBAOI,gC/DuqNZ,C+D9qNQ,OAOI,e/D2qNZ,C+DlrNQ,OAOI,oB/D+qNZ,C+DtrNQ,OAOI,mB/DmrNZ,C+D1rNQ,OAOI,kB/DurNZ,C+D9rNQ,OAOI,oB/D2rNZ,C+DlsNQ,OAOI,kB/D+rNZ,C+DtsNQ,uBAOI,oC/DmsNZ,C+D1sNQ,qBAOI,kC/DusNZ,C+D9sNQ,wBAOI,gC/D2sNZ,C+DltNQ,yBAOI,uC/D+sNZ,C+DttNQ,wBAOI,sC/DmtNZ,C+D1tNQ,wBAOI,sC/DutNZ,C+D9tNQ,mBAOI,gC/D2tNZ,C+DluNQ,iBAOI,8B/D+tNZ,C+DtuNQ,oBAOI,4B/DmuNZ,C+D1uNQ,sBAOI,8B/DuuNZ,C+D9uNQ,qBAOI,6B/D2uNZ,C+DlvNQ,qBAOI,kC/D+uNZ,C+DtvNQ,mBAOI,gC/DmvNZ,C+D1vNQ,sBAOI,8B/DuvNZ,C+D9vNQ,uBAOI,qC/D2vNZ,C+DlwNQ,sBAOI,oC/D+vNZ,C+DtwNQ,uBAOI,+B/DmwNZ,C+D1wNQ,iBAOI,yB/DuwNZ,C+D9wNQ,kBAOI,+B/D2wNZ,C+DlxNQ,gBAOI,6B/D+wNZ,C+DtxNQ,mBAOI,2B/DmxNZ,C+D1xNQ,qBAOI,6B/DuxNZ,C+D9xNQ,oBAOI,4B/D2xNZ,C+DlyNQ,aAOI,kB/D+xNZ,C+DtyNQ,SAOI,iB/DmyNZ,C+D1yNQ,SAOI,iB/DuyNZ,C+D9yNQ,SAOI,iB/D2yNZ,C+DlzNQ,SAOI,iB/D+yNZ,C+DtzNQ,SAOI,iB/DmzNZ,C+D1zNQ,SAOI,iB/DuzNZ,C+D9zNQ,YAOI,iB/D2zNZ,C+Dl0NQ,KAOI,kB/D+zNZ,C+Dt0NQ,KAOI,uB/Dm0NZ,C+D10NQ,KAOI,sB/Du0NZ,C+D90NQ,KAOI,qB/D20NZ,C+Dl1NQ,KAOI,uB/D+0NZ,C+Dt1NQ,KAOI,qB/Dm1NZ,C+D11NQ,QAOI,qB/Du1NZ,C+D91NQ,MAOI,gD/D41NZ,C+Dn2NQ,MAOI,0D/Di2NZ,C+Dx2NQ,MAOI,wD/Ds2NZ,C+D72NQ,MAOI,sD/D22NZ,C+Dl3NQ,MAOI,0D/Dg3NZ,C+Dv3NQ,MAOI,sD/Dq3NZ,C+D53NQ,SAOI,sD/D03NZ,C+Dj4NQ,MAOI,gD/D+3NZ,C+Dt4NQ,MAOI,0D/Do4NZ,C+D34NQ,MAOI,wD/Dy4NZ,C+Dh5NQ,MAOI,sD/D84NZ,C+Dr5NQ,MAOI,0D/Dm5NZ,C+D15NQ,MAOI,sD/Dw5NZ,C+D/5NQ,SAOI,sD/D65NZ,C+Dp6NQ,MAOI,sB/Di6NZ,C+Dx6NQ,MAOI,2B/Dq6NZ,C+D56NQ,MAOI,0B/Dy6NZ,C+Dh7NQ,MAOI,yB/D66NZ,C+Dp7NQ,MAOI,2B/Di7NZ,C+Dx7NQ,MAOI,yB/Dq7NZ,C+D57NQ,SAOI,yB/Dy7NZ,C+Dh8NQ,MAOI,wB/D67NZ,C+Dp8NQ,MAOI,6B/Di8NZ,C+Dx8NQ,MAOI,4B/Dq8NZ,C+D58NQ,MAOI,2B/Dy8NZ,C+Dh9NQ,MAOI,6B/D68NZ,C+Dp9NQ,MAOI,2B/Di9NZ,C+Dx9NQ,SAOI,2B/Dq9NZ,C+D59NQ,MAOI,yB/Dy9NZ,C+Dh+NQ,MAOI,8B/D69NZ,C+Dp+NQ,MAOI,6B/Di+NZ,C+Dx+NQ,MAOI,4B/Dq+NZ,C+D5+NQ,MAOI,8B/Dy+NZ,C+Dh/NQ,MAOI,4B/D6+NZ,C+Dp/NQ,SAOI,4B/Di/NZ,C+Dx/NQ,MAOI,uB/Dq/NZ,C+D5/NQ,MAOI,4B/Dy/NZ,C+DhgOQ,MAOI,2B/D6/NZ,C+DpgOQ,MAOI,0B/DigOZ,C+DxgOQ,MAOI,4B/DqgOZ,C+D5gOQ,MAOI,0B/DygOZ,C+DhhOQ,SAOI,0B/D6gOZ,C+DphOQ,KAOI,mB/DihOZ,C+DxhOQ,KAOI,wB/DqhOZ,C+D5hOQ,KAOI,uB/DyhOZ,C+DhiOQ,KAOI,sB/D6hOZ,C+DpiOQ,KAOI,wB/DiiOZ,C+DxiOQ,KAOI,sB/DqiOZ,C+D5iOQ,MAOI,kD/D0iOZ,C+DjjOQ,MAOI,4D/D+iOZ,C+DtjOQ,MAOI,0D/DojOZ,C+D3jOQ,MAOI,wD/DyjOZ,C+DhkOQ,MAOI,4D/D8jOZ,C+DrkOQ,MAOI,wD/DmkOZ,C+D1kOQ,MAOI,kD/DwkOZ,C+D/kOQ,MAOI,4D/D6kOZ,C+DplOQ,MAOI,0D/DklOZ,C+DzlOQ,MAOI,wD/DulOZ,C+D9lOQ,MAOI,4D/D4lOZ,C+DnmOQ,MAOI,wD/DimOZ,C+DxmOQ,MAOI,uB/DqmOZ,C+D5mOQ,MAOI,4B/DymOZ,C+DhnOQ,MAOI,2B/D6mOZ,C+DpnOQ,MAOI,0B/DinOZ,C+DxnOQ,MAOI,4B/DqnOZ,C+D5nOQ,MAOI,0B/DynOZ,C+DhoOQ,MAOI,yB/D6nOZ,C+DpoOQ,MAOI,8B/DioOZ,C+DxoOQ,MAOI,6B/DqoOZ,C+D5oOQ,MAOI,4B/DyoOZ,C+DhpOQ,MAOI,8B/D6oOZ,C+DppOQ,MAOI,4B/DipOZ,C+DxpOQ,MAOI,0B/DqpOZ,C+D5pOQ,MAOI,+B/DypOZ,C+DhqOQ,MAOI,8B/D6pOZ,C+DpqOQ,MAOI,6B/DiqOZ,C+DxqOQ,MAOI,+B/DqqOZ,C+D5qOQ,MAOI,6B/DyqOZ,C+DhrOQ,MAOI,wB/D6qOZ,C+DprOQ,MAOI,6B/DirOZ,C+DxrOQ,MAOI,4B/DqrOZ,C+D5rOQ,MAOI,2B/DyrOZ,C+DhsOQ,MAOI,6B/D6rOZ,C+DpsOQ,MAOI,2B/DisOZ,C+DxsOQ,gBAOI,+I/DqsOZ,C+D5sOQ,MAOI,0C/DysOZ,C+DhtOQ,MAOI,yC/D6sOZ,C+DptOQ,MAOI,uC/DitOZ,C+DxtOQ,MAOI,yC/DqtOZ,C+D5tOQ,MAOI,2B/DytOZ,C+DhuOQ,MAOI,wB/D6tOZ,C+DpuOQ,YAOI,2B/DiuOZ,C+DxuOQ,YAOI,2B/DquOZ,C+D5uOQ,UAOI,yB/DyuOZ,C+DhvOQ,YAOI,6B/D6uOZ,C+DpvOQ,WAOI,yB/DivOZ,C+DxvOQ,SAOI,yB/DqvOZ,C+D5vOQ,WAOI,4B/DyvOZ,C+DhwOQ,MAOI,uB/D6vOZ,C+DpwOQ,OAOI,0B/DiwOZ,C+DxwOQ,SAOI,yB/DqwOZ,C+D5wOQ,OAOI,uB/DywOZ,C+DhxOQ,YAOI,yB/D6wOZ,C+DpxOQ,UAOI,0B/DixOZ,C+DxxOQ,aAOI,2B/DqxOZ,C+D5xOQ,sBAOI,8B/DyxOZ,C+DhyOQ,2BAOI,mC/D6xOZ,C+DpyOQ,8BAOI,sC/DiyOZ,C+DxyOQ,gBAOI,kC/DqyOZ,C+D5yOQ,gBAOI,kC/DyyOZ,C+DhzOQ,iBAOI,mC/D6yOZ,C+DpzOQ,WAOI,4B/DizOZ,C+DxzOQ,aAOI,4B/DqzOZ,C+D5zOQ,YAOI,8D/D2zOZ,C+Dl0OQ,cAIQ,oBAGJ,0H/Di0OZ,C+Dx0OQ,gBAIQ,oBAGJ,6H/Ds0OZ,C+D70OQ,cAIQ,oBAGJ,yH/D20OZ,C+Dl1OQ,WAIQ,oBAGJ,uH/Dg1OZ,C+Dv1OQ,cAIQ,oBAGJ,yH/Dq1OZ,C+D51OQ,aAIQ,oBAGJ,wH/D01OZ,C+Dj2OQ,YAIQ,oBAGJ,yH/D+1OZ,C+Dt2OQ,WAIQ,oBAGJ,qH/Do2OZ,C+D32OQ,YAIQ,oBAGJ,mH/Dy2OZ,C+Dh3OQ,YAIQ,oBAGJ,yH/D82OZ,C+Dr3OQ,WAIQ,oBAGJ,2H/Dm3OZ,C+D13OQ,YAIQ,oBAGJ,uB/Dw3OZ,C+D/3OQ,eAIQ,oBAGJ,yB/D63OZ,C+Dp4OQ,eAIQ,oBAGJ,yB/Dk4OZ,C+Dz4OQ,YAIQ,oBAGJ,uB/Du4OZ,C+Dx5OQ,iBACE,sB/D25OV,C+D55OQ,iBACE,qB/D+5OV,C+Dh6OQ,iBACE,sB/Dm6OV,C+Dp6OQ,kBACE,mB/Du6OV,C+D95OQ,YAIQ,kBAGJ,4I/D45OZ,C+Dn6OQ,cAIQ,kBAGJ,+I/Di6OZ,C+Dx6OQ,YAIQ,kBAGJ,2I/Ds6OZ,C+D76OQ,SAIQ,kBAGJ,yI/D26OZ,C+Dl7OQ,YAIQ,kBAGJ,2I/Dg7OZ,C+Dv7OQ,WAIQ,kBAGJ,0I/Dq7OZ,C+D57OQ,UAIQ,kBAGJ,2I/D07OZ,C+Dj8OQ,SAIQ,kBAGJ,uI/D+7OZ,C+Dt8OQ,UAIQ,kBAGJ,qI/Do8OZ,C+D38OQ,UAIQ,kBAGJ,2I/Dy8OZ,C+Dh9OQ,SAIQ,kBAGJ,6I/D88OZ,C+Dr9OQ,gBAIQ,kBAGJ,kC/Dm9OZ,C+Dp+OQ,eACE,mB/Du+OV,C+Dx+OQ,eACE,oB/D2+OV,C+D5+OQ,eACE,mB/D++OV,C+Dh/OQ,eACE,oB/Dm/OV,C+Dp/OQ,gBACE,iB/Du/OV,C+D9+OQ,aAOI,gH/D2+OZ,C+Dl/OQ,iBAOI,2D/D++OZ,C+Dt/OQ,kBAOI,6D/Dm/OZ,C+D1/OQ,kBAOI,6D/Du/OZ,C+D9/OQ,SAOI,6B/D2/OZ,C+DlgPQ,SAOI,6B/D+/OZ,C+DtgPQ,SAOI,8B/DmgPZ,C+D1gPQ,WAOI,yB/DugPZ,C+D9gPQ,WAOI,6B/D2gPZ,C+DlhPQ,WAOI,8B/D+gPZ,C+DthPQ,WAOI,6B/DmhPZ,C+D1hPQ,gBAOI,2B/DuhPZ,C+D9hPQ,cAOI,6B/D2hPZ,C+DliPQ,aAOI,uC/DgiPZ,C+DviPQ,0BAOI,wC/DqiPZ,C+D5iPQ,6BAOI,2C/D0iPZ,C+DjjPQ,+BAOI,0C/D+iPZ,C+DtjPQ,eAOI,uC/D+iPZ,C+DtjPQ,SAOI,4B/DmjPZ,C+D1jPQ,WAOI,2B/DujPZ,CQ9jPI,yBuDAI,gBAOI,oB/D4jPV,C+DnkPM,cAOI,qB/DgkPV,C+DvkPM,eAOI,oB/DokPV,C+D3kPM,aAOI,wB/DwkPV,C+D/kPM,mBAOI,8B/D4kPV,C+DnlPM,YAOI,uB/DglPV,C+DvlPM,WAOI,sB/DolPV,C+D3lPM,YAOI,uB/DwlPV,C+D/lPM,gBAOI,2B/D4lPV,C+DnmPM,iBAOI,4B/DgmPV,C+DvmPM,WAOI,sB/DomPV,C+D3mPM,kBAOI,6B/DwmPV,C+D/mPM,WAOI,sB/D4mPV,C+DnnPM,cAOI,uB/DgnPV,C+DvnPM,aAOI,4B/DonPV,C+D3nPM,gBAOI,+B/DwnPV,C+D/nPM,qBAOI,oC/D4nPV,C+DnoPM,wBAOI,uC/DgoPV,C+DvoPM,gBAOI,qB/DooPV,C+D3oPM,gBAOI,qB/DwoPV,C+D/oPM,kBAOI,uB/D4oPV,C+DnpPM,kBAOI,uB/DgpPV,C+DvpPM,cAOI,wB/DopPV,C+D3pPM,gBAOI,0B/DwpPV,C+D/pPM,sBAOI,gC/D4pPV,C+DnqPM,UAOI,e/DgqPV,C+DvqPM,UAOI,oB/DoqPV,C+D3qPM,UAOI,mB/DwqPV,C+D/qPM,UAOI,kB/D4qPV,C+DnrPM,UAOI,oB/DgrPV,C+DvrPM,UAOI,kB/DorPV,C+D3rPM,0BAOI,oC/DwrPV,C+D/rPM,wBAOI,kC/D4rPV,C+DnsPM,2BAOI,gC/DgsPV,C+DvsPM,4BAOI,uC/DosPV,C+D3sPM,2BAOI,sC/DwsPV,C+D/sPM,2BAOI,sC/D4sPV,C+DntPM,sBAOI,gC/DgtPV,C+DvtPM,oBAOI,8B/DotPV,C+D3tPM,uBAOI,4B/DwtPV,C+D/tPM,yBAOI,8B/D4tPV,C+DnuPM,wBAOI,6B/DguPV,C+DvuPM,wBAOI,kC/DouPV,C+D3uPM,sBAOI,gC/DwuPV,C+D/uPM,yBAOI,8B/D4uPV,C+DnvPM,0BAOI,qC/DgvPV,C+DvvPM,yBAOI,oC/DovPV,C+D3vPM,0BAOI,+B/DwvPV,C+D/vPM,oBAOI,yB/D4vPV,C+DnwPM,qBAOI,+B/DgwPV,C+DvwPM,mBAOI,6B/DowPV,C+D3wPM,sBAOI,2B/DwwPV,C+D/wPM,wBAOI,6B/D4wPV,C+DnxPM,uBAOI,4B/DgxPV,C+DvxPM,gBAOI,kB/DoxPV,C+D3xPM,YAOI,iB/DwxPV,C+D/xPM,YAOI,iB/D4xPV,C+DnyPM,YAOI,iB/DgyPV,C+DvyPM,YAOI,iB/DoyPV,C+D3yPM,YAOI,iB/DwyPV,C+D/yPM,YAOI,iB/D4yPV,C+DnzPM,eAOI,iB/DgzPV,C+DvzPM,QAOI,kB/DozPV,C+D3zPM,QAOI,uB/DwzPV,C+D/zPM,QAOI,sB/D4zPV,C+Dn0PM,QAOI,qB/Dg0PV,C+Dv0PM,QAOI,uB/Do0PV,C+D30PM,QAOI,qB/Dw0PV,C+D/0PM,WAOI,qB/D40PV,C+Dn1PM,SAOI,gD/Di1PV,C+Dx1PM,SAOI,0D/Ds1PV,C+D71PM,SAOI,wD/D21PV,C+Dl2PM,SAOI,sD/Dg2PV,C+Dv2PM,SAOI,0D/Dq2PV,C+D52PM,SAOI,sD/D02PV,C+Dj3PM,YAOI,sD/D+2PV,C+Dt3PM,SAOI,gD/Do3PV,C+D33PM,SAOI,0D/Dy3PV,C+Dh4PM,SAOI,wD/D83PV,C+Dr4PM,SAOI,sD/Dm4PV,C+D14PM,SAOI,0D/Dw4PV,C+D/4PM,SAOI,sD/D64PV,C+Dp5PM,YAOI,sD/Dk5PV,C+Dz5PM,SAOI,sB/Ds5PV,C+D75PM,SAOI,2B/D05PV,C+Dj6PM,SAOI,0B/D85PV,C+Dr6PM,SAOI,yB/Dk6PV,C+Dz6PM,SAOI,2B/Ds6PV,C+D76PM,SAOI,yB/D06PV,C+Dj7PM,YAOI,yB/D86PV,C+Dr7PM,SAOI,wB/Dk7PV,C+Dz7PM,SAOI,6B/Ds7PV,C+D77PM,SAOI,4B/D07PV,C+Dj8PM,SAOI,2B/D87PV,C+Dr8PM,SAOI,6B/Dk8PV,C+Dz8PM,SAOI,2B/Ds8PV,C+D78PM,YAOI,2B/D08PV,C+Dj9PM,SAOI,yB/D88PV,C+Dr9PM,SAOI,8B/Dk9PV,C+Dz9PM,SAOI,6B/Ds9PV,C+D79PM,SAOI,4B/D09PV,C+Dj+PM,SAOI,8B/D89PV,C+Dr+PM,SAOI,4B/Dk+PV,C+Dz+PM,YAOI,4B/Ds+PV,C+D7+PM,SAOI,uB/D0+PV,C+Dj/PM,SAOI,4B/D8+PV,C+Dr/PM,SAOI,2B/Dk/PV,C+Dz/PM,SAOI,0B/Ds/PV,C+D7/PM,SAOI,4B/D0/PV,C+DjgQM,SAOI,0B/D8/PV,C+DrgQM,YAOI,0B/DkgQV,C+DzgQM,QAOI,mB/DsgQV,C+D7gQM,QAOI,wB/D0gQV,C+DjhQM,QAOI,uB/D8gQV,C+DrhQM,QAOI,sB/DkhQV,C+DzhQM,QAOI,wB/DshQV,C+D7hQM,QAOI,sB/D0hQV,C+DjiQM,SAOI,kD/D+hQV,C+DtiQM,SAOI,4D/DoiQV,C+D3iQM,SAOI,0D/DyiQV,C+DhjQM,SAOI,wD/D8iQV,C+DrjQM,SAOI,4D/DmjQV,C+D1jQM,SAOI,wD/DwjQV,C+D/jQM,SAOI,kD/D6jQV,C+DpkQM,SAOI,4D/DkkQV,C+DzkQM,SAOI,0D/DukQV,C+D9kQM,SAOI,wD/D4kQV,C+DnlQM,SAOI,4D/DilQV,C+DxlQM,SAOI,wD/DslQV,C+D7lQM,SAOI,uB/D0lQV,C+DjmQM,SAOI,4B/D8lQV,C+DrmQM,SAOI,2B/DkmQV,C+DzmQM,SAOI,0B/DsmQV,C+D7mQM,SAOI,4B/D0mQV,C+DjnQM,SAOI,0B/D8mQV,C+DrnQM,SAOI,yB/DknQV,C+DznQM,SAOI,8B/DsnQV,C+D7nQM,SAOI,6B/D0nQV,C+DjoQM,SAOI,4B/D8nQV,C+DroQM,SAOI,8B/DkoQV,C+DzoQM,SAOI,4B/DsoQV,C+D7oQM,SAOI,0B/D0oQV,C+DjpQM,SAOI,+B/D8oQV,C+DrpQM,SAOI,8B/DkpQV,C+DzpQM,SAOI,6B/DspQV,C+D7pQM,SAOI,+B/D0pQV,C+DjqQM,SAOI,6B/D8pQV,C+DrqQM,SAOI,wB/DkqQV,C+DzqQM,SAOI,6B/DsqQV,C+D7qQM,SAOI,4B/D0qQV,C+DjrQM,SAOI,2B/D8qQV,C+DrrQM,SAOI,6B/DkrQV,C+DzrQM,SAOI,2B/DsrQV,C+D7rQM,eAOI,yB/D0rQV,C+DjsQM,aAOI,0B/D8rQV,C+DrsQM,gBAOI,2B/DksQV,CACF,CQ1sQI,yBuDAI,gBAOI,oB/DusQV,C+D9sQM,cAOI,qB/D2sQV,C+DltQM,eAOI,oB/D+sQV,C+DttQM,aAOI,wB/DmtQV,C+D1tQM,mBAOI,8B/DutQV,C+D9tQM,YAOI,uB/D2tQV,C+DluQM,WAOI,sB/D+tQV,C+DtuQM,YAOI,uB/DmuQV,C+D1uQM,gBAOI,2B/DuuQV,C+D9uQM,iBAOI,4B/D2uQV,C+DlvQM,WAOI,sB/D+uQV,C+DtvQM,kBAOI,6B/DmvQV,C+D1vQM,WAOI,sB/DuvQV,C+D9vQM,cAOI,uB/D2vQV,C+DlwQM,aAOI,4B/D+vQV,C+DtwQM,gBAOI,+B/DmwQV,C+D1wQM,qBAOI,oC/DuwQV,C+D9wQM,wBAOI,uC/D2wQV,C+DlxQM,gBAOI,qB/D+wQV,C+DtxQM,gBAOI,qB/DmxQV,C+D1xQM,kBAOI,uB/DuxQV,C+D9xQM,kBAOI,uB/D2xQV,C+DlyQM,cAOI,wB/D+xQV,C+DtyQM,gBAOI,0B/DmyQV,C+D1yQM,sBAOI,gC/DuyQV,C+D9yQM,UAOI,e/D2yQV,C+DlzQM,UAOI,oB/D+yQV,C+DtzQM,UAOI,mB/DmzQV,C+D1zQM,UAOI,kB/DuzQV,C+D9zQM,UAOI,oB/D2zQV,C+Dl0QM,UAOI,kB/D+zQV,C+Dt0QM,0BAOI,oC/Dm0QV,C+D10QM,wBAOI,kC/Du0QV,C+D90QM,2BAOI,gC/D20QV,C+Dl1QM,4BAOI,uC/D+0QV,C+Dt1QM,2BAOI,sC/Dm1QV,C+D11QM,2BAOI,sC/Du1QV,C+D91QM,sBAOI,gC/D21QV,C+Dl2QM,oBAOI,8B/D+1QV,C+Dt2QM,uBAOI,4B/Dm2QV,C+D12QM,yBAOI,8B/Du2QV,C+D92QM,wBAOI,6B/D22QV,C+Dl3QM,wBAOI,kC/D+2QV,C+Dt3QM,sBAOI,gC/Dm3QV,C+D13QM,yBAOI,8B/Du3QV,C+D93QM,0BAOI,qC/D23QV,C+Dl4QM,yBAOI,oC/D+3QV,C+Dt4QM,0BAOI,+B/Dm4QV,C+D14QM,oBAOI,yB/Du4QV,C+D94QM,qBAOI,+B/D24QV,C+Dl5QM,mBAOI,6B/D+4QV,C+Dt5QM,sBAOI,2B/Dm5QV,C+D15QM,wBAOI,6B/Du5QV,C+D95QM,uBAOI,4B/D25QV,C+Dl6QM,gBAOI,kB/D+5QV,C+Dt6QM,YAOI,iB/Dm6QV,C+D16QM,YAOI,iB/Du6QV,C+D96QM,YAOI,iB/D26QV,C+Dl7QM,YAOI,iB/D+6QV,C+Dt7QM,YAOI,iB/Dm7QV,C+D17QM,YAOI,iB/Du7QV,C+D97QM,eAOI,iB/D27QV,C+Dl8QM,QAOI,kB/D+7QV,C+Dt8QM,QAOI,uB/Dm8QV,C+D18QM,QAOI,sB/Du8QV,C+D98QM,QAOI,qB/D28QV,C+Dl9QM,QAOI,uB/D+8QV,C+Dt9QM,QAOI,qB/Dm9QV,C+D19QM,WAOI,qB/Du9QV,C+D99QM,SAOI,gD/D49QV,C+Dn+QM,SAOI,0D/Di+QV,C+Dx+QM,SAOI,wD/Ds+QV,C+D7+QM,SAOI,sD/D2+QV,C+Dl/QM,SAOI,0D/Dg/QV,C+Dv/QM,SAOI,sD/Dq/QV,C+D5/QM,YAOI,sD/D0/QV,C+DjgRM,SAOI,gD/D+/QV,C+DtgRM,SAOI,0D/DogRV,C+D3gRM,SAOI,wD/DygRV,C+DhhRM,SAOI,sD/D8gRV,C+DrhRM,SAOI,0D/DmhRV,C+D1hRM,SAOI,sD/DwhRV,C+D/hRM,YAOI,sD/D6hRV,C+DpiRM,SAOI,sB/DiiRV,C+DxiRM,SAOI,2B/DqiRV,C+D5iRM,SAOI,0B/DyiRV,C+DhjRM,SAOI,yB/D6iRV,C+DpjRM,SAOI,2B/DijRV,C+DxjRM,SAOI,yB/DqjRV,C+D5jRM,YAOI,yB/DyjRV,C+DhkRM,SAOI,wB/D6jRV,C+DpkRM,SAOI,6B/DikRV,C+DxkRM,SAOI,4B/DqkRV,C+D5kRM,SAOI,2B/DykRV,C+DhlRM,SAOI,6B/D6kRV,C+DplRM,SAOI,2B/DilRV,C+DxlRM,YAOI,2B/DqlRV,C+D5lRM,SAOI,yB/DylRV,C+DhmRM,SAOI,8B/D6lRV,C+DpmRM,SAOI,6B/DimRV,C+DxmRM,SAOI,4B/DqmRV,C+D5mRM,SAOI,8B/DymRV,C+DhnRM,SAOI,4B/D6mRV,C+DpnRM,YAOI,4B/DinRV,C+DxnRM,SAOI,uB/DqnRV,C+D5nRM,SAOI,4B/DynRV,C+DhoRM,SAOI,2B/D6nRV,C+DpoRM,SAOI,0B/DioRV,C+DxoRM,SAOI,4B/DqoRV,C+D5oRM,SAOI,0B/DyoRV,C+DhpRM,YAOI,0B/D6oRV,C+DppRM,QAOI,mB/DipRV,C+DxpRM,QAOI,wB/DqpRV,C+D5pRM,QAOI,uB/DypRV,C+DhqRM,QAOI,sB/D6pRV,C+DpqRM,QAOI,wB/DiqRV,C+DxqRM,QAOI,sB/DqqRV,C+D5qRM,SAOI,kD/D0qRV,C+DjrRM,SAOI,4D/D+qRV,C+DtrRM,SAOI,0D/DorRV,C+D3rRM,SAOI,wD/DyrRV,C+DhsRM,SAOI,4D/D8rRV,C+DrsRM,SAOI,wD/DmsRV,C+D1sRM,SAOI,kD/DwsRV,C+D/sRM,SAOI,4D/D6sRV,C+DptRM,SAOI,0D/DktRV,C+DztRM,SAOI,wD/DutRV,C+D9tRM,SAOI,4D/D4tRV,C+DnuRM,SAOI,wD/DiuRV,C+DxuRM,SAOI,uB/DquRV,C+D5uRM,SAOI,4B/DyuRV,C+DhvRM,SAOI,2B/D6uRV,C+DpvRM,SAOI,0B/DivRV,C+DxvRM,SAOI,4B/DqvRV,C+D5vRM,SAOI,0B/DyvRV,C+DhwRM,SAOI,yB/D6vRV,C+DpwRM,SAOI,8B/DiwRV,C+DxwRM,SAOI,6B/DqwRV,C+D5wRM,SAOI,4B/DywRV,C+DhxRM,SAOI,8B/D6wRV,C+DpxRM,SAOI,4B/DixRV,C+DxxRM,SAOI,0B/DqxRV,C+D5xRM,SAOI,+B/DyxRV,C+DhyRM,SAOI,8B/D6xRV,C+DpyRM,SAOI,6B/DiyRV,C+DxyRM,SAOI,+B/DqyRV,C+D5yRM,SAOI,6B/DyyRV,C+DhzRM,SAOI,wB/D6yRV,C+DpzRM,SAOI,6B/DizRV,C+DxzRM,SAOI,4B/DqzRV,C+D5zRM,SAOI,2B/DyzRV,C+Dh0RM,SAOI,6B/D6zRV,C+Dp0RM,SAOI,2B/Di0RV,C+Dx0RM,eAOI,yB/Dq0RV,C+D50RM,aAOI,0B/Dy0RV,C+Dh1RM,gBAOI,2B/D60RV,CACF,CQr1RI,yBuDAI,gBAOI,oB/Dk1RV,C+Dz1RM,cAOI,qB/Ds1RV,C+D71RM,eAOI,oB/D01RV,C+Dj2RM,aAOI,wB/D81RV,C+Dr2RM,mBAOI,8B/Dk2RV,C+Dz2RM,YAOI,uB/Ds2RV,C+D72RM,WAOI,sB/D02RV,C+Dj3RM,YAOI,uB/D82RV,C+Dr3RM,gBAOI,2B/Dk3RV,C+Dz3RM,iBAOI,4B/Ds3RV,C+D73RM,WAOI,sB/D03RV,C+Dj4RM,kBAOI,6B/D83RV,C+Dr4RM,WAOI,sB/Dk4RV,C+Dz4RM,cAOI,uB/Ds4RV,C+D74RM,aAOI,4B/D04RV,C+Dj5RM,gBAOI,+B/D84RV,C+Dr5RM,qBAOI,oC/Dk5RV,C+Dz5RM,wBAOI,uC/Ds5RV,C+D75RM,gBAOI,qB/D05RV,C+Dj6RM,gBAOI,qB/D85RV,C+Dr6RM,kBAOI,uB/Dk6RV,C+Dz6RM,kBAOI,uB/Ds6RV,C+D76RM,cAOI,wB/D06RV,C+Dj7RM,gBAOI,0B/D86RV,C+Dr7RM,sBAOI,gC/Dk7RV,C+Dz7RM,UAOI,e/Ds7RV,C+D77RM,UAOI,oB/D07RV,C+Dj8RM,UAOI,mB/D87RV,C+Dr8RM,UAOI,kB/Dk8RV,C+Dz8RM,UAOI,oB/Ds8RV,C+D78RM,UAOI,kB/D08RV,C+Dj9RM,0BAOI,oC/D88RV,C+Dr9RM,wBAOI,kC/Dk9RV,C+Dz9RM,2BAOI,gC/Ds9RV,C+D79RM,4BAOI,uC/D09RV,C+Dj+RM,2BAOI,sC/D89RV,C+Dr+RM,2BAOI,sC/Dk+RV,C+Dz+RM,sBAOI,gC/Ds+RV,C+D7+RM,oBAOI,8B/D0+RV,C+Dj/RM,uBAOI,4B/D8+RV,C+Dr/RM,yBAOI,8B/Dk/RV,C+Dz/RM,wBAOI,6B/Ds/RV,C+D7/RM,wBAOI,kC/D0/RV,C+DjgSM,sBAOI,gC/D8/RV,C+DrgSM,yBAOI,8B/DkgSV,C+DzgSM,0BAOI,qC/DsgSV,C+D7gSM,yBAOI,oC/D0gSV,C+DjhSM,0BAOI,+B/D8gSV,C+DrhSM,oBAOI,yB/DkhSV,C+DzhSM,qBAOI,+B/DshSV,C+D7hSM,mBAOI,6B/D0hSV,C+DjiSM,sBAOI,2B/D8hSV,C+DriSM,wBAOI,6B/DkiSV,C+DziSM,uBAOI,4B/DsiSV,C+D7iSM,gBAOI,kB/D0iSV,C+DjjSM,YAOI,iB/D8iSV,C+DrjSM,YAOI,iB/DkjSV,C+DzjSM,YAOI,iB/DsjSV,C+D7jSM,YAOI,iB/D0jSV,C+DjkSM,YAOI,iB/D8jSV,C+DrkSM,YAOI,iB/DkkSV,C+DzkSM,eAOI,iB/DskSV,C+D7kSM,QAOI,kB/D0kSV,C+DjlSM,QAOI,uB/D8kSV,C+DrlSM,QAOI,sB/DklSV,C+DzlSM,QAOI,qB/DslSV,C+D7lSM,QAOI,uB/D0lSV,C+DjmSM,QAOI,qB/D8lSV,C+DrmSM,WAOI,qB/DkmSV,C+DzmSM,SAOI,gD/DumSV,C+D9mSM,SAOI,0D/D4mSV,C+DnnSM,SAOI,wD/DinSV,C+DxnSM,SAOI,sD/DsnSV,C+D7nSM,SAOI,0D/D2nSV,C+DloSM,SAOI,sD/DgoSV,C+DvoSM,YAOI,sD/DqoSV,C+D5oSM,SAOI,gD/D0oSV,C+DjpSM,SAOI,0D/D+oSV,C+DtpSM,SAOI,wD/DopSV,C+D3pSM,SAOI,sD/DypSV,C+DhqSM,SAOI,0D/D8pSV,C+DrqSM,SAOI,sD/DmqSV,C+D1qSM,YAOI,sD/DwqSV,C+D/qSM,SAOI,sB/D4qSV,C+DnrSM,SAOI,2B/DgrSV,C+DvrSM,SAOI,0B/DorSV,C+D3rSM,SAOI,yB/DwrSV,C+D/rSM,SAOI,2B/D4rSV,C+DnsSM,SAOI,yB/DgsSV,C+DvsSM,YAOI,yB/DosSV,C+D3sSM,SAOI,wB/DwsSV,C+D/sSM,SAOI,6B/D4sSV,C+DntSM,SAOI,4B/DgtSV,C+DvtSM,SAOI,2B/DotSV,C+D3tSM,SAOI,6B/DwtSV,C+D/tSM,SAOI,2B/D4tSV,C+DnuSM,YAOI,2B/DguSV,C+DvuSM,SAOI,yB/DouSV,C+D3uSM,SAOI,8B/DwuSV,C+D/uSM,SAOI,6B/D4uSV,C+DnvSM,SAOI,4B/DgvSV,C+DvvSM,SAOI,8B/DovSV,C+D3vSM,SAOI,4B/DwvSV,C+D/vSM,YAOI,4B/D4vSV,C+DnwSM,SAOI,uB/DgwSV,C+DvwSM,SAOI,4B/DowSV,C+D3wSM,SAOI,2B/DwwSV,C+D/wSM,SAOI,0B/D4wSV,C+DnxSM,SAOI,4B/DgxSV,C+DvxSM,SAOI,0B/DoxSV,C+D3xSM,YAOI,0B/DwxSV,C+D/xSM,QAOI,mB/D4xSV,C+DnySM,QAOI,wB/DgySV,C+DvySM,QAOI,uB/DoySV,C+D3ySM,QAOI,sB/DwySV,C+D/ySM,QAOI,wB/D4ySV,C+DnzSM,QAOI,sB/DgzSV,C+DvzSM,SAOI,kD/DqzSV,C+D5zSM,SAOI,4D/D0zSV,C+Dj0SM,SAOI,0D/D+zSV,C+Dt0SM,SAOI,wD/Do0SV,C+D30SM,SAOI,4D/Dy0SV,C+Dh1SM,SAOI,wD/D80SV,C+Dr1SM,SAOI,kD/Dm1SV,C+D11SM,SAOI,4D/Dw1SV,C+D/1SM,SAOI,0D/D61SV,C+Dp2SM,SAOI,wD/Dk2SV,C+Dz2SM,SAOI,4D/Du2SV,C+D92SM,SAOI,wD/D42SV,C+Dn3SM,SAOI,uB/Dg3SV,C+Dv3SM,SAOI,4B/Do3SV,C+D33SM,SAOI,2B/Dw3SV,C+D/3SM,SAOI,0B/D43SV,C+Dn4SM,SAOI,4B/Dg4SV,C+Dv4SM,SAOI,0B/Do4SV,C+D34SM,SAOI,yB/Dw4SV,C+D/4SM,SAOI,8B/D44SV,C+Dn5SM,SAOI,6B/Dg5SV,C+Dv5SM,SAOI,4B/Do5SV,C+D35SM,SAOI,8B/Dw5SV,C+D/5SM,SAOI,4B/D45SV,C+Dn6SM,SAOI,0B/Dg6SV,C+Dv6SM,SAOI,+B/Do6SV,C+D36SM,SAOI,8B/Dw6SV,C+D/6SM,SAOI,6B/D46SV,C+Dn7SM,SAOI,+B/Dg7SV,C+Dv7SM,SAOI,6B/Do7SV,C+D37SM,SAOI,wB/Dw7SV,C+D/7SM,SAOI,6B/D47SV,C+Dn8SM,SAOI,4B/Dg8SV,C+Dv8SM,SAOI,2B/Do8SV,C+D38SM,SAOI,6B/Dw8SV,C+D/8SM,SAOI,2B/D48SV,C+Dn9SM,eAOI,yB/Dg9SV,C+Dv9SM,aAOI,0B/Do9SV,C+D39SM,gBAOI,2B/Dw9SV,CACF,CQh+SI,0BuDAI,gBAOI,oB/D69SV,C+Dp+SM,cAOI,qB/Di+SV,C+Dx+SM,eAOI,oB/Dq+SV,C+D5+SM,aAOI,wB/Dy+SV,C+Dh/SM,mBAOI,8B/D6+SV,C+Dp/SM,YAOI,uB/Di/SV,C+Dx/SM,WAOI,sB/Dq/SV,C+D5/SM,YAOI,uB/Dy/SV,C+DhgTM,gBAOI,2B/D6/SV,C+DpgTM,iBAOI,4B/DigTV,C+DxgTM,WAOI,sB/DqgTV,C+D5gTM,kBAOI,6B/DygTV,C+DhhTM,WAOI,sB/D6gTV,C+DphTM,cAOI,uB/DihTV,C+DxhTM,aAOI,4B/DqhTV,C+D5hTM,gBAOI,+B/DyhTV,C+DhiTM,qBAOI,oC/D6hTV,C+DpiTM,wBAOI,uC/DiiTV,C+DxiTM,gBAOI,qB/DqiTV,C+D5iTM,gBAOI,qB/DyiTV,C+DhjTM,kBAOI,uB/D6iTV,C+DpjTM,kBAOI,uB/DijTV,C+DxjTM,cAOI,wB/DqjTV,C+D5jTM,gBAOI,0B/DyjTV,C+DhkTM,sBAOI,gC/D6jTV,C+DpkTM,UAOI,e/DikTV,C+DxkTM,UAOI,oB/DqkTV,C+D5kTM,UAOI,mB/DykTV,C+DhlTM,UAOI,kB/D6kTV,C+DplTM,UAOI,oB/DilTV,C+DxlTM,UAOI,kB/DqlTV,C+D5lTM,0BAOI,oC/DylTV,C+DhmTM,wBAOI,kC/D6lTV,C+DpmTM,2BAOI,gC/DimTV,C+DxmTM,4BAOI,uC/DqmTV,C+D5mTM,2BAOI,sC/DymTV,C+DhnTM,2BAOI,sC/D6mTV,C+DpnTM,sBAOI,gC/DinTV,C+DxnTM,oBAOI,8B/DqnTV,C+D5nTM,uBAOI,4B/DynTV,C+DhoTM,yBAOI,8B/D6nTV,C+DpoTM,wBAOI,6B/DioTV,C+DxoTM,wBAOI,kC/DqoTV,C+D5oTM,sBAOI,gC/DyoTV,C+DhpTM,yBAOI,8B/D6oTV,C+DppTM,0BAOI,qC/DipTV,C+DxpTM,yBAOI,oC/DqpTV,C+D5pTM,0BAOI,+B/DypTV,C+DhqTM,oBAOI,yB/D6pTV,C+DpqTM,qBAOI,+B/DiqTV,C+DxqTM,mBAOI,6B/DqqTV,C+D5qTM,sBAOI,2B/DyqTV,C+DhrTM,wBAOI,6B/D6qTV,C+DprTM,uBAOI,4B/DirTV,C+DxrTM,gBAOI,kB/DqrTV,C+D5rTM,YAOI,iB/DyrTV,C+DhsTM,YAOI,iB/D6rTV,C+DpsTM,YAOI,iB/DisTV,C+DxsTM,YAOI,iB/DqsTV,C+D5sTM,YAOI,iB/DysTV,C+DhtTM,YAOI,iB/D6sTV,C+DptTM,eAOI,iB/DitTV,C+DxtTM,QAOI,kB/DqtTV,C+D5tTM,QAOI,uB/DytTV,C+DhuTM,QAOI,sB/D6tTV,C+DpuTM,QAOI,qB/DiuTV,C+DxuTM,QAOI,uB/DquTV,C+D5uTM,QAOI,qB/DyuTV,C+DhvTM,WAOI,qB/D6uTV,C+DpvTM,SAOI,gD/DkvTV,C+DzvTM,SAOI,0D/DuvTV,C+D9vTM,SAOI,wD/D4vTV,C+DnwTM,SAOI,sD/DiwTV,C+DxwTM,SAOI,0D/DswTV,C+D7wTM,SAOI,sD/D2wTV,C+DlxTM,YAOI,sD/DgxTV,C+DvxTM,SAOI,gD/DqxTV,C+D5xTM,SAOI,0D/D0xTV,C+DjyTM,SAOI,wD/D+xTV,C+DtyTM,SAOI,sD/DoyTV,C+D3yTM,SAOI,0D/DyyTV,C+DhzTM,SAOI,sD/D8yTV,C+DrzTM,YAOI,sD/DmzTV,C+D1zTM,SAOI,sB/DuzTV,C+D9zTM,SAOI,2B/D2zTV,C+Dl0TM,SAOI,0B/D+zTV,C+Dt0TM,SAOI,yB/Dm0TV,C+D10TM,SAOI,2B/Du0TV,C+D90TM,SAOI,yB/D20TV,C+Dl1TM,YAOI,yB/D+0TV,C+Dt1TM,SAOI,wB/Dm1TV,C+D11TM,SAOI,6B/Du1TV,C+D91TM,SAOI,4B/D21TV,C+Dl2TM,SAOI,2B/D+1TV,C+Dt2TM,SAOI,6B/Dm2TV,C+D12TM,SAOI,2B/Du2TV,C+D92TM,YAOI,2B/D22TV,C+Dl3TM,SAOI,yB/D+2TV,C+Dt3TM,SAOI,8B/Dm3TV,C+D13TM,SAOI,6B/Du3TV,C+D93TM,SAOI,4B/D23TV,C+Dl4TM,SAOI,8B/D+3TV,C+Dt4TM,SAOI,4B/Dm4TV,C+D14TM,YAOI,4B/Du4TV,C+D94TM,SAOI,uB/D24TV,C+Dl5TM,SAOI,4B/D+4TV,C+Dt5TM,SAOI,2B/Dm5TV,C+D15TM,SAOI,0B/Du5TV,C+D95TM,SAOI,4B/D25TV,C+Dl6TM,SAOI,0B/D+5TV,C+Dt6TM,YAOI,0B/Dm6TV,C+D16TM,QAOI,mB/Du6TV,C+D96TM,QAOI,wB/D26TV,C+Dl7TM,QAOI,uB/D+6TV,C+Dt7TM,QAOI,sB/Dm7TV,C+D17TM,QAOI,wB/Du7TV,C+D97TM,QAOI,sB/D27TV,C+Dl8TM,SAOI,kD/Dg8TV,C+Dv8TM,SAOI,4D/Dq8TV,C+D58TM,SAOI,0D/D08TV,C+Dj9TM,SAOI,wD/D+8TV,C+Dt9TM,SAOI,4D/Do9TV,C+D39TM,SAOI,wD/Dy9TV,C+Dh+TM,SAOI,kD/D89TV,C+Dr+TM,SAOI,4D/Dm+TV,C+D1+TM,SAOI,0D/Dw+TV,C+D/+TM,SAOI,wD/D6+TV,C+Dp/TM,SAOI,4D/Dk/TV,C+Dz/TM,SAOI,wD/Du/TV,C+D9/TM,SAOI,uB/D2/TV,C+DlgUM,SAOI,4B/D+/TV,C+DtgUM,SAOI,2B/DmgUV,C+D1gUM,SAOI,0B/DugUV,C+D9gUM,SAOI,4B/D2gUV,C+DlhUM,SAOI,0B/D+gUV,C+DthUM,SAOI,yB/DmhUV,C+D1hUM,SAOI,8B/DuhUV,C+D9hUM,SAOI,6B/D2hUV,C+DliUM,SAOI,4B/D+hUV,C+DtiUM,SAOI,8B/DmiUV,C+D1iUM,SAOI,4B/DuiUV,C+D9iUM,SAOI,0B/D2iUV,C+DljUM,SAOI,+B/D+iUV,C+DtjUM,SAOI,8B/DmjUV,C+D1jUM,SAOI,6B/DujUV,C+D9jUM,SAOI,+B/D2jUV,C+DlkUM,SAOI,6B/D+jUV,C+DtkUM,SAOI,wB/DmkUV,C+D1kUM,SAOI,6B/DukUV,C+D9kUM,SAOI,4B/D2kUV,C+DllUM,SAOI,2B/D+kUV,C+DtlUM,SAOI,6B/DmlUV,C+D1lUM,SAOI,2B/DulUV,C+D9lUM,eAOI,yB/D2lUV,C+DlmUM,aAOI,0B/D+lUV,C+DtmUM,gBAOI,2B/DmmUV,CACF,CQ3mUI,0BuDAI,iBAOI,oB/DwmUV,C+D/mUM,eAOI,qB/D4mUV,C+DnnUM,gBAOI,oB/DgnUV,C+DvnUM,cAOI,wB/DonUV,C+D3nUM,oBAOI,8B/DwnUV,C+D/nUM,aAOI,uB/D4nUV,C+DnoUM,YAOI,sB/DgoUV,C+DvoUM,aAOI,uB/DooUV,C+D3oUM,iBAOI,2B/DwoUV,C+D/oUM,kBAOI,4B/D4oUV,C+DnpUM,YAOI,sB/DgpUV,C+DvpUM,mBAOI,6B/DopUV,C+D3pUM,YAOI,sB/DwpUV,C+D/pUM,eAOI,uB/D4pUV,C+DnqUM,cAOI,4B/DgqUV,C+DvqUM,iBAOI,+B/DoqUV,C+D3qUM,sBAOI,oC/DwqUV,C+D/qUM,yBAOI,uC/D4qUV,C+DnrUM,iBAOI,qB/DgrUV,C+DvrUM,iBAOI,qB/DorUV,C+D3rUM,mBAOI,uB/DwrUV,C+D/rUM,mBAOI,uB/D4rUV,C+DnsUM,eAOI,wB/DgsUV,C+DvsUM,iBAOI,0B/DosUV,C+D3sUM,uBAOI,gC/DwsUV,C+D/sUM,WAOI,e/D4sUV,C+DntUM,WAOI,oB/DgtUV,C+DvtUM,WAOI,mB/DotUV,C+D3tUM,WAOI,kB/DwtUV,C+D/tUM,WAOI,oB/D4tUV,C+DnuUM,WAOI,kB/DguUV,C+DvuUM,2BAOI,oC/DouUV,C+D3uUM,yBAOI,kC/DwuUV,C+D/uUM,4BAOI,gC/D4uUV,C+DnvUM,6BAOI,uC/DgvUV,C+DvvUM,4BAOI,sC/DovUV,C+D3vUM,4BAOI,sC/DwvUV,C+D/vUM,uBAOI,gC/D4vUV,C+DnwUM,qBAOI,8B/DgwUV,C+DvwUM,wBAOI,4B/DowUV,C+D3wUM,0BAOI,8B/DwwUV,C+D/wUM,yBAOI,6B/D4wUV,C+DnxUM,yBAOI,kC/DgxUV,C+DvxUM,uBAOI,gC/DoxUV,C+D3xUM,0BAOI,8B/DwxUV,C+D/xUM,2BAOI,qC/D4xUV,C+DnyUM,0BAOI,oC/DgyUV,C+DvyUM,2BAOI,+B/DoyUV,C+D3yUM,qBAOI,yB/DwyUV,C+D/yUM,sBAOI,+B/D4yUV,C+DnzUM,oBAOI,6B/DgzUV,C+DvzUM,uBAOI,2B/DozUV,C+D3zUM,yBAOI,6B/DwzUV,C+D/zUM,wBAOI,4B/D4zUV,C+Dn0UM,iBAOI,kB/Dg0UV,C+Dv0UM,aAOI,iB/Do0UV,C+D30UM,aAOI,iB/Dw0UV,C+D/0UM,aAOI,iB/D40UV,C+Dn1UM,aAOI,iB/Dg1UV,C+Dv1UM,aAOI,iB/Do1UV,C+D31UM,aAOI,iB/Dw1UV,C+D/1UM,gBAOI,iB/D41UV,C+Dn2UM,SAOI,kB/Dg2UV,C+Dv2UM,SAOI,uB/Do2UV,C+D32UM,SAOI,sB/Dw2UV,C+D/2UM,SAOI,qB/D42UV,C+Dn3UM,SAOI,uB/Dg3UV,C+Dv3UM,SAOI,qB/Do3UV,C+D33UM,YAOI,qB/Dw3UV,C+D/3UM,UAOI,gD/D63UV,C+Dp4UM,UAOI,0D/Dk4UV,C+Dz4UM,UAOI,wD/Du4UV,C+D94UM,UAOI,sD/D44UV,C+Dn5UM,UAOI,0D/Di5UV,C+Dx5UM,UAOI,sD/Ds5UV,C+D75UM,aAOI,sD/D25UV,C+Dl6UM,UAOI,gD/Dg6UV,C+Dv6UM,UAOI,0D/Dq6UV,C+D56UM,UAOI,wD/D06UV,C+Dj7UM,UAOI,sD/D+6UV,C+Dt7UM,UAOI,0D/Do7UV,C+D37UM,UAOI,sD/Dy7UV,C+Dh8UM,aAOI,sD/D87UV,C+Dr8UM,UAOI,sB/Dk8UV,C+Dz8UM,UAOI,2B/Ds8UV,C+D78UM,UAOI,0B/D08UV,C+Dj9UM,UAOI,yB/D88UV,C+Dr9UM,UAOI,2B/Dk9UV,C+Dz9UM,UAOI,yB/Ds9UV,C+D79UM,aAOI,yB/D09UV,C+Dj+UM,UAOI,wB/D89UV,C+Dr+UM,UAOI,6B/Dk+UV,C+Dz+UM,UAOI,4B/Ds+UV,C+D7+UM,UAOI,2B/D0+UV,C+Dj/UM,UAOI,6B/D8+UV,C+Dr/UM,UAOI,2B/Dk/UV,C+Dz/UM,aAOI,2B/Ds/UV,C+D7/UM,UAOI,yB/D0/UV,C+DjgVM,UAOI,8B/D8/UV,C+DrgVM,UAOI,6B/DkgVV,C+DzgVM,UAOI,4B/DsgVV,C+D7gVM,UAOI,8B/D0gVV,C+DjhVM,UAOI,4B/D8gVV,C+DrhVM,aAOI,4B/DkhVV,C+DzhVM,UAOI,uB/DshVV,C+D7hVM,UAOI,4B/D0hVV,C+DjiVM,UAOI,2B/D8hVV,C+DriVM,UAOI,0B/DkiVV,C+DziVM,UAOI,4B/DsiVV,C+D7iVM,UAOI,0B/D0iVV,C+DjjVM,aAOI,0B/D8iVV,C+DrjVM,SAOI,mB/DkjVV,C+DzjVM,SAOI,wB/DsjVV,C+D7jVM,SAOI,uB/D0jVV,C+DjkVM,SAOI,sB/D8jVV,C+DrkVM,SAOI,wB/DkkVV,C+DzkVM,SAOI,sB/DskVV,C+D7kVM,UAOI,kD/D2kVV,C+DllVM,UAOI,4D/DglVV,C+DvlVM,UAOI,0D/DqlVV,C+D5lVM,UAOI,wD/D0lVV,C+DjmVM,UAOI,4D/D+lVV,C+DtmVM,UAOI,wD/DomVV,C+D3mVM,UAOI,kD/DymVV,C+DhnVM,UAOI,4D/D8mVV,C+DrnVM,UAOI,0D/DmnVV,C+D1nVM,UAOI,wD/DwnVV,C+D/nVM,UAOI,4D/D6nVV,C+DpoVM,UAOI,wD/DkoVV,C+DzoVM,UAOI,uB/DsoVV,C+D7oVM,UAOI,4B/D0oVV,C+DjpVM,UAOI,2B/D8oVV,C+DrpVM,UAOI,0B/DkpVV,C+DzpVM,UAOI,4B/DspVV,C+D7pVM,UAOI,0B/D0pVV,C+DjqVM,UAOI,yB/D8pVV,C+DrqVM,UAOI,8B/DkqVV,C+DzqVM,UAOI,6B/DsqVV,C+D7qVM,UAOI,4B/D0qVV,C+DjrVM,UAOI,8B/D8qVV,C+DrrVM,UAOI,4B/DkrVV,C+DzrVM,UAOI,0B/DsrVV,C+D7rVM,UAOI,+B/D0rVV,C+DjsVM,UAOI,8B/D8rVV,C+DrsVM,UAOI,6B/DksVV,C+DzsVM,UAOI,+B/DssVV,C+D7sVM,UAOI,6B/D0sVV,C+DjtVM,UAOI,wB/D8sVV,C+DrtVM,UAOI,6B/DktVV,C+DztVM,UAOI,4B/DstVV,C+D7tVM,UAOI,2B/D0tVV,C+DjuVM,UAOI,6B/D8tVV,C+DruVM,UAOI,2B/DkuVV,C+DzuVM,gBAOI,yB/DsuVV,C+D7uVM,cAOI,0B/D0uVV,C+DjvVM,iBAOI,2B/D8uVV,CACF,CgElyVA,0BD4CQ,MAOI,0B/DmvVV,C+D1vVM,MAOI,wB/DuvVV,C+D9vVM,MAOI,2B/D2vVV,C+DlwVM,MAOI,0B/D+vVV,CACF,CgEhyVA,aDyBQ,gBAOI,wB/DowVV,C+D3wVM,sBAOI,8B/DwwVV,C+D/wVM,eAOI,uB/D4wVV,C+DnxVM,cAOI,sB/DgxVV,C+DvxVM,eAOI,uB/DoxVV,C+D3xVM,mBAOI,2B/DwxVV,C+D/xVM,oBAOI,4B/D4xVV,C+DnyVM,cAOI,sB/DgyVV,C+DvyVM,qBAOI,6B/DoyVV,C+D3yVM,cAOI,sB/DwyVV,CACF","sources":["../node_modules/bootstrap/scss/_type.scss","../node_modules/bootstrap/scss/_images.scss","../node_modules/bootstrap/scss/bootstrap.scss","../node_modules/bootstrap/scss/_root.scss","../node_modules/bootstrap/scss/_reboot.scss","../node_modules/bootstrap/scss/_offcanvas.scss","../node_modules/bootstrap/scss/_placeholders.scss","index.css","App.css","../node_modules/bootstrap/dist/css/bootstrap.css","../node_modules/bootstrap/scss/vendor/_rfs.scss","../node_modules/bootstrap/scss/_variables.scss","../node_modules/bootstrap/scss/mixins/_border-radius.scss","../node_modules/bootstrap/scss/mixins/_lists.scss","../node_modules/bootstrap/scss/mixins/_image.scss","../node_modules/bootstrap/scss/_containers.scss","../node_modules/bootstrap/scss/mixins/_container.scss","../node_modules/bootstrap/scss/mixins/_breakpoints.scss","../node_modules/bootstrap/scss/_grid.scss","../node_modules/bootstrap/scss/mixins/_grid.scss","../node_modules/bootstrap/scss/_tables.scss","../node_modules/bootstrap/scss/mixins/_table-variants.scss","../node_modules/bootstrap/scss/forms/_labels.scss","../node_modules/bootstrap/scss/forms/_form-text.scss","../node_modules/bootstrap/scss/forms/_form-control.scss","../node_modules/bootstrap/scss/mixins/_transition.scss","../node_modules/bootstrap/scss/mixins/_gradients.scss","../node_modules/bootstrap/scss/forms/_form-select.scss","../node_modules/bootstrap/scss/forms/_form-check.scss","../node_modules/bootstrap/scss/forms/_form-range.scss","../node_modules/bootstrap/scss/forms/_floating-labels.scss","../node_modules/bootstrap/scss/forms/_input-group.scss","../node_modules/bootstrap/scss/mixins/_forms.scss","../node_modules/bootstrap/scss/_buttons.scss","../node_modules/bootstrap/scss/mixins/_buttons.scss","../node_modules/bootstrap/scss/_transitions.scss","../node_modules/bootstrap/scss/_dropdown.scss","../node_modules/bootstrap/scss/mixins/_caret.scss","../node_modules/bootstrap/scss/_button-group.scss","../node_modules/bootstrap/scss/_nav.scss","../node_modules/bootstrap/scss/_navbar.scss","../node_modules/bootstrap/scss/_card.scss","../node_modules/bootstrap/scss/_accordion.scss","../node_modules/bootstrap/scss/_breadcrumb.scss","../node_modules/bootstrap/scss/_pagination.scss","../node_modules/bootstrap/scss/mixins/_pagination.scss","../node_modules/bootstrap/scss/_badge.scss","../node_modules/bootstrap/scss/_alert.scss","../node_modules/bootstrap/scss/mixins/_alert.scss","../node_modules/bootstrap/scss/_progress.scss","../node_modules/bootstrap/scss/_list-group.scss","../node_modules/bootstrap/scss/mixins/_list-group.scss","../node_modules/bootstrap/scss/_close.scss","../node_modules/bootstrap/scss/_toasts.scss","../node_modules/bootstrap/scss/_modal.scss","../node_modules/bootstrap/scss/mixins/_backdrop.scss","../node_modules/bootstrap/scss/_tooltip.scss","../node_modules/bootstrap/scss/mixins/_reset-text.scss","../node_modules/bootstrap/scss/_popover.scss","../node_modules/bootstrap/scss/_carousel.scss","../node_modules/bootstrap/scss/mixins/_clearfix.scss","../node_modules/bootstrap/scss/_spinners.scss","../node_modules/bootstrap/scss/helpers/_colored-links.scss","../node_modules/bootstrap/scss/helpers/_ratio.scss","../node_modules/bootstrap/scss/helpers/_position.scss","../node_modules/bootstrap/scss/helpers/_stacks.scss","../node_modules/bootstrap/scss/helpers/_visually-hidden.scss","../node_modules/bootstrap/scss/mixins/_visually-hidden.scss","../node_modules/bootstrap/scss/helpers/_stretched-link.scss","../node_modules/bootstrap/scss/helpers/_text-truncation.scss","../node_modules/bootstrap/scss/mixins/_text-truncate.scss","../node_modules/bootstrap/scss/helpers/_vr.scss","../node_modules/bootstrap/scss/mixins/_utilities.scss","../node_modules/bootstrap/scss/utilities/_api.scss"],"sourcesContent":["//\n// Headings\n//\n.h1 {\n @extend h1;\n}\n\n.h2 {\n @extend h2;\n}\n\n.h3 {\n @extend h3;\n}\n\n.h4 {\n @extend h4;\n}\n\n.h5 {\n @extend h5;\n}\n\n.h6 {\n @extend h6;\n}\n\n\n.lead {\n @include font-size($lead-font-size);\n font-weight: $lead-font-weight;\n}\n\n// Type display classes\n@each $display, $font-size in $display-font-sizes {\n .display-#{$display} {\n @include font-size($font-size);\n font-weight: $display-font-weight;\n line-height: $display-line-height;\n }\n}\n\n//\n// Emphasis\n//\n.small {\n @extend small;\n}\n\n.mark {\n @extend mark;\n}\n\n//\n// Lists\n//\n\n.list-unstyled {\n @include list-unstyled();\n}\n\n// Inline turns list items into inline-block\n.list-inline {\n @include list-unstyled();\n}\n.list-inline-item {\n display: inline-block;\n\n &:not(:last-child) {\n margin-right: $list-inline-padding;\n }\n}\n\n\n//\n// Misc\n//\n\n// Builds on `abbr`\n.initialism {\n @include font-size($initialism-font-size);\n text-transform: uppercase;\n}\n\n// Blockquotes\n.blockquote {\n margin-bottom: $blockquote-margin-y;\n @include font-size($blockquote-font-size);\n\n > :last-child {\n margin-bottom: 0;\n }\n}\n\n.blockquote-footer {\n margin-top: -$blockquote-margin-y;\n margin-bottom: $blockquote-margin-y;\n @include font-size($blockquote-footer-font-size);\n color: $blockquote-footer-color;\n\n &::before {\n content: \"\\2014\\00A0\"; // em dash, nbsp\n }\n}\n","// Responsive images (ensure images don't scale beyond their parents)\n//\n// This is purposefully opt-in via an explicit class rather than being the default for all ``s.\n// We previously tried the \"images are responsive by default\" approach in Bootstrap v2,\n// and abandoned it in Bootstrap v3 because it breaks lots of third-party widgets (including Google Maps)\n// which weren't expecting the images within themselves to be involuntarily resized.\n// See also https://github.com/twbs/bootstrap/issues/18178\n.img-fluid {\n @include img-fluid();\n}\n\n\n// Image thumbnails\n.img-thumbnail {\n padding: $thumbnail-padding;\n background-color: $thumbnail-bg;\n border: $thumbnail-border-width solid $thumbnail-border-color;\n @include border-radius($thumbnail-border-radius);\n @include box-shadow($thumbnail-box-shadow);\n\n // Keep them at most 100% wide\n @include img-fluid();\n}\n\n//\n// Figures\n//\n\n.figure {\n // Ensures the caption's text aligns with the image.\n display: inline-block;\n}\n\n.figure-img {\n margin-bottom: $spacer * .5;\n line-height: 1;\n}\n\n.figure-caption {\n @include font-size($figure-caption-font-size);\n color: $figure-caption-color;\n}\n","/*!\n * Bootstrap v5.1.3 (https://getbootstrap.com/)\n * Copyright 2011-2021 The Bootstrap Authors\n * Copyright 2011-2021 Twitter, Inc.\n * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)\n */\n\n// scss-docs-start import-stack\n// Configuration\n@import \"functions\";\n@import \"variables\";\n@import \"mixins\";\n@import \"utilities\";\n\n// Layout & components\n@import \"root\";\n@import \"reboot\";\n@import \"type\";\n@import \"images\";\n@import \"containers\";\n@import \"grid\";\n@import \"tables\";\n@import \"forms\";\n@import \"buttons\";\n@import \"transitions\";\n@import \"dropdown\";\n@import \"button-group\";\n@import \"nav\";\n@import \"navbar\";\n@import \"card\";\n@import \"accordion\";\n@import \"breadcrumb\";\n@import \"pagination\";\n@import \"badge\";\n@import \"alert\";\n@import \"progress\";\n@import \"list-group\";\n@import \"close\";\n@import \"toasts\";\n@import \"modal\";\n@import \"tooltip\";\n@import \"popover\";\n@import \"carousel\";\n@import \"spinners\";\n@import \"offcanvas\";\n@import \"placeholders\";\n\n// Helpers\n@import \"helpers\";\n\n// Utilities\n@import \"utilities/api\";\n// scss-docs-end import-stack\n",":root {\n // Note: Custom variable values only support SassScript inside `#{}`.\n\n // Colors\n //\n // Generate palettes for full colors, grays, and theme colors.\n\n @each $color, $value in $colors {\n --#{$variable-prefix}#{$color}: #{$value};\n }\n\n @each $color, $value in $grays {\n --#{$variable-prefix}gray-#{$color}: #{$value};\n }\n\n @each $color, $value in $theme-colors {\n --#{$variable-prefix}#{$color}: #{$value};\n }\n\n @each $color, $value in $theme-colors-rgb {\n --#{$variable-prefix}#{$color}-rgb: #{$value};\n }\n\n --#{$variable-prefix}white-rgb: #{to-rgb($white)};\n --#{$variable-prefix}black-rgb: #{to-rgb($black)};\n --#{$variable-prefix}body-color-rgb: #{to-rgb($body-color)};\n --#{$variable-prefix}body-bg-rgb: #{to-rgb($body-bg)};\n\n // Fonts\n\n // Note: Use `inspect` for lists so that quoted items keep the quotes.\n // See https://github.com/sass/sass/issues/2383#issuecomment-336349172\n --#{$variable-prefix}font-sans-serif: #{inspect($font-family-sans-serif)};\n --#{$variable-prefix}font-monospace: #{inspect($font-family-monospace)};\n --#{$variable-prefix}gradient: #{$gradient};\n\n // Root and body\n // stylelint-disable custom-property-empty-line-before\n // scss-docs-start root-body-variables\n @if $font-size-root != null {\n --#{$variable-prefix}root-font-size: #{$font-size-root};\n }\n --#{$variable-prefix}body-font-family: #{$font-family-base};\n --#{$variable-prefix}body-font-size: #{$font-size-base};\n --#{$variable-prefix}body-font-weight: #{$font-weight-base};\n --#{$variable-prefix}body-line-height: #{$line-height-base};\n --#{$variable-prefix}body-color: #{$body-color};\n @if $body-text-align != null {\n --#{$variable-prefix}body-text-align: #{$body-text-align};\n }\n --#{$variable-prefix}body-bg: #{$body-bg};\n // scss-docs-end root-body-variables\n // stylelint-enable custom-property-empty-line-before\n}\n","// stylelint-disable declaration-no-important, selector-no-qualifying-type, property-no-vendor-prefix\n\n\n// Reboot\n//\n// Normalization of HTML elements, manually forked from Normalize.css to remove\n// styles targeting irrelevant browsers while applying new styles.\n//\n// Normalize is licensed MIT. https://github.com/necolas/normalize.css\n\n\n// Document\n//\n// Change from `box-sizing: content-box` so that `width` is not affected by `padding` or `border`.\n\n*,\n*::before,\n*::after {\n box-sizing: border-box;\n}\n\n\n// Root\n//\n// Ability to the value of the root font sizes, affecting the value of `rem`.\n// null by default, thus nothing is generated.\n\n:root {\n @if $font-size-root != null {\n font-size: var(--#{$variable-prefix}root-font-size);\n }\n\n @if $enable-smooth-scroll {\n @media (prefers-reduced-motion: no-preference) {\n scroll-behavior: smooth;\n }\n }\n}\n\n\n// Body\n//\n// 1. Remove the margin in all browsers.\n// 2. As a best practice, apply a default `background-color`.\n// 3. Prevent adjustments of font size after orientation changes in iOS.\n// 4. Change the default tap highlight to be completely transparent in iOS.\n\n// scss-docs-start reboot-body-rules\nbody {\n margin: 0; // 1\n font-family: var(--#{$variable-prefix}body-font-family);\n @include font-size(var(--#{$variable-prefix}body-font-size));\n font-weight: var(--#{$variable-prefix}body-font-weight);\n line-height: var(--#{$variable-prefix}body-line-height);\n color: var(--#{$variable-prefix}body-color);\n text-align: var(--#{$variable-prefix}body-text-align);\n background-color: var(--#{$variable-prefix}body-bg); // 2\n -webkit-text-size-adjust: 100%; // 3\n -webkit-tap-highlight-color: rgba($black, 0); // 4\n}\n// scss-docs-end reboot-body-rules\n\n\n// Content grouping\n//\n// 1. Reset Firefox's gray color\n// 2. Set correct height and prevent the `size` attribute to make the `hr` look like an input field\n\nhr {\n margin: $hr-margin-y 0;\n color: $hr-color; // 1\n background-color: currentColor;\n border: 0;\n opacity: $hr-opacity;\n}\n\nhr:not([size]) {\n height: $hr-height; // 2\n}\n\n\n// Typography\n//\n// 1. Remove top margins from headings\n// By default, `

`-`

` all receive top and bottom margins. We nuke the top\n// margin for easier control within type scales as it avoids margin collapsing.\n\n%heading {\n margin-top: 0; // 1\n margin-bottom: $headings-margin-bottom;\n font-family: $headings-font-family;\n font-style: $headings-font-style;\n font-weight: $headings-font-weight;\n line-height: $headings-line-height;\n color: $headings-color;\n}\n\nh1 {\n @extend %heading;\n @include font-size($h1-font-size);\n}\n\nh2 {\n @extend %heading;\n @include font-size($h2-font-size);\n}\n\nh3 {\n @extend %heading;\n @include font-size($h3-font-size);\n}\n\nh4 {\n @extend %heading;\n @include font-size($h4-font-size);\n}\n\nh5 {\n @extend %heading;\n @include font-size($h5-font-size);\n}\n\nh6 {\n @extend %heading;\n @include font-size($h6-font-size);\n}\n\n\n// Reset margins on paragraphs\n//\n// Similarly, the top margin on `

`s get reset. However, we also reset the\n// bottom margin to use `rem` units instead of `em`.\n\np {\n margin-top: 0;\n margin-bottom: $paragraph-margin-bottom;\n}\n\n\n// Abbreviations\n//\n// 1. Duplicate behavior to the data-bs-* attribute for our tooltip plugin\n// 2. Add the correct text decoration in Chrome, Edge, Opera, and Safari.\n// 3. Add explicit cursor to indicate changed behavior.\n// 4. Prevent the text-decoration to be skipped.\n\nabbr[title],\nabbr[data-bs-original-title] { // 1\n text-decoration: underline dotted; // 2\n cursor: help; // 3\n text-decoration-skip-ink: none; // 4\n}\n\n\n// Address\n\naddress {\n margin-bottom: 1rem;\n font-style: normal;\n line-height: inherit;\n}\n\n\n// Lists\n\nol,\nul {\n padding-left: 2rem;\n}\n\nol,\nul,\ndl {\n margin-top: 0;\n margin-bottom: 1rem;\n}\n\nol ol,\nul ul,\nol ul,\nul ol {\n margin-bottom: 0;\n}\n\ndt {\n font-weight: $dt-font-weight;\n}\n\n// 1. Undo browser default\n\ndd {\n margin-bottom: .5rem;\n margin-left: 0; // 1\n}\n\n\n// Blockquote\n\nblockquote {\n margin: 0 0 1rem;\n}\n\n\n// Strong\n//\n// Add the correct font weight in Chrome, Edge, and Safari\n\nb,\nstrong {\n font-weight: $font-weight-bolder;\n}\n\n\n// Small\n//\n// Add the correct font size in all browsers\n\nsmall {\n @include font-size($small-font-size);\n}\n\n\n// Mark\n\nmark {\n padding: $mark-padding;\n background-color: $mark-bg;\n}\n\n\n// Sub and Sup\n//\n// Prevent `sub` and `sup` elements from affecting the line height in\n// all browsers.\n\nsub,\nsup {\n position: relative;\n @include font-size($sub-sup-font-size);\n line-height: 0;\n vertical-align: baseline;\n}\n\nsub { bottom: -.25em; }\nsup { top: -.5em; }\n\n\n// Links\n\na {\n color: $link-color;\n text-decoration: $link-decoration;\n\n &:hover {\n color: $link-hover-color;\n text-decoration: $link-hover-decoration;\n }\n}\n\n// And undo these styles for placeholder links/named anchors (without href).\n// It would be more straightforward to just use a[href] in previous block, but that\n// causes specificity issues in many other styles that are too complex to fix.\n// See https://github.com/twbs/bootstrap/issues/19402\n\na:not([href]):not([class]) {\n &,\n &:hover {\n color: inherit;\n text-decoration: none;\n }\n}\n\n\n// Code\n\npre,\ncode,\nkbd,\nsamp {\n font-family: $font-family-code;\n @include font-size(1em); // Correct the odd `em` font sizing in all browsers.\n direction: ltr #{\"/* rtl:ignore */\"};\n unicode-bidi: bidi-override;\n}\n\n// 1. Remove browser default top margin\n// 2. Reset browser default of `1em` to use `rem`s\n// 3. Don't allow content to break outside\n\npre {\n display: block;\n margin-top: 0; // 1\n margin-bottom: 1rem; // 2\n overflow: auto; // 3\n @include font-size($code-font-size);\n color: $pre-color;\n\n // Account for some code outputs that place code tags in pre tags\n code {\n @include font-size(inherit);\n color: inherit;\n word-break: normal;\n }\n}\n\ncode {\n @include font-size($code-font-size);\n color: $code-color;\n word-wrap: break-word;\n\n // Streamline the style when inside anchors to avoid broken underline and more\n a > & {\n color: inherit;\n }\n}\n\nkbd {\n padding: $kbd-padding-y $kbd-padding-x;\n @include font-size($kbd-font-size);\n color: $kbd-color;\n background-color: $kbd-bg;\n @include border-radius($border-radius-sm);\n\n kbd {\n padding: 0;\n @include font-size(1em);\n font-weight: $nested-kbd-font-weight;\n }\n}\n\n\n// Figures\n//\n// Apply a consistent margin strategy (matches our type styles).\n\nfigure {\n margin: 0 0 1rem;\n}\n\n\n// Images and content\n\nimg,\nsvg {\n vertical-align: middle;\n}\n\n\n// Tables\n//\n// Prevent double borders\n\ntable {\n caption-side: bottom;\n border-collapse: collapse;\n}\n\ncaption {\n padding-top: $table-cell-padding-y;\n padding-bottom: $table-cell-padding-y;\n color: $table-caption-color;\n text-align: left;\n}\n\n// 1. Removes font-weight bold by inheriting\n// 2. Matches default `` alignment by inheriting `text-align`.\n// 3. Fix alignment for Safari\n\nth {\n font-weight: $table-th-font-weight; // 1\n text-align: inherit; // 2\n text-align: -webkit-match-parent; // 3\n}\n\nthead,\ntbody,\ntfoot,\ntr,\ntd,\nth {\n border-color: inherit;\n border-style: solid;\n border-width: 0;\n}\n\n\n// Forms\n//\n// 1. Allow labels to use `margin` for spacing.\n\nlabel {\n display: inline-block; // 1\n}\n\n// Remove the default `border-radius` that macOS Chrome adds.\n// See https://github.com/twbs/bootstrap/issues/24093\n\nbutton {\n // stylelint-disable-next-line property-disallowed-list\n border-radius: 0;\n}\n\n// Explicitly remove focus outline in Chromium when it shouldn't be\n// visible (e.g. as result of mouse click or touch tap). It already\n// should be doing this automatically, but seems to currently be\n// confused and applies its very visible two-tone outline anyway.\n\nbutton:focus:not(:focus-visible) {\n outline: 0;\n}\n\n// 1. Remove the margin in Firefox and Safari\n\ninput,\nbutton,\nselect,\noptgroup,\ntextarea {\n margin: 0; // 1\n font-family: inherit;\n @include font-size(inherit);\n line-height: inherit;\n}\n\n// Remove the inheritance of text transform in Firefox\nbutton,\nselect {\n text-transform: none;\n}\n// Set the cursor for non-`\n * \n * );\n * }\n * ```\n *\n * When the `in` prop is set to `true`, the child component will first receive\n * the class `example-enter`, then the `example-enter-active` will be added in\n * the next tick. `CSSTransition` [forces a\n * reflow](https://github.com/reactjs/react-transition-group/blob/5007303e729a74be66a21c3e2205e4916821524b/src/CSSTransition.js#L208-L215)\n * between before adding the `example-enter-active`. This is an important trick\n * because it allows us to transition between `example-enter` and\n * `example-enter-active` even though they were added immediately one after\n * another. Most notably, this is what makes it possible for us to animate\n * _appearance_.\n *\n * ```css\n * .my-node-enter {\n * opacity: 0;\n * }\n * .my-node-enter-active {\n * opacity: 1;\n * transition: opacity 200ms;\n * }\n * .my-node-exit {\n * opacity: 1;\n * }\n * .my-node-exit-active {\n * opacity: 0;\n * transition: opacity 200ms;\n * }\n * ```\n *\n * `*-active` classes represent which styles you want to animate **to**.\n */\n\n\nvar CSSTransition =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(CSSTransition, _React$Component);\n\n function CSSTransition() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _this.onEnter = function (node, appearing) {\n var _this$getClassNames = _this.getClassNames(appearing ? 'appear' : 'enter'),\n className = _this$getClassNames.className;\n\n _this.removeClasses(node, 'exit');\n\n addClass(node, className);\n\n if (_this.props.onEnter) {\n _this.props.onEnter(node, appearing);\n }\n };\n\n _this.onEntering = function (node, appearing) {\n var _this$getClassNames2 = _this.getClassNames(appearing ? 'appear' : 'enter'),\n activeClassName = _this$getClassNames2.activeClassName;\n\n _this.reflowAndAddClass(node, activeClassName);\n\n if (_this.props.onEntering) {\n _this.props.onEntering(node, appearing);\n }\n };\n\n _this.onEntered = function (node, appearing) {\n var appearClassName = _this.getClassNames('appear').doneClassName;\n\n var enterClassName = _this.getClassNames('enter').doneClassName;\n\n var doneClassName = appearing ? appearClassName + \" \" + enterClassName : enterClassName;\n\n _this.removeClasses(node, appearing ? 'appear' : 'enter');\n\n addClass(node, doneClassName);\n\n if (_this.props.onEntered) {\n _this.props.onEntered(node, appearing);\n }\n };\n\n _this.onExit = function (node) {\n var _this$getClassNames3 = _this.getClassNames('exit'),\n className = _this$getClassNames3.className;\n\n _this.removeClasses(node, 'appear');\n\n _this.removeClasses(node, 'enter');\n\n addClass(node, className);\n\n if (_this.props.onExit) {\n _this.props.onExit(node);\n }\n };\n\n _this.onExiting = function (node) {\n var _this$getClassNames4 = _this.getClassNames('exit'),\n activeClassName = _this$getClassNames4.activeClassName;\n\n _this.reflowAndAddClass(node, activeClassName);\n\n if (_this.props.onExiting) {\n _this.props.onExiting(node);\n }\n };\n\n _this.onExited = function (node) {\n var _this$getClassNames5 = _this.getClassNames('exit'),\n doneClassName = _this$getClassNames5.doneClassName;\n\n _this.removeClasses(node, 'exit');\n\n addClass(node, doneClassName);\n\n if (_this.props.onExited) {\n _this.props.onExited(node);\n }\n };\n\n _this.getClassNames = function (type) {\n var classNames = _this.props.classNames;\n var isStringClassNames = typeof classNames === 'string';\n var prefix = isStringClassNames && classNames ? classNames + '-' : '';\n var className = isStringClassNames ? prefix + type : classNames[type];\n var activeClassName = isStringClassNames ? className + '-active' : classNames[type + 'Active'];\n var doneClassName = isStringClassNames ? className + '-done' : classNames[type + 'Done'];\n return {\n className: className,\n activeClassName: activeClassName,\n doneClassName: doneClassName\n };\n };\n\n return _this;\n }\n\n var _proto = CSSTransition.prototype;\n\n _proto.removeClasses = function removeClasses(node, type) {\n var _this$getClassNames6 = this.getClassNames(type),\n className = _this$getClassNames6.className,\n activeClassName = _this$getClassNames6.activeClassName,\n doneClassName = _this$getClassNames6.doneClassName;\n\n className && removeClass(node, className);\n activeClassName && removeClass(node, activeClassName);\n doneClassName && removeClass(node, doneClassName);\n };\n\n _proto.reflowAndAddClass = function reflowAndAddClass(node, className) {\n // This is for to force a repaint,\n // which is necessary in order to transition styles when adding a class name.\n if (className) {\n /* eslint-disable no-unused-expressions */\n node && node.scrollTop;\n /* eslint-enable no-unused-expressions */\n\n addClass(node, className);\n }\n };\n\n _proto.render = function render() {\n var props = _extends({}, this.props);\n\n delete props.classNames;\n return _react.default.createElement(_Transition.default, _extends({}, props, {\n onEnter: this.onEnter,\n onEntered: this.onEntered,\n onEntering: this.onEntering,\n onExit: this.onExit,\n onExiting: this.onExiting,\n onExited: this.onExited\n }));\n };\n\n return CSSTransition;\n}(_react.default.Component);\n\nCSSTransition.defaultProps = {\n classNames: ''\n};\nCSSTransition.propTypes = process.env.NODE_ENV !== \"production\" ? _extends({}, _Transition.default.propTypes, {\n /**\n * The animation classNames applied to the component as it enters, exits or\n * has finished the transition. A single name can be provided and it will be\n * suffixed for each stage: e.g.\n *\n * `classNames=\"fade\"` applies `fade-enter`, `fade-enter-active`,\n * `fade-enter-done`, `fade-exit`, `fade-exit-active`, `fade-exit-done`,\n * `fade-appear`, `fade-appear-active`, and `fade-appear-done`.\n *\n * **Note**: `fade-appear-done` and `fade-enter-done` will _both_ be applied.\n * This allows you to define different behavior for when appearing is done and\n * when regular entering is done, using selectors like\n * `.fade-enter-done:not(.fade-appear-done)`. For example, you could apply an\n * epic entrance animation when element first appears in the DOM using\n * [Animate.css](https://daneden.github.io/animate.css/). Otherwise you can\n * simply use `fade-enter-done` for defining both cases.\n *\n * Each individual classNames can also be specified independently like:\n *\n * ```js\n * classNames={{\n * appear: 'my-appear',\n * appearActive: 'my-active-appear',\n * appearDone: 'my-done-appear',\n * enter: 'my-enter',\n * enterActive: 'my-active-enter',\n * enterDone: 'my-done-enter',\n * exit: 'my-exit',\n * exitActive: 'my-active-exit',\n * exitDone: 'my-done-exit',\n * }}\n * ```\n *\n * If you want to set these classes using CSS Modules:\n *\n * ```js\n * import styles from './styles.css';\n * ```\n *\n * you might want to use camelCase in your CSS file, that way could simply\n * spread them instead of listing them one by one:\n *\n * ```js\n * classNames={{ ...styles }}\n * ```\n *\n * @type {string | {\n * appear?: string,\n * appearActive?: string,\n * appearDone?: string,\n * enter?: string,\n * enterActive?: string,\n * enterDone?: string,\n * exit?: string,\n * exitActive?: string,\n * exitDone?: string,\n * }}\n */\n classNames: _PropTypes.classNamesShape,\n\n /**\n * A `` callback fired immediately after the 'enter' or 'appear' class is\n * applied.\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEnter: PropTypes.func,\n\n /**\n * A `` callback fired immediately after the 'enter-active' or\n * 'appear-active' class is applied.\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEntering: PropTypes.func,\n\n /**\n * A `` callback fired immediately after the 'enter' or\n * 'appear' classes are **removed** and the `done` class is added to the DOM node.\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEntered: PropTypes.func,\n\n /**\n * A `` callback fired immediately after the 'exit' class is\n * applied.\n *\n * @type Function(node: HtmlElement)\n */\n onExit: PropTypes.func,\n\n /**\n * A `` callback fired immediately after the 'exit-active' is applied.\n *\n * @type Function(node: HtmlElement)\n */\n onExiting: PropTypes.func,\n\n /**\n * A `` callback fired immediately after the 'exit' classes\n * are **removed** and the `exit-done` class is added to the DOM node.\n *\n * @type Function(node: HtmlElement)\n */\n onExited: PropTypes.func\n}) : {};\nvar _default = CSSTransition;\nexports.default = _default;\nmodule.exports = exports[\"default\"];","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reactDom = require(\"react-dom\");\n\nvar _TransitionGroup = _interopRequireDefault(require(\"./TransitionGroup\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\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; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\n/**\n * The `` component is a specialized `Transition` component\n * that animates between two children.\n *\n * ```jsx\n * \n *

I appear first
\n *
I replace the above
\n * \n * ```\n */\nvar ReplaceTransition =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(ReplaceTransition, _React$Component);\n\n function ReplaceTransition() {\n var _this;\n\n for (var _len = arguments.length, _args = new Array(_len), _key = 0; _key < _len; _key++) {\n _args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(_args)) || this;\n\n _this.handleEnter = function () {\n for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n args[_key2] = arguments[_key2];\n }\n\n return _this.handleLifecycle('onEnter', 0, args);\n };\n\n _this.handleEntering = function () {\n for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n args[_key3] = arguments[_key3];\n }\n\n return _this.handleLifecycle('onEntering', 0, args);\n };\n\n _this.handleEntered = function () {\n for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n args[_key4] = arguments[_key4];\n }\n\n return _this.handleLifecycle('onEntered', 0, args);\n };\n\n _this.handleExit = function () {\n for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {\n args[_key5] = arguments[_key5];\n }\n\n return _this.handleLifecycle('onExit', 1, args);\n };\n\n _this.handleExiting = function () {\n for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {\n args[_key6] = arguments[_key6];\n }\n\n return _this.handleLifecycle('onExiting', 1, args);\n };\n\n _this.handleExited = function () {\n for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {\n args[_key7] = arguments[_key7];\n }\n\n return _this.handleLifecycle('onExited', 1, args);\n };\n\n return _this;\n }\n\n var _proto = ReplaceTransition.prototype;\n\n _proto.handleLifecycle = function handleLifecycle(handler, idx, originalArgs) {\n var _child$props;\n\n var children = this.props.children;\n\n var child = _react.default.Children.toArray(children)[idx];\n\n if (child.props[handler]) (_child$props = child.props)[handler].apply(_child$props, originalArgs);\n if (this.props[handler]) this.props[handler]((0, _reactDom.findDOMNode)(this));\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n children = _this$props.children,\n inProp = _this$props.in,\n props = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"in\"]);\n\n var _React$Children$toArr = _react.default.Children.toArray(children),\n first = _React$Children$toArr[0],\n second = _React$Children$toArr[1];\n\n delete props.onEnter;\n delete props.onEntering;\n delete props.onEntered;\n delete props.onExit;\n delete props.onExiting;\n delete props.onExited;\n return _react.default.createElement(_TransitionGroup.default, props, inProp ? _react.default.cloneElement(first, {\n key: 'first',\n onEnter: this.handleEnter,\n onEntering: this.handleEntering,\n onEntered: this.handleEntered\n }) : _react.default.cloneElement(second, {\n key: 'second',\n onEnter: this.handleExit,\n onEntering: this.handleExiting,\n onEntered: this.handleExited\n }));\n };\n\n return ReplaceTransition;\n}(_react.default.Component);\n\nReplaceTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n in: _propTypes.default.bool.isRequired,\n children: function children(props, propName) {\n if (_react.default.Children.count(props[propName]) !== 2) return new Error(\"\\\"\" + propName + \"\\\" must be exactly two transition components.\");\n return null;\n }\n} : {};\nvar _default = ReplaceTransition;\nexports.default = _default;\nmodule.exports = exports[\"default\"];","\"use strict\";\n\nexports.__esModule = true;\nexports.default = exports.EXITING = exports.ENTERED = exports.ENTERING = exports.EXITED = exports.UNMOUNTED = void 0;\n\nvar PropTypes = _interopRequireWildcard(require(\"prop-types\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reactDom = _interopRequireDefault(require(\"react-dom\"));\n\nvar _reactLifecyclesCompat = require(\"react-lifecycles-compat\");\n\nvar _PropTypes = require(\"./utils/PropTypes\");\n\nvar _TransitionGroupContext = _interopRequireDefault(require(\"./TransitionGroupContext\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }\n\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; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar UNMOUNTED = 'unmounted';\nexports.UNMOUNTED = UNMOUNTED;\nvar EXITED = 'exited';\nexports.EXITED = EXITED;\nvar ENTERING = 'entering';\nexports.ENTERING = ENTERING;\nvar ENTERED = 'entered';\nexports.ENTERED = ENTERED;\nvar EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n * transition: `opacity ${duration}ms ease-in-out`,\n * opacity: 0,\n * }\n *\n * const transitionStyles = {\n * entering: { opacity: 1 },\n * entered: { opacity: 1 },\n * exiting: { opacity: 0 },\n * exited: { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n * \n * {state => (\n *
\n * I'm a fade Transition!\n *
\n * )}\n *
\n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n * - `'entering'`\n * - `'entered'`\n * - `'exiting'`\n * - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n *
\n * \n * {state => (\n * // ...\n * )}\n * \n * \n *
\n * );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state\n * and stay there for 500ms (the value of `timeout`) before it finally switches\n * to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from\n * `'exiting'` to `'exited'`.\n */\n\nexports.EXITING = EXITING;\n\nvar Transition =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(Transition, _React$Component);\n\n function Transition(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n var parentGroup = context; // In the context of a TransitionGroup all enters are really appears\n\n var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n var initialStatus;\n _this.appearStatus = null;\n\n if (props.in) {\n if (appear) {\n initialStatus = EXITED;\n _this.appearStatus = ENTERING;\n } else {\n initialStatus = ENTERED;\n }\n } else {\n if (props.unmountOnExit || props.mountOnEnter) {\n initialStatus = UNMOUNTED;\n } else {\n initialStatus = EXITED;\n }\n }\n\n _this.state = {\n status: initialStatus\n };\n _this.nextCallback = null;\n return _this;\n }\n\n Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n var nextIn = _ref.in;\n\n if (nextIn && prevState.status === UNMOUNTED) {\n return {\n status: EXITED\n };\n }\n\n return null;\n }; // getSnapshotBeforeUpdate(prevProps) {\n // let nextStatus = null\n // if (prevProps !== this.props) {\n // const { status } = this.state\n // if (this.props.in) {\n // if (status !== ENTERING && status !== ENTERED) {\n // nextStatus = ENTERING\n // }\n // } else {\n // if (status === ENTERING || status === ENTERED) {\n // nextStatus = EXITING\n // }\n // }\n // }\n // return { nextStatus }\n // }\n\n\n var _proto = Transition.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.updateStatus(true, this.appearStatus);\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var nextStatus = null;\n\n if (prevProps !== this.props) {\n var status = this.state.status;\n\n if (this.props.in) {\n if (status !== ENTERING && status !== ENTERED) {\n nextStatus = ENTERING;\n }\n } else {\n if (status === ENTERING || status === ENTERED) {\n nextStatus = EXITING;\n }\n }\n }\n\n this.updateStatus(false, nextStatus);\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.cancelNextCallback();\n };\n\n _proto.getTimeouts = function getTimeouts() {\n var timeout = this.props.timeout;\n var exit, enter, appear;\n exit = enter = appear = timeout;\n\n if (timeout != null && typeof timeout !== 'number') {\n exit = timeout.exit;\n enter = timeout.enter; // TODO: remove fallback for next major\n\n appear = timeout.appear !== undefined ? timeout.appear : enter;\n }\n\n return {\n exit: exit,\n enter: enter,\n appear: appear\n };\n };\n\n _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n if (mounting === void 0) {\n mounting = false;\n }\n\n if (nextStatus !== null) {\n // nextStatus will always be ENTERING or EXITING.\n this.cancelNextCallback();\n\n var node = _reactDom.default.findDOMNode(this);\n\n if (nextStatus === ENTERING) {\n this.performEnter(node, mounting);\n } else {\n this.performExit(node);\n }\n } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n this.setState({\n status: UNMOUNTED\n });\n }\n };\n\n _proto.performEnter = function performEnter(node, mounting) {\n var _this2 = this;\n\n var enter = this.props.enter;\n var appearing = this.context ? this.context.isMounting : mounting;\n var timeouts = this.getTimeouts();\n var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED\n // if we are mounting and running this it means appear _must_ be set\n\n if (!mounting && !enter) {\n this.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(node);\n });\n return;\n }\n\n this.props.onEnter(node, appearing);\n this.safeSetState({\n status: ENTERING\n }, function () {\n _this2.props.onEntering(node, appearing);\n\n _this2.onTransitionEnd(node, enterTimeout, function () {\n _this2.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(node, appearing);\n });\n });\n });\n };\n\n _proto.performExit = function performExit(node) {\n var _this3 = this;\n\n var exit = this.props.exit;\n var timeouts = this.getTimeouts(); // no exit animation skip right to EXITED\n\n if (!exit) {\n this.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(node);\n });\n return;\n }\n\n this.props.onExit(node);\n this.safeSetState({\n status: EXITING\n }, function () {\n _this3.props.onExiting(node);\n\n _this3.onTransitionEnd(node, timeouts.exit, function () {\n _this3.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(node);\n });\n });\n });\n };\n\n _proto.cancelNextCallback = function cancelNextCallback() {\n if (this.nextCallback !== null) {\n this.nextCallback.cancel();\n this.nextCallback = null;\n }\n };\n\n _proto.safeSetState = function safeSetState(nextState, callback) {\n // This shouldn't be necessary, but there are weird race conditions with\n // setState callbacks and unmounting in testing, so always make sure that\n // we can cancel any pending setState callbacks after we unmount.\n callback = this.setNextCallback(callback);\n this.setState(nextState, callback);\n };\n\n _proto.setNextCallback = function setNextCallback(callback) {\n var _this4 = this;\n\n var active = true;\n\n this.nextCallback = function (event) {\n if (active) {\n active = false;\n _this4.nextCallback = null;\n callback(event);\n }\n };\n\n this.nextCallback.cancel = function () {\n active = false;\n };\n\n return this.nextCallback;\n };\n\n _proto.onTransitionEnd = function onTransitionEnd(node, timeout, handler) {\n this.setNextCallback(handler);\n var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;\n\n if (!node || doesNotHaveTimeoutOrListener) {\n setTimeout(this.nextCallback, 0);\n return;\n }\n\n if (this.props.addEndListener) {\n this.props.addEndListener(node, this.nextCallback);\n }\n\n if (timeout != null) {\n setTimeout(this.nextCallback, timeout);\n }\n };\n\n _proto.render = function render() {\n var status = this.state.status;\n\n if (status === UNMOUNTED) {\n return null;\n }\n\n var _this$props = this.props,\n children = _this$props.children,\n childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\"]); // filter props for Transtition\n\n\n delete childProps.in;\n delete childProps.mountOnEnter;\n delete childProps.unmountOnExit;\n delete childProps.appear;\n delete childProps.enter;\n delete childProps.exit;\n delete childProps.timeout;\n delete childProps.addEndListener;\n delete childProps.onEnter;\n delete childProps.onEntering;\n delete childProps.onEntered;\n delete childProps.onExit;\n delete childProps.onExiting;\n delete childProps.onExited;\n\n if (typeof children === 'function') {\n // allows for nested Transitions\n return _react.default.createElement(_TransitionGroupContext.default.Provider, {\n value: null\n }, children(status, childProps));\n }\n\n var child = _react.default.Children.only(children);\n\n return (// allows for nested Transitions\n _react.default.createElement(_TransitionGroupContext.default.Provider, {\n value: null\n }, _react.default.cloneElement(child, childProps))\n );\n };\n\n return Transition;\n}(_react.default.Component);\n\nTransition.contextType = _TransitionGroupContext.default;\nTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * A `function` child can be used instead of a React element. This function is\n * called with the current transition status (`'entering'`, `'entered'`,\n * `'exiting'`, `'exited'`, `'unmounted'`), which can be used to apply context\n * specific props to a component.\n *\n * ```jsx\n * \n * {state => (\n * \n * )}\n * \n * ```\n */\n children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,\n\n /**\n * Show the component; triggers the enter or exit states\n */\n in: PropTypes.bool,\n\n /**\n * By default the child component is mounted immediately along with\n * the parent `Transition` component. If you want to \"lazy mount\" the component on the\n * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay\n * mounted, even on \"exited\", unless you also specify `unmountOnExit`.\n */\n mountOnEnter: PropTypes.bool,\n\n /**\n * By default the child component stays mounted after it reaches the `'exited'` state.\n * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.\n */\n unmountOnExit: PropTypes.bool,\n\n /**\n * Normally a component is not transitioned if it is shown when the `` component mounts.\n * If you want to transition on the first mount set `appear` to `true`, and the\n * component will transition in as soon as the `` mounts.\n *\n * > Note: there are no specific \"appear\" states. `appear` only adds an additional `enter` transition.\n */\n appear: PropTypes.bool,\n\n /**\n * Enable or disable enter transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * Enable or disable exit transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * The duration of the transition, in milliseconds.\n * Required unless `addEndListener` is provided.\n *\n * You may specify a single timeout for all transitions:\n *\n * ```jsx\n * timeout={500}\n * ```\n *\n * or individually:\n *\n * ```jsx\n * timeout={{\n * appear: 500,\n * enter: 300,\n * exit: 500,\n * }}\n * ```\n *\n * - `appear` defaults to the value of `enter`\n * - `enter` defaults to `0`\n * - `exit` defaults to `0`\n *\n * @type {number | { enter?: number, exit?: number, appear?: number }}\n */\n timeout: function timeout(props) {\n var pt = _PropTypes.timeoutsShape;\n if (!props.addEndListener) pt = pt.isRequired;\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return pt.apply(void 0, [props].concat(args));\n },\n\n /**\n * Add a custom transition end trigger. Called with the transitioning\n * DOM node and a `done` callback. Allows for more fine grained transition end\n * logic. **Note:** Timeouts are still used as a fallback if provided.\n *\n * ```jsx\n * addEndListener={(node, done) => {\n * // use the css transitionend event to mark the finish of a transition\n * node.addEventListener('transitionend', done, false);\n * }}\n * ```\n */\n addEndListener: PropTypes.func,\n\n /**\n * Callback fired before the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired after the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired after the \"entered\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired before the \"exiting\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired after the \"exiting\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExiting: PropTypes.func,\n\n /**\n * Callback fired after the \"exited\" status is applied.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExited: PropTypes.func // Name the function so it is clearer in the documentation\n\n} : {};\n\nfunction noop() {}\n\nTransition.defaultProps = {\n in: false,\n mountOnEnter: false,\n unmountOnExit: false,\n appear: false,\n enter: true,\n exit: true,\n onEnter: noop,\n onEntering: noop,\n onEntered: noop,\n onExit: noop,\n onExiting: noop,\n onExited: noop\n};\nTransition.UNMOUNTED = 0;\nTransition.EXITED = 1;\nTransition.ENTERING = 2;\nTransition.ENTERED = 3;\nTransition.EXITING = 4;\n\nvar _default = (0, _reactLifecyclesCompat.polyfill)(Transition);\n\nexports.default = _default;","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reactLifecyclesCompat = require(\"react-lifecycles-compat\");\n\nvar _TransitionGroupContext = _interopRequireDefault(require(\"./TransitionGroupContext\"));\n\nvar _ChildMapping = require(\"./utils/ChildMapping\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\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; }\n\nfunction _extends() { _extends = Object.assign || 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); }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nvar values = Object.values || function (obj) {\n return Object.keys(obj).map(function (k) {\n return obj[k];\n });\n};\n\nvar defaultProps = {\n component: 'div',\n childFactory: function childFactory(child) {\n return child;\n }\n /**\n * The `` component manages a set of transition components\n * (`` and ``) in a list. Like with the transition\n * components, `` is a state machine for managing the mounting\n * and unmounting of components over time.\n *\n * Consider the example below. As items are removed or added to the TodoList the\n * `in` prop is toggled automatically by the ``.\n *\n * Note that `` does not define any animation behavior!\n * Exactly _how_ a list item animates is up to the individual transition\n * component. This means you can mix and match animations across different list\n * items.\n */\n\n};\n\nvar TransitionGroup =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(TransitionGroup, _React$Component);\n\n function TransitionGroup(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n\n var handleExited = _this.handleExited.bind(_assertThisInitialized(_assertThisInitialized(_this))); // Initial children should all be entering, dependent on appear\n\n\n _this.state = {\n contextValue: {\n isMounting: true\n },\n handleExited: handleExited,\n firstRender: true\n };\n return _this;\n }\n\n var _proto = TransitionGroup.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.mounted = true;\n this.setState({\n contextValue: {\n isMounting: false\n }\n });\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.mounted = false;\n };\n\n TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n var prevChildMapping = _ref.children,\n handleExited = _ref.handleExited,\n firstRender = _ref.firstRender;\n return {\n children: firstRender ? (0, _ChildMapping.getInitialChildMapping)(nextProps, handleExited) : (0, _ChildMapping.getNextChildMapping)(nextProps, prevChildMapping, handleExited),\n firstRender: false\n };\n };\n\n _proto.handleExited = function handleExited(child, node) {\n var currentChildMapping = (0, _ChildMapping.getChildMapping)(this.props.children);\n if (child.key in currentChildMapping) return;\n\n if (child.props.onExited) {\n child.props.onExited(node);\n }\n\n if (this.mounted) {\n this.setState(function (state) {\n var children = _extends({}, state.children);\n\n delete children[child.key];\n return {\n children: children\n };\n });\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n Component = _this$props.component,\n childFactory = _this$props.childFactory,\n props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n var contextValue = this.state.contextValue;\n var children = values(this.state.children).map(childFactory);\n delete props.appear;\n delete props.enter;\n delete props.exit;\n\n if (Component === null) {\n return _react.default.createElement(_TransitionGroupContext.default.Provider, {\n value: contextValue\n }, children);\n }\n\n return _react.default.createElement(_TransitionGroupContext.default.Provider, {\n value: contextValue\n }, _react.default.createElement(Component, props, children));\n };\n\n return TransitionGroup;\n}(_react.default.Component);\n\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * `` renders a `
` by default. You can change this\n * behavior by providing a `component` prop.\n * If you use React v16+ and would like to avoid a wrapping `
` element\n * you can pass in `component={null}`. This is useful if the wrapping div\n * borks your css styles.\n */\n component: _propTypes.default.any,\n\n /**\n * A set of `` components, that are toggled `in` and out as they\n * leave. the `` will inject specific transition props, so\n * remember to spread them through if you are wrapping the `` as\n * with our `` example.\n *\n * While this component is meant for multiple `Transition` or `CSSTransition`\n * children, sometimes you may want to have a single transition child with\n * content that you want to be transitioned out and in when you change it\n * (e.g. routes, images etc.) In that case you can change the `key` prop of\n * the transition child as you change its content, this will cause\n * `TransitionGroup` to transition the child out and back in.\n */\n children: _propTypes.default.node,\n\n /**\n * A convenience prop that enables or disables appear animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n appear: _propTypes.default.bool,\n\n /**\n * A convenience prop that enables or disables enter animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n enter: _propTypes.default.bool,\n\n /**\n * A convenience prop that enables or disables exit animations\n * for all children. Note that specifying this will override any defaults set\n * on individual children Transitions.\n */\n exit: _propTypes.default.bool,\n\n /**\n * You may need to apply reactive updates to a child as it is exiting.\n * This is generally done by using `cloneElement` however in the case of an exiting\n * child the element has already been removed and not accessible to the consumer.\n *\n * If you do need to update a child as it leaves you can provide a `childFactory`\n * to wrap every child, even the ones that are leaving.\n *\n * @type Function(child: ReactElement) -> ReactElement\n */\n childFactory: _propTypes.default.func\n} : {};\nTransitionGroup.defaultProps = defaultProps;\n\nvar _default = (0, _reactLifecyclesCompat.polyfill)(TransitionGroup);\n\nexports.default = _default;\nmodule.exports = exports[\"default\"];","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar _default = _react.default.createContext(null);\n\nexports.default = _default;\nmodule.exports = exports[\"default\"];","\"use strict\";\n\nvar _CSSTransition = _interopRequireDefault(require(\"./CSSTransition\"));\n\nvar _ReplaceTransition = _interopRequireDefault(require(\"./ReplaceTransition\"));\n\nvar _TransitionGroup = _interopRequireDefault(require(\"./TransitionGroup\"));\n\nvar _Transition = _interopRequireDefault(require(\"./Transition\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nmodule.exports = {\n Transition: _Transition.default,\n TransitionGroup: _TransitionGroup.default,\n ReplaceTransition: _ReplaceTransition.default,\n CSSTransition: _CSSTransition.default\n};","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.default = addClass;\n\nvar _hasClass = _interopRequireDefault(require(\"./hasClass\"));\n\nfunction addClass(element, className) {\n if (element.classList) element.classList.add(className);else if (!(0, _hasClass.default)(element, className)) if (typeof element.className === 'string') element.className = element.className + ' ' + className;else element.setAttribute('class', (element.className && element.className.baseVal || '') + ' ' + className);\n}\n\nmodule.exports = exports[\"default\"];","\"use strict\";\n\nexports.__esModule = true;\nexports.default = hasClass;\n\nfunction hasClass(element, className) {\n if (element.classList) return !!className && element.classList.contains(className);else return (\" \" + (element.className.baseVal || element.className) + \" \").indexOf(\" \" + className + \" \") !== -1;\n}\n\nmodule.exports = exports[\"default\"];","'use strict';\n\nfunction replaceClassName(origClass, classToRemove) {\n return origClass.replace(new RegExp('(^|\\\\s)' + classToRemove + '(?:\\\\s|$)', 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n}\n\nmodule.exports = function removeClass(element, className) {\n if (element.classList) element.classList.remove(className);else if (typeof element.className === 'string') element.className = replaceClassName(element.className, className);else element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));\n};","\"use strict\";\n\nexports.__esModule = true;\nexports.getChildMapping = getChildMapping;\nexports.mergeChildMappings = mergeChildMappings;\nexports.getInitialChildMapping = getInitialChildMapping;\nexports.getNextChildMapping = getNextChildMapping;\n\nvar _react = require(\"react\");\n\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\nfunction getChildMapping(children, mapFn) {\n var mapper = function mapper(child) {\n return mapFn && (0, _react.isValidElement)(child) ? mapFn(child) : child;\n };\n\n var result = Object.create(null);\n if (children) _react.Children.map(children, function (c) {\n return c;\n }).forEach(function (child) {\n // run the map function here instead so that the key is the computed one\n result[child.key] = mapper(child);\n });\n return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\n\nfunction mergeChildMappings(prev, next) {\n prev = prev || {};\n next = next || {};\n\n function getValueForKey(key) {\n return key in next ? next[key] : prev[key];\n } // For each key of `next`, the list of keys to insert before that key in\n // the combined list\n\n\n var nextKeysPending = Object.create(null);\n var pendingKeys = [];\n\n for (var prevKey in prev) {\n if (prevKey in next) {\n if (pendingKeys.length) {\n nextKeysPending[prevKey] = pendingKeys;\n pendingKeys = [];\n }\n } else {\n pendingKeys.push(prevKey);\n }\n }\n\n var i;\n var childMapping = {};\n\n for (var nextKey in next) {\n if (nextKeysPending[nextKey]) {\n for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n var pendingNextKey = nextKeysPending[nextKey][i];\n childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n }\n }\n\n childMapping[nextKey] = getValueForKey(nextKey);\n } // Finally, add the keys which didn't appear before any key in `next`\n\n\n for (i = 0; i < pendingKeys.length; i++) {\n childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n }\n\n return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nfunction getInitialChildMapping(props, onExited) {\n return getChildMapping(props.children, function (child) {\n return (0, _react.cloneElement)(child, {\n onExited: onExited.bind(null, child),\n in: true,\n appear: getProp(child, 'appear', props),\n enter: getProp(child, 'enter', props),\n exit: getProp(child, 'exit', props)\n });\n });\n}\n\nfunction getNextChildMapping(nextProps, prevChildMapping, onExited) {\n var nextChildMapping = getChildMapping(nextProps.children);\n var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n Object.keys(children).forEach(function (key) {\n var child = children[key];\n if (!(0, _react.isValidElement)(child)) return;\n var hasPrev = key in prevChildMapping;\n var hasNext = key in nextChildMapping;\n var prevChild = prevChildMapping[key];\n var isLeaving = (0, _react.isValidElement)(prevChild) && !prevChild.props.in; // item is new (entering)\n\n if (hasNext && (!hasPrev || isLeaving)) {\n // console.log('entering', key)\n children[key] = (0, _react.cloneElement)(child, {\n onExited: onExited.bind(null, child),\n in: true,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n } else if (!hasNext && hasPrev && !isLeaving) {\n // item is old (exiting)\n // console.log('leaving', key)\n children[key] = (0, _react.cloneElement)(child, {\n in: false\n });\n } else if (hasNext && hasPrev && (0, _react.isValidElement)(prevChild)) {\n // item hasn't changed transition states\n // copy over the last transition props;\n // console.log('unchanged', key)\n children[key] = (0, _react.cloneElement)(child, {\n onExited: onExited.bind(null, child),\n in: prevChild.props.in,\n exit: getProp(child, 'exit', nextProps),\n enter: getProp(child, 'enter', nextProps)\n });\n }\n });\n return children;\n}","\"use strict\";\n\nexports.__esModule = true;\nexports.classNamesShape = exports.timeoutsShape = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar timeoutsShape = process.env.NODE_ENV !== 'production' ? _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.shape({\n enter: _propTypes.default.number,\n exit: _propTypes.default.number,\n appear: _propTypes.default.number\n}).isRequired]) : null;\nexports.timeoutsShape = timeoutsShape;\nvar classNamesShape = process.env.NODE_ENV !== 'production' ? _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.shape({\n enter: _propTypes.default.string,\n exit: _propTypes.default.string,\n active: _propTypes.default.string\n}), _propTypes.default.shape({\n enter: _propTypes.default.string,\n enterDone: _propTypes.default.string,\n enterActive: _propTypes.default.string,\n exit: _propTypes.default.string,\n exitDone: _propTypes.default.string,\n exitActive: _propTypes.default.string\n})]) : null;\nexports.classNamesShape = classNamesShape;","/**\n * @license React\n * react-jsx-runtime.production.min.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'use strict';var f=require(\"react\"),k=Symbol.for(\"react.element\"),l=Symbol.for(\"react.fragment\"),m=Object.prototype.hasOwnProperty,n=f.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED.ReactCurrentOwner,p={key:!0,ref:!0,__self:!0,__source:!0};\nfunction q(c,a,g){var b,d={},e=null,h=null;void 0!==g&&(e=\"\"+g);void 0!==a.key&&(e=\"\"+a.key);void 0!==a.ref&&(h=a.ref);for(b in a)m.call(a,b)&&!p.hasOwnProperty(b)&&(d[b]=a[b]);if(c&&c.defaultProps)for(b in a=c.defaultProps,a)void 0===d[b]&&(d[b]=a[b]);return{$$typeof:k,type:c,key:e,ref:h,props:d,_owner:n.current}}exports.Fragment=l;exports.jsx=q;exports.jsxs=q;\n","/**\n * @license React\n * react.production.min.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'use strict';var l=Symbol.for(\"react.element\"),n=Symbol.for(\"react.portal\"),p=Symbol.for(\"react.fragment\"),q=Symbol.for(\"react.strict_mode\"),r=Symbol.for(\"react.profiler\"),t=Symbol.for(\"react.provider\"),u=Symbol.for(\"react.context\"),v=Symbol.for(\"react.forward_ref\"),w=Symbol.for(\"react.suspense\"),x=Symbol.for(\"react.memo\"),y=Symbol.for(\"react.lazy\"),z=Symbol.iterator;function A(a){if(null===a||\"object\"!==typeof a)return null;a=z&&a[z]||a[\"@@iterator\"];return\"function\"===typeof a?a:null}\nvar B={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},C=Object.assign,D={};function E(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}E.prototype.isReactComponent={};\nE.prototype.setState=function(a,b){if(\"object\"!==typeof a&&\"function\"!==typeof a&&null!=a)throw Error(\"setState(...): takes an object of state variables to update or a function which returns an object of state variables.\");this.updater.enqueueSetState(this,a,b,\"setState\")};E.prototype.forceUpdate=function(a){this.updater.enqueueForceUpdate(this,a,\"forceUpdate\")};function F(){}F.prototype=E.prototype;function G(a,b,e){this.props=a;this.context=b;this.refs=D;this.updater=e||B}var H=G.prototype=new F;\nH.constructor=G;C(H,E.prototype);H.isPureReactComponent=!0;var I=Array.isArray,J=Object.prototype.hasOwnProperty,K={current:null},L={key:!0,ref:!0,__self:!0,__source:!0};\nfunction M(a,b,e){var d,c={},k=null,h=null;if(null!=b)for(d in void 0!==b.ref&&(h=b.ref),void 0!==b.key&&(k=\"\"+b.key),b)J.call(b,d)&&!L.hasOwnProperty(d)&&(c[d]=b[d]);var g=arguments.length-2;if(1===g)c.children=e;else if(1>>1,e=a[d];if(0>>1;dg(C,c))ng(x,C)?(a[d]=x,a[n]=c,d=n):(a[d]=C,a[m]=c,d=m);else if(ng(x,c))a[d]=x,a[n]=c,d=n;else break a}}return b}\nfunction g(a,b){var c=a.sortIndex-b.sortIndex;return 0!==c?c:a.id-b.id}if(\"object\"===typeof performance&&\"function\"===typeof performance.now){var l=performance;exports.unstable_now=function(){return l.now()}}else{var p=Date,q=p.now();exports.unstable_now=function(){return p.now()-q}}var r=[],t=[],u=1,v=null,y=3,z=!1,A=!1,B=!1,D=\"function\"===typeof setTimeout?setTimeout:null,E=\"function\"===typeof clearTimeout?clearTimeout:null,F=\"undefined\"!==typeof setImmediate?setImmediate:null;\n\"undefined\"!==typeof navigator&&void 0!==navigator.scheduling&&void 0!==navigator.scheduling.isInputPending&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function G(a){for(var b=h(t);null!==b;){if(null===b.callback)k(t);else if(b.startTime<=a)k(t),b.sortIndex=b.expirationTime,f(r,b);else break;b=h(t)}}function H(a){B=!1;G(a);if(!A)if(null!==h(r))A=!0,I(J);else{var b=h(t);null!==b&&K(H,b.startTime-a)}}\nfunction J(a,b){A=!1;B&&(B=!1,E(L),L=-1);z=!0;var c=y;try{G(b);for(v=h(r);null!==v&&(!(v.expirationTime>b)||a&&!M());){var d=v.callback;if(\"function\"===typeof d){v.callback=null;y=v.priorityLevel;var e=d(v.expirationTime<=b);b=exports.unstable_now();\"function\"===typeof e?v.callback=e:v===h(r)&&k(r);G(b)}else k(r);v=h(r)}if(null!==v)var w=!0;else{var m=h(t);null!==m&&K(H,m.startTime-b);w=!1}return w}finally{v=null,y=c,z=!1}}var N=!1,O=null,L=-1,P=5,Q=-1;\nfunction M(){return exports.unstable_now()-Qa||125d?(a.sortIndex=c,f(t,a),null===h(r)&&a===h(t)&&(B?(E(L),L=-1):B=!0,K(H,c-d))):(a.sortIndex=e,f(r,a),A||z||(A=!0,I(J)));return a};\nexports.unstable_shouldYield=M;exports.unstable_wrapCallback=function(a){var b=y;return function(){var c=y;y=b;try{return a.apply(this,arguments)}finally{y=c}}};\n","'use strict';\n\nif (process.env.NODE_ENV === 'production') {\n module.exports = require('./cjs/scheduler.production.min.js');\n} else {\n module.exports = require('./cjs/scheduler.development.js');\n}\n","'use strict';\n\nvar GetIntrinsic = require('get-intrinsic');\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar gOPD = require('gopd');\n\nvar $TypeError = require('es-errors/type');\nvar $floor = GetIntrinsic('%Math.floor%');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionLength(fn, length) {\n\tif (typeof fn !== 'function') {\n\t\tthrow new $TypeError('`fn` is not a function');\n\t}\n\tif (typeof length !== 'number' || length < 0 || length > 0xFFFFFFFF || $floor(length) !== length) {\n\t\tthrow new $TypeError('`length` must be a positive 32-bit integer');\n\t}\n\n\tvar loose = arguments.length > 2 && !!arguments[2];\n\n\tvar functionLengthIsConfigurable = true;\n\tvar functionLengthIsWritable = true;\n\tif ('length' in fn && gOPD) {\n\t\tvar desc = gOPD(fn, 'length');\n\t\tif (desc && !desc.configurable) {\n\t\t\tfunctionLengthIsConfigurable = false;\n\t\t}\n\t\tif (desc && !desc.writable) {\n\t\t\tfunctionLengthIsWritable = false;\n\t\t}\n\t}\n\n\tif (functionLengthIsConfigurable || functionLengthIsWritable || !loose) {\n\t\tif (hasDescriptors) {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length, true, true);\n\t\t} else {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'length', length);\n\t\t}\n\t}\n\treturn fn;\n};\n","'use strict';\n\nvar define = require('define-data-property');\nvar hasDescriptors = require('has-property-descriptors')();\nvar functionsHaveConfigurableNames = require('functions-have-names').functionsHaveConfigurableNames();\n\nvar $TypeError = require('es-errors/type');\n\n/** @type {import('.')} */\nmodule.exports = function setFunctionName(fn, name) {\n\tif (typeof fn !== 'function') {\n\t\tthrow new $TypeError('`fn` is not a function');\n\t}\n\tvar loose = arguments.length > 2 && !!arguments[2];\n\tif (!loose || functionsHaveConfigurableNames) {\n\t\tif (hasDescriptors) {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'name', name, true, true);\n\t\t} else {\n\t\t\tdefine(/** @type {Parameters[0]} */ (fn), 'name', name);\n\t\t}\n\t}\n\treturn fn;\n};\n","/**\n * Copyright (c) 2014-present, Facebook, Inc.\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\n/**\n * Similar to invariant but only logs a warning if the condition is not met.\n * This can be used to log issues in development environments in critical\n * paths. Removing the logging code for production environments will keep the\n * same logic and follow the same code paths.\n */\n\nvar __DEV__ = process.env.NODE_ENV !== 'production';\n\nvar warning = function() {};\n\nif (__DEV__) {\n var printWarning = function printWarning(format, args) {\n var len = arguments.length;\n args = new Array(len > 1 ? len - 1 : 0);\n for (var key = 1; key < len; key++) {\n args[key - 1] = arguments[key];\n }\n var argIndex = 0;\n var message = 'Warning: ' +\n format.replace(/%s/g, function() {\n return args[argIndex++];\n });\n if (typeof console !== 'undefined') {\n console.error(message);\n }\n try {\n // --- Welcome to debugging React ---\n // This error was thrown as a convenience so that you can use this stack\n // to find the callsite that caused this warning to fire.\n throw new Error(message);\n } catch (x) {}\n }\n\n warning = function(condition, format, args) {\n var len = arguments.length;\n args = new Array(len > 2 ? len - 2 : 0);\n for (var key = 2; key < len; key++) {\n args[key - 2] = arguments[key];\n }\n if (format === undefined) {\n throw new Error(\n '`warning(condition, format, ...args)` requires a warning ' +\n 'message argument'\n );\n }\n if (!condition) {\n printWarning.apply(null, [format].concat(args));\n }\n };\n}\n\nmodule.exports = warning;\n","function _interopRequireDefault(e) {\n return e && e.__esModule ? e : {\n \"default\": e\n };\n}\nmodule.exports = _interopRequireDefault, module.exports.__esModule = true, module.exports[\"default\"] = module.exports;","/*!\n\tCopyright (c) 2018 Jed Watson.\n\tLicensed under the MIT License (MIT), see\n\thttp://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = '';\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (arg) {\n\t\t\t\tclasses = appendClass(classes, parseValue(arg));\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction parseValue (arg) {\n\t\tif (typeof arg === 'string' || typeof arg === 'number') {\n\t\t\treturn arg;\n\t\t}\n\n\t\tif (typeof arg !== 'object') {\n\t\t\treturn '';\n\t\t}\n\n\t\tif (Array.isArray(arg)) {\n\t\t\treturn classNames.apply(null, arg);\n\t\t}\n\n\t\tif (arg.toString !== Object.prototype.toString && !arg.toString.toString().includes('[native code]')) {\n\t\t\treturn arg.toString();\n\t\t}\n\n\t\tvar classes = '';\n\n\t\tfor (var key in arg) {\n\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\tclasses = appendClass(classes, key);\n\t\t\t}\n\t\t}\n\n\t\treturn classes;\n\t}\n\n\tfunction appendClass (value, newClass) {\n\t\tif (!newClass) {\n\t\t\treturn value;\n\t\t}\n\t\n\t\tif (value) {\n\t\t\treturn value + ' ' + newClass;\n\t\t}\n\t\n\t\treturn value + newClass;\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tclassNames.default = classNames;\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n","// 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](module, module.exports, __webpack_require__);\n\n\t// Return the exports of the module\n\treturn module.exports;\n}\n\n// expose the modules object (__webpack_modules__)\n__webpack_require__.m = __webpack_modules__;\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__.f = {};\n// This file contains only the entry chunk.\n// The chunk loading function for additional chunks\n__webpack_require__.e = (chunkId) => {\n\treturn Promise.all(Object.keys(__webpack_require__.f).reduce((promises, key) => {\n\t\t__webpack_require__.f[key](chunkId, promises);\n\t\treturn promises;\n\t}, []));\n};","// This function allow to reference async chunks\n__webpack_require__.u = (chunkId) => {\n\t// return url for filenames based on template\n\treturn \"static/js/\" + chunkId + \".\" + \"d855a71b\" + \".chunk.js\";\n};","// This function allow to reference async chunks\n__webpack_require__.miniCssF = (chunkId) => {\n\t// return url for filenames based on template\n\treturn undefined;\n};","__webpack_require__.g = (function() {\n\tif (typeof globalThis === 'object') return globalThis;\n\ttry {\n\t\treturn this || new Function('return this')();\n\t} catch (e) {\n\t\tif (typeof window === 'object') return window;\n\t}\n})();","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","var inProgress = {};\nvar dataWebpackPrefix = \"frontend:\";\n// loadScript function to load a script via script tag\n__webpack_require__.l = (url, done, key, chunkId) => {\n\tif(inProgress[url]) { inProgress[url].push(done); return; }\n\tvar script, needAttach;\n\tif(key !== undefined) {\n\t\tvar scripts = document.getElementsByTagName(\"script\");\n\t\tfor(var i = 0; i < scripts.length; i++) {\n\t\t\tvar s = scripts[i];\n\t\t\tif(s.getAttribute(\"src\") == url || s.getAttribute(\"data-webpack\") == dataWebpackPrefix + key) { script = s; break; }\n\t\t}\n\t}\n\tif(!script) {\n\t\tneedAttach = true;\n\t\tscript = document.createElement('script');\n\n\t\tscript.charset = 'utf-8';\n\t\tscript.timeout = 120;\n\t\tif (__webpack_require__.nc) {\n\t\t\tscript.setAttribute(\"nonce\", __webpack_require__.nc);\n\t\t}\n\t\tscript.setAttribute(\"data-webpack\", dataWebpackPrefix + key);\n\n\t\tscript.src = url;\n\t}\n\tinProgress[url] = [done];\n\tvar onScriptComplete = (prev, event) => {\n\t\t// avoid mem leaks in IE.\n\t\tscript.onerror = script.onload = null;\n\t\tclearTimeout(timeout);\n\t\tvar doneFns = inProgress[url];\n\t\tdelete inProgress[url];\n\t\tscript.parentNode && script.parentNode.removeChild(script);\n\t\tdoneFns && doneFns.forEach((fn) => (fn(event)));\n\t\tif(prev) return prev(event);\n\t}\n\tvar timeout = setTimeout(onScriptComplete.bind(null, undefined, { type: 'timeout', target: script }), 120000);\n\tscript.onerror = onScriptComplete.bind(null, script.onerror);\n\tscript.onload = onScriptComplete.bind(null, script.onload);\n\tneedAttach && document.head.appendChild(script);\n};","// 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};","__webpack_require__.p = \"/\";","// no baseURI\n\n// object to store loaded and loading chunks\n// undefined = chunk not loaded, null = chunk preloaded/prefetched\n// [resolve, reject, Promise] = chunk loading, 0 = chunk loaded\nvar installedChunks = {\n\t792: 0\n};\n\n__webpack_require__.f.j = (chunkId, promises) => {\n\t\t// JSONP chunk loading for javascript\n\t\tvar installedChunkData = __webpack_require__.o(installedChunks, chunkId) ? installedChunks[chunkId] : undefined;\n\t\tif(installedChunkData !== 0) { // 0 means \"already installed\".\n\n\t\t\t// a Promise means \"currently loading\".\n\t\t\tif(installedChunkData) {\n\t\t\t\tpromises.push(installedChunkData[2]);\n\t\t\t} else {\n\t\t\t\tif(true) { // all chunks have JS\n\t\t\t\t\t// setup Promise in chunk cache\n\t\t\t\t\tvar promise = new Promise((resolve, reject) => (installedChunkData = installedChunks[chunkId] = [resolve, reject]));\n\t\t\t\t\tpromises.push(installedChunkData[2] = promise);\n\n\t\t\t\t\t// start chunk loading\n\t\t\t\t\tvar url = __webpack_require__.p + __webpack_require__.u(chunkId);\n\t\t\t\t\t// create error before stack unwound to get useful stacktrace later\n\t\t\t\t\tvar error = new Error();\n\t\t\t\t\tvar loadingEnded = (event) => {\n\t\t\t\t\t\tif(__webpack_require__.o(installedChunks, chunkId)) {\n\t\t\t\t\t\t\tinstalledChunkData = installedChunks[chunkId];\n\t\t\t\t\t\t\tif(installedChunkData !== 0) installedChunks[chunkId] = undefined;\n\t\t\t\t\t\t\tif(installedChunkData) {\n\t\t\t\t\t\t\t\tvar errorType = event && (event.type === 'load' ? 'missing' : event.type);\n\t\t\t\t\t\t\t\tvar realSrc = event && event.target && event.target.src;\n\t\t\t\t\t\t\t\terror.message = 'Loading chunk ' + chunkId + ' failed.\\n(' + errorType + ': ' + realSrc + ')';\n\t\t\t\t\t\t\t\terror.name = 'ChunkLoadError';\n\t\t\t\t\t\t\t\terror.type = errorType;\n\t\t\t\t\t\t\t\terror.request = realSrc;\n\t\t\t\t\t\t\t\tinstalledChunkData[1](error);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t};\n\t\t\t\t\t__webpack_require__.l(url, loadingEnded, \"chunk-\" + chunkId, chunkId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n};\n\n// no prefetching\n\n// no preloaded\n\n// no HMR\n\n// no HMR manifest\n\n// no on chunks loaded\n\n// install a JSONP callback for chunk loading\nvar webpackJsonpCallback = (parentChunkLoadingFunction, data) => {\n\tvar chunkIds = data[0];\n\tvar moreModules = data[1];\n\tvar runtime = data[2];\n\t// add \"moreModules\" to the modules object,\n\t// then flag all \"chunkIds\" as loaded and fire callback\n\tvar moduleId, chunkId, i = 0;\n\tif(chunkIds.some((id) => (installedChunks[id] !== 0))) {\n\t\tfor(moduleId in moreModules) {\n\t\t\tif(__webpack_require__.o(moreModules, moduleId)) {\n\t\t\t\t__webpack_require__.m[moduleId] = moreModules[moduleId];\n\t\t\t}\n\t\t}\n\t\tif(runtime) var result = runtime(__webpack_require__);\n\t}\n\tif(parentChunkLoadingFunction) parentChunkLoadingFunction(data);\n\tfor(;i < chunkIds.length; i++) {\n\t\tchunkId = chunkIds[i];\n\t\tif(__webpack_require__.o(installedChunks, chunkId) && installedChunks[chunkId]) {\n\t\t\tinstalledChunks[chunkId][0]();\n\t\t}\n\t\tinstalledChunks[chunkId] = 0;\n\t}\n\n}\n\nvar chunkLoadingGlobal = self[\"webpackChunkfrontend\"] = self[\"webpackChunkfrontend\"] || [];\nchunkLoadingGlobal.forEach(webpackJsonpCallback.bind(null, 0));\nchunkLoadingGlobal.push = webpackJsonpCallback.bind(null, chunkLoadingGlobal.push.bind(chunkLoadingGlobal));","const reportWebVitals = onPerfEntry => {\n if (onPerfEntry && onPerfEntry instanceof Function) {\n import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => {\n getCLS(onPerfEntry);\n getFID(onPerfEntry);\n getFCP(onPerfEntry);\n getLCP(onPerfEntry);\n getTTFB(onPerfEntry);\n });\n }\n};\n\nexport default reportWebVitals;\n","function _setPrototypeOf(t, e) {\n return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {\n return t.__proto__ = e, t;\n }, _setPrototypeOf(t, e);\n}\nexport { _setPrototypeOf as default };","import setPrototypeOf from \"./setPrototypeOf.js\";\nfunction _inheritsLoose(t, o) {\n t.prototype = Object.create(o.prototype), t.prototype.constructor = t, setPrototypeOf(t, o);\n}\nexport { _inheritsLoose as default };","function _extends() {\n return _extends = Object.assign ? Object.assign.bind() : function (n) {\n for (var e = 1; e < arguments.length; e++) {\n var t = arguments[e];\n for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]);\n }\n return n;\n }, _extends.apply(null, arguments);\n}\nexport { _extends as default };","function isAbsolute(pathname) {\n return pathname.charAt(0) === '/';\n}\n\n// About 1.5x faster than the two-arg version of Array#splice()\nfunction spliceOne(list, index) {\n for (var i = index, k = i + 1, n = list.length; k < n; i += 1, k += 1) {\n list[i] = list[k];\n }\n\n list.pop();\n}\n\n// This implementation is based heavily on node's url.parse\nfunction resolvePathname(to, from) {\n if (from === undefined) from = '';\n\n var toParts = (to && to.split('/')) || [];\n var fromParts = (from && from.split('/')) || [];\n\n var isToAbs = to && isAbsolute(to);\n var isFromAbs = from && isAbsolute(from);\n var mustEndAbs = isToAbs || isFromAbs;\n\n if (to && isAbsolute(to)) {\n // to is absolute\n fromParts = toParts;\n } else if (toParts.length) {\n // to is relative, drop the filename\n fromParts.pop();\n fromParts = fromParts.concat(toParts);\n }\n\n if (!fromParts.length) return '/';\n\n var hasTrailingSlash;\n if (fromParts.length) {\n var last = fromParts[fromParts.length - 1];\n hasTrailingSlash = last === '.' || last === '..' || last === '';\n } else {\n hasTrailingSlash = false;\n }\n\n var up = 0;\n for (var i = fromParts.length; i >= 0; i--) {\n var part = fromParts[i];\n\n if (part === '.') {\n spliceOne(fromParts, i);\n } else if (part === '..') {\n spliceOne(fromParts, i);\n up++;\n } else if (up) {\n spliceOne(fromParts, i);\n up--;\n }\n }\n\n if (!mustEndAbs) for (; up--; up) fromParts.unshift('..');\n\n if (\n mustEndAbs &&\n fromParts[0] !== '' &&\n (!fromParts[0] || !isAbsolute(fromParts[0]))\n )\n fromParts.unshift('');\n\n var result = fromParts.join('/');\n\n if (hasTrailingSlash && result.substr(-1) !== '/') result += '/';\n\n return result;\n}\n\nexport default resolvePathname;\n","var isProduction = process.env.NODE_ENV === 'production';\nvar prefix = 'Invariant failed';\nfunction invariant(condition, message) {\n if (condition) {\n return;\n }\n if (isProduction) {\n throw new Error(prefix);\n }\n var provided = typeof message === 'function' ? message() : message;\n var value = provided ? \"\".concat(prefix, \": \").concat(provided) : prefix;\n throw new Error(value);\n}\n\nexport { invariant as default };\n","import _extends from '@babel/runtime/helpers/esm/extends';\nimport resolvePathname from 'resolve-pathname';\nimport valueEqual from 'value-equal';\nimport warning from 'tiny-warning';\nimport invariant from 'tiny-invariant';\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === '/' ? path : '/' + path;\n}\nfunction stripLeadingSlash(path) {\n return path.charAt(0) === '/' ? path.substr(1) : path;\n}\nfunction hasBasename(path, prefix) {\n return path.toLowerCase().indexOf(prefix.toLowerCase()) === 0 && '/?#'.indexOf(path.charAt(prefix.length)) !== -1;\n}\nfunction stripBasename(path, prefix) {\n return hasBasename(path, prefix) ? path.substr(prefix.length) : path;\n}\nfunction stripTrailingSlash(path) {\n return path.charAt(path.length - 1) === '/' ? path.slice(0, -1) : path;\n}\nfunction parsePath(path) {\n var pathname = path || '/';\n var search = '';\n var hash = '';\n var hashIndex = pathname.indexOf('#');\n\n if (hashIndex !== -1) {\n hash = pathname.substr(hashIndex);\n pathname = pathname.substr(0, hashIndex);\n }\n\n var searchIndex = pathname.indexOf('?');\n\n if (searchIndex !== -1) {\n search = pathname.substr(searchIndex);\n pathname = pathname.substr(0, searchIndex);\n }\n\n return {\n pathname: pathname,\n search: search === '?' ? '' : search,\n hash: hash === '#' ? '' : hash\n };\n}\nfunction createPath(location) {\n var pathname = location.pathname,\n search = location.search,\n hash = location.hash;\n var path = pathname || '/';\n if (search && search !== '?') path += search.charAt(0) === '?' ? search : \"?\" + search;\n if (hash && hash !== '#') path += hash.charAt(0) === '#' ? hash : \"#\" + hash;\n return path;\n}\n\nfunction createLocation(path, state, key, currentLocation) {\n var location;\n\n if (typeof path === 'string') {\n // Two-arg form: push(path, state)\n location = parsePath(path);\n location.state = state;\n } else {\n // One-arg form: push(location)\n location = _extends({}, path);\n if (location.pathname === undefined) location.pathname = '';\n\n if (location.search) {\n if (location.search.charAt(0) !== '?') location.search = '?' + location.search;\n } else {\n location.search = '';\n }\n\n if (location.hash) {\n if (location.hash.charAt(0) !== '#') location.hash = '#' + location.hash;\n } else {\n location.hash = '';\n }\n\n if (state !== undefined && location.state === undefined) location.state = state;\n }\n\n try {\n location.pathname = decodeURI(location.pathname);\n } catch (e) {\n if (e instanceof URIError) {\n throw new URIError('Pathname \"' + location.pathname + '\" could not be decoded. ' + 'This is likely caused by an invalid percent-encoding.');\n } else {\n throw e;\n }\n }\n\n if (key) location.key = key;\n\n if (currentLocation) {\n // Resolve incomplete/relative pathname relative to current location.\n if (!location.pathname) {\n location.pathname = currentLocation.pathname;\n } else if (location.pathname.charAt(0) !== '/') {\n location.pathname = resolvePathname(location.pathname, currentLocation.pathname);\n }\n } else {\n // When there is no prior location and pathname is empty, set it to /\n if (!location.pathname) {\n location.pathname = '/';\n }\n }\n\n return location;\n}\nfunction locationsAreEqual(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash && a.key === b.key && valueEqual(a.state, b.state);\n}\n\nfunction createTransitionManager() {\n var prompt = null;\n\n function setPrompt(nextPrompt) {\n process.env.NODE_ENV !== \"production\" ? warning(prompt == null, 'A history supports only one prompt at a time') : void 0;\n prompt = nextPrompt;\n return function () {\n if (prompt === nextPrompt) prompt = null;\n };\n }\n\n function confirmTransitionTo(location, action, getUserConfirmation, callback) {\n // TODO: If another transition starts while we're still confirming\n // the previous one, we may end up in a weird state. Figure out the\n // best way to handle this.\n if (prompt != null) {\n var result = typeof prompt === 'function' ? prompt(location, action) : prompt;\n\n if (typeof result === 'string') {\n if (typeof getUserConfirmation === 'function') {\n getUserConfirmation(result, callback);\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'A history needs a getUserConfirmation function in order to use a prompt message') : void 0;\n callback(true);\n }\n } else {\n // Return false from a transition hook to cancel the transition.\n callback(result !== false);\n }\n } else {\n callback(true);\n }\n }\n\n var listeners = [];\n\n function appendListener(fn) {\n var isActive = true;\n\n function listener() {\n if (isActive) fn.apply(void 0, arguments);\n }\n\n listeners.push(listener);\n return function () {\n isActive = false;\n listeners = listeners.filter(function (item) {\n return item !== listener;\n });\n };\n }\n\n function notifyListeners() {\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n listeners.forEach(function (listener) {\n return listener.apply(void 0, args);\n });\n }\n\n return {\n setPrompt: setPrompt,\n confirmTransitionTo: confirmTransitionTo,\n appendListener: appendListener,\n notifyListeners: notifyListeners\n };\n}\n\nvar canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nfunction getConfirmation(message, callback) {\n callback(window.confirm(message)); // eslint-disable-line no-alert\n}\n/**\n * Returns true if the HTML5 history API is supported. Taken from Modernizr.\n *\n * https://github.com/Modernizr/Modernizr/blob/master/LICENSE\n * https://github.com/Modernizr/Modernizr/blob/master/feature-detects/history.js\n * changed to avoid false negatives for Windows Phones: https://github.com/reactjs/react-router/issues/586\n */\n\nfunction supportsHistory() {\n var ua = window.navigator.userAgent;\n if ((ua.indexOf('Android 2.') !== -1 || ua.indexOf('Android 4.0') !== -1) && ua.indexOf('Mobile Safari') !== -1 && ua.indexOf('Chrome') === -1 && ua.indexOf('Windows Phone') === -1) return false;\n return window.history && 'pushState' in window.history;\n}\n/**\n * Returns true if browser fires popstate on hash change.\n * IE10 and IE11 do not.\n */\n\nfunction supportsPopStateOnHashChange() {\n return window.navigator.userAgent.indexOf('Trident') === -1;\n}\n/**\n * Returns false if using go(n) with hash history causes a full page reload.\n */\n\nfunction supportsGoWithoutReloadUsingHash() {\n return window.navigator.userAgent.indexOf('Firefox') === -1;\n}\n/**\n * Returns true if a given popstate event is an extraneous WebKit event.\n * Accounts for the fact that Chrome on iOS fires real popstate events\n * containing undefined state when pressing the back button.\n */\n\nfunction isExtraneousPopstateEvent(event) {\n return event.state === undefined && navigator.userAgent.indexOf('CriOS') === -1;\n}\n\nvar PopStateEvent = 'popstate';\nvar HashChangeEvent = 'hashchange';\n\nfunction getHistoryState() {\n try {\n return window.history.state || {};\n } catch (e) {\n // IE 11 sometimes throws when accessing window.history.state\n // See https://github.com/ReactTraining/history/pull/289\n return {};\n }\n}\n/**\n * Creates a history object that uses the HTML5 history API including\n * pushState, replaceState, and the popstate event.\n */\n\n\nfunction createBrowserHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Browser history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canUseHistory = supportsHistory();\n var needsHashChangeListener = !supportsPopStateOnHashChange();\n var _props = props,\n _props$forceRefresh = _props.forceRefresh,\n forceRefresh = _props$forceRefresh === void 0 ? false : _props$forceRefresh,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n\n function getDOMLocation(historyState) {\n var _ref = historyState || {},\n key = _ref.key,\n state = _ref.state;\n\n var _window$location = window.location,\n pathname = _window$location.pathname,\n search = _window$location.search,\n hash = _window$location.hash;\n var path = pathname + search + hash;\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path, state, key);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function handlePopState(event) {\n // Ignore extraneous popstate events in WebKit.\n if (isExtraneousPopstateEvent(event)) return;\n handlePop(getDOMLocation(event.state));\n }\n\n function handleHashChange() {\n handlePop(getDOMLocation(getHistoryState()));\n }\n\n var forceNextPop = false;\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of keys we've seen in sessionStorage.\n // Instead, we just default to 0 for keys we don't know.\n\n var toIndex = allKeys.indexOf(toLocation.key);\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allKeys.indexOf(fromLocation.key);\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n }\n\n var initialLocation = getDOMLocation(getHistoryState());\n var allKeys = [initialLocation.key]; // Public interface\n\n function createHref(location) {\n return basename + createPath(location);\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.pushState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.href = href;\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n var nextKeys = allKeys.slice(0, prevIndex + 1);\n nextKeys.push(location.key);\n allKeys = nextKeys;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot push state in browsers that do not support HTML5 history') : void 0;\n window.location.href = href;\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var href = createHref(location);\n var key = location.key,\n state = location.state;\n\n if (canUseHistory) {\n globalHistory.replaceState({\n key: key,\n state: state\n }, null, href);\n\n if (forceRefresh) {\n window.location.replace(href);\n } else {\n var prevIndex = allKeys.indexOf(history.location.key);\n if (prevIndex !== -1) allKeys[prevIndex] = location.key;\n setState({\n action: action,\n location: location\n });\n }\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Browser history cannot replace state in browsers that do not support HTML5 history') : void 0;\n window.location.replace(href);\n }\n });\n }\n\n function go(n) {\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.addEventListener(HashChangeEvent, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(PopStateEvent, handlePopState);\n if (needsHashChangeListener) window.removeEventListener(HashChangeEvent, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nvar HashChangeEvent$1 = 'hashchange';\nvar HashPathCoders = {\n hashbang: {\n encodePath: function encodePath(path) {\n return path.charAt(0) === '!' ? path : '!/' + stripLeadingSlash(path);\n },\n decodePath: function decodePath(path) {\n return path.charAt(0) === '!' ? path.substr(1) : path;\n }\n },\n noslash: {\n encodePath: stripLeadingSlash,\n decodePath: addLeadingSlash\n },\n slash: {\n encodePath: addLeadingSlash,\n decodePath: addLeadingSlash\n }\n};\n\nfunction stripHash(url) {\n var hashIndex = url.indexOf('#');\n return hashIndex === -1 ? url : url.slice(0, hashIndex);\n}\n\nfunction getHashPath() {\n // We can't use window.location.hash here because it's not\n // consistent across browsers - Firefox will pre-decode it!\n var href = window.location.href;\n var hashIndex = href.indexOf('#');\n return hashIndex === -1 ? '' : href.substring(hashIndex + 1);\n}\n\nfunction pushHashPath(path) {\n window.location.hash = path;\n}\n\nfunction replaceHashPath(path) {\n window.location.replace(stripHash(window.location.href) + '#' + path);\n}\n\nfunction createHashHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n !canUseDOM ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Hash history needs a DOM') : invariant(false) : void 0;\n var globalHistory = window.history;\n var canGoWithoutReload = supportsGoWithoutReloadUsingHash();\n var _props = props,\n _props$getUserConfirm = _props.getUserConfirmation,\n getUserConfirmation = _props$getUserConfirm === void 0 ? getConfirmation : _props$getUserConfirm,\n _props$hashType = _props.hashType,\n hashType = _props$hashType === void 0 ? 'slash' : _props$hashType;\n var basename = props.basename ? stripTrailingSlash(addLeadingSlash(props.basename)) : '';\n var _HashPathCoders$hashT = HashPathCoders[hashType],\n encodePath = _HashPathCoders$hashT.encodePath,\n decodePath = _HashPathCoders$hashT.decodePath;\n\n function getDOMLocation() {\n var path = decodePath(getHashPath());\n process.env.NODE_ENV !== \"production\" ? warning(!basename || hasBasename(path, basename), 'You are attempting to use a basename on a page whose URL path does not begin ' + 'with the basename. Expected path \"' + path + '\" to begin with \"' + basename + '\".') : void 0;\n if (basename) path = stripBasename(path, basename);\n return createLocation(path);\n }\n\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = globalHistory.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n var forceNextPop = false;\n var ignorePath = null;\n\n function locationsAreEqual$$1(a, b) {\n return a.pathname === b.pathname && a.search === b.search && a.hash === b.hash;\n }\n\n function handleHashChange() {\n var path = getHashPath();\n var encodedPath = encodePath(path);\n\n if (path !== encodedPath) {\n // Ensure we always have a properly-encoded hash.\n replaceHashPath(encodedPath);\n } else {\n var location = getDOMLocation();\n var prevLocation = history.location;\n if (!forceNextPop && locationsAreEqual$$1(prevLocation, location)) return; // A hashchange doesn't always == location change.\n\n if (ignorePath === createPath(location)) return; // Ignore this change; we already setState in push/replace.\n\n ignorePath = null;\n handlePop(location);\n }\n }\n\n function handlePop(location) {\n if (forceNextPop) {\n forceNextPop = false;\n setState();\n } else {\n var action = 'POP';\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location\n });\n } else {\n revertPop(location);\n }\n });\n }\n }\n\n function revertPop(fromLocation) {\n var toLocation = history.location; // TODO: We could probably make this more reliable by\n // keeping a list of paths we've seen in sessionStorage.\n // Instead, we just default to 0 for paths we don't know.\n\n var toIndex = allPaths.lastIndexOf(createPath(toLocation));\n if (toIndex === -1) toIndex = 0;\n var fromIndex = allPaths.lastIndexOf(createPath(fromLocation));\n if (fromIndex === -1) fromIndex = 0;\n var delta = toIndex - fromIndex;\n\n if (delta) {\n forceNextPop = true;\n go(delta);\n }\n } // Ensure the hash is encoded properly before doing anything else.\n\n\n var path = getHashPath();\n var encodedPath = encodePath(path);\n if (path !== encodedPath) replaceHashPath(encodedPath);\n var initialLocation = getDOMLocation();\n var allPaths = [createPath(initialLocation)]; // Public interface\n\n function createHref(location) {\n var baseTag = document.querySelector('base');\n var href = '';\n\n if (baseTag && baseTag.getAttribute('href')) {\n href = stripHash(window.location.href);\n }\n\n return href + '#' + encodePath(basename + createPath(location));\n }\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot push state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a PUSH, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n pushHashPath(encodedPath);\n var prevIndex = allPaths.lastIndexOf(createPath(history.location));\n var nextPaths = allPaths.slice(0, prevIndex + 1);\n nextPaths.push(path);\n allPaths = nextPaths;\n setState({\n action: action,\n location: location\n });\n } else {\n process.env.NODE_ENV !== \"production\" ? warning(false, 'Hash history cannot PUSH the same path; a new entry will not be added to the history stack') : void 0;\n setState();\n }\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(state === undefined, 'Hash history cannot replace state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, undefined, undefined, history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var path = createPath(location);\n var encodedPath = encodePath(basename + path);\n var hashChanged = getHashPath() !== encodedPath;\n\n if (hashChanged) {\n // We cannot tell if a hashchange was caused by a REPLACE, so we'd\n // rather setState here and ignore the hashchange. The caveat here\n // is that other hash histories in the page will consider it a POP.\n ignorePath = path;\n replaceHashPath(encodedPath);\n }\n\n var prevIndex = allPaths.indexOf(createPath(history.location));\n if (prevIndex !== -1) allPaths[prevIndex] = path;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n process.env.NODE_ENV !== \"production\" ? warning(canGoWithoutReload, 'Hash history go(n) causes a full page reload in this browser') : void 0;\n globalHistory.go(n);\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n var listenerCount = 0;\n\n function checkDOMListeners(delta) {\n listenerCount += delta;\n\n if (listenerCount === 1 && delta === 1) {\n window.addEventListener(HashChangeEvent$1, handleHashChange);\n } else if (listenerCount === 0) {\n window.removeEventListener(HashChangeEvent$1, handleHashChange);\n }\n }\n\n var isBlocked = false;\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n var unblock = transitionManager.setPrompt(prompt);\n\n if (!isBlocked) {\n checkDOMListeners(1);\n isBlocked = true;\n }\n\n return function () {\n if (isBlocked) {\n isBlocked = false;\n checkDOMListeners(-1);\n }\n\n return unblock();\n };\n }\n\n function listen(listener) {\n var unlisten = transitionManager.appendListener(listener);\n checkDOMListeners(1);\n return function () {\n checkDOMListeners(-1);\n unlisten();\n };\n }\n\n var history = {\n length: globalHistory.length,\n action: 'POP',\n location: initialLocation,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n block: block,\n listen: listen\n };\n return history;\n}\n\nfunction clamp(n, lowerBound, upperBound) {\n return Math.min(Math.max(n, lowerBound), upperBound);\n}\n/**\n * Creates a history object that stores locations in memory.\n */\n\n\nfunction createMemoryHistory(props) {\n if (props === void 0) {\n props = {};\n }\n\n var _props = props,\n getUserConfirmation = _props.getUserConfirmation,\n _props$initialEntries = _props.initialEntries,\n initialEntries = _props$initialEntries === void 0 ? ['/'] : _props$initialEntries,\n _props$initialIndex = _props.initialIndex,\n initialIndex = _props$initialIndex === void 0 ? 0 : _props$initialIndex,\n _props$keyLength = _props.keyLength,\n keyLength = _props$keyLength === void 0 ? 6 : _props$keyLength;\n var transitionManager = createTransitionManager();\n\n function setState(nextState) {\n _extends(history, nextState);\n\n history.length = history.entries.length;\n transitionManager.notifyListeners(history.location, history.action);\n }\n\n function createKey() {\n return Math.random().toString(36).substr(2, keyLength);\n }\n\n var index = clamp(initialIndex, 0, initialEntries.length - 1);\n var entries = initialEntries.map(function (entry) {\n return typeof entry === 'string' ? createLocation(entry, undefined, createKey()) : createLocation(entry, undefined, entry.key || createKey());\n }); // Public interface\n\n var createHref = createPath;\n\n function push(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to push when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'PUSH';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n var prevIndex = history.index;\n var nextIndex = prevIndex + 1;\n var nextEntries = history.entries.slice(0);\n\n if (nextEntries.length > nextIndex) {\n nextEntries.splice(nextIndex, nextEntries.length - nextIndex, location);\n } else {\n nextEntries.push(location);\n }\n\n setState({\n action: action,\n location: location,\n index: nextIndex,\n entries: nextEntries\n });\n });\n }\n\n function replace(path, state) {\n process.env.NODE_ENV !== \"production\" ? warning(!(typeof path === 'object' && path.state !== undefined && state !== undefined), 'You should avoid providing a 2nd state argument to replace when the 1st ' + 'argument is a location-like object that already has state; it is ignored') : void 0;\n var action = 'REPLACE';\n var location = createLocation(path, state, createKey(), history.location);\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (!ok) return;\n history.entries[history.index] = location;\n setState({\n action: action,\n location: location\n });\n });\n }\n\n function go(n) {\n var nextIndex = clamp(history.index + n, 0, history.entries.length - 1);\n var action = 'POP';\n var location = history.entries[nextIndex];\n transitionManager.confirmTransitionTo(location, action, getUserConfirmation, function (ok) {\n if (ok) {\n setState({\n action: action,\n location: location,\n index: nextIndex\n });\n } else {\n // Mimic the behavior of DOM histories by\n // causing a render after a cancelled POP.\n setState();\n }\n });\n }\n\n function goBack() {\n go(-1);\n }\n\n function goForward() {\n go(1);\n }\n\n function canGo(n) {\n var nextIndex = history.index + n;\n return nextIndex >= 0 && nextIndex < history.entries.length;\n }\n\n function block(prompt) {\n if (prompt === void 0) {\n prompt = false;\n }\n\n return transitionManager.setPrompt(prompt);\n }\n\n function listen(listener) {\n return transitionManager.appendListener(listener);\n }\n\n var history = {\n length: entries.length,\n action: 'POP',\n location: entries[index],\n index: index,\n entries: entries,\n createHref: createHref,\n push: push,\n replace: replace,\n go: go,\n goBack: goBack,\n goForward: goForward,\n canGo: canGo,\n block: block,\n listen: listen\n };\n return history;\n}\n\nexport { createBrowserHistory, createHashHistory, createMemoryHistory, createLocation, locationsAreEqual, parsePath, createPath };\n","function _objectWithoutPropertiesLoose(r, e) {\n if (null == r) return {};\n var t = {};\n for (var n in r) if ({}.hasOwnProperty.call(r, n)) {\n if (e.includes(n)) continue;\n t[n] = r[n];\n }\n return t;\n}\nexport { _objectWithoutPropertiesLoose as default };","// MIT License\n// Copyright (c) 2019-present StringEpsilon \n// Copyright (c) 2017-2019 James Kyle \n// https://github.com/StringEpsilon/mini-create-react-context\nimport React from \"react\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\nconst MAX_SIGNED_31_BIT_INT = 1073741823;\n\nconst commonjsGlobal =\n typeof globalThis !== \"undefined\" // 'global proper'\n ? // eslint-disable-next-line no-undef\n globalThis\n : typeof window !== \"undefined\"\n ? window // Browser\n : typeof global !== \"undefined\"\n ? global // node.js\n : {};\n\nfunction getUniqueId() {\n let key = \"__global_unique_id__\";\n return (commonjsGlobal[key] = (commonjsGlobal[key] || 0) + 1);\n}\n\n// Inlined Object.is polyfill.\n// https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is\nfunction objectIs(x, y) {\n if (x === y) {\n return x !== 0 || 1 / x === 1 / y;\n } else {\n // eslint-disable-next-line no-self-compare\n return x !== x && y !== y;\n }\n}\n\nfunction createEventEmitter(value) {\n let handlers = [];\n return {\n on(handler) {\n handlers.push(handler);\n },\n\n off(handler) {\n handlers = handlers.filter(h => h !== handler);\n },\n\n get() {\n return value;\n },\n\n set(newValue, changedBits) {\n value = newValue;\n handlers.forEach(handler => handler(value, changedBits));\n }\n };\n}\n\nfunction onlyChild(children) {\n return Array.isArray(children) ? children[0] : children;\n}\n\nexport default function createReactContext(defaultValue, calculateChangedBits) {\n const contextProp = \"__create-react-context-\" + getUniqueId() + \"__\";\n\n class Provider extends React.Component {\n emitter = createEventEmitter(this.props.value);\n\n static childContextTypes = {\n [contextProp]: PropTypes.object.isRequired\n };\n\n getChildContext() {\n return {\n [contextProp]: this.emitter\n };\n }\n\n componentWillReceiveProps(nextProps) {\n if (this.props.value !== nextProps.value) {\n let oldValue = this.props.value;\n let newValue = nextProps.value;\n let changedBits;\n\n if (objectIs(oldValue, newValue)) {\n changedBits = 0; // No change\n } else {\n changedBits =\n typeof calculateChangedBits === \"function\"\n ? calculateChangedBits(oldValue, newValue)\n : MAX_SIGNED_31_BIT_INT;\n if (process.env.NODE_ENV !== \"production\") {\n warning(\n (changedBits & MAX_SIGNED_31_BIT_INT) === changedBits,\n \"calculateChangedBits: Expected the return value to be a \" +\n \"31-bit integer. Instead received: \" +\n changedBits\n );\n }\n\n changedBits |= 0;\n\n if (changedBits !== 0) {\n this.emitter.set(nextProps.value, changedBits);\n }\n }\n }\n }\n\n render() {\n return this.props.children;\n }\n }\n\n class Consumer extends React.Component {\n static contextTypes = {\n [contextProp]: PropTypes.object\n };\n\n observedBits;\n\n state = {\n value: this.getValue()\n };\n\n componentWillReceiveProps(nextProps) {\n let { observedBits } = nextProps;\n this.observedBits =\n observedBits === undefined || observedBits === null\n ? MAX_SIGNED_31_BIT_INT // Subscribe to all changes by default\n : observedBits;\n }\n\n componentDidMount() {\n if (this.context[contextProp]) {\n this.context[contextProp].on(this.onUpdate);\n }\n let { observedBits } = this.props;\n this.observedBits =\n observedBits === undefined || observedBits === null\n ? MAX_SIGNED_31_BIT_INT // Subscribe to all changes by default\n : observedBits;\n }\n\n componentWillUnmount() {\n if (this.context[contextProp]) {\n this.context[contextProp].off(this.onUpdate);\n }\n }\n\n getValue() {\n if (this.context[contextProp]) {\n return this.context[contextProp].get();\n } else {\n return defaultValue;\n }\n }\n\n onUpdate = (newValue, changedBits) => {\n const observedBits = this.observedBits | 0;\n if ((observedBits & changedBits) !== 0) {\n this.setState({ value: this.getValue() });\n }\n };\n\n render() {\n return onlyChild(this.props.children)(this.state.value);\n }\n }\n\n return {\n Provider,\n Consumer\n };\n}\n","// MIT License\n// Copyright (c) 2019-present StringEpsilon \n// Copyright (c) 2017-2019 James Kyle \n// https://github.com/StringEpsilon/mini-create-react-context\nimport React from \"react\";\nimport createReactContext from \"./miniCreateReactContext\";\n\nexport default React.createContext || createReactContext;\n","// TODO: Replace with React.createContext once we can assume React 16+\nimport createContext from \"./createContext\";\n\nconst createNamedContext = name => {\n const context = createContext();\n context.displayName = name;\n\n return context;\n};\n\nexport default createNamedContext;\n","import createNamedContext from \"./createNamedContext\";\n\nconst historyContext = /*#__PURE__*/ createNamedContext(\"Router-History\");\nexport default historyContext;\n","import createNamedContext from \"./createNamedContext\";\n\nconst context = /*#__PURE__*/ createNamedContext(\"Router\");\nexport default context;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\nimport HistoryContext from \"./HistoryContext.js\";\nimport RouterContext from \"./RouterContext.js\";\n\n/**\n * The public API for putting history on context.\n */\nclass Router extends React.Component {\n static computeRootMatch(pathname) {\n return { path: \"/\", url: \"/\", params: {}, isExact: pathname === \"/\" };\n }\n\n constructor(props) {\n super(props);\n\n this.state = {\n location: props.history.location\n };\n\n // This is a bit of a hack. We have to start listening for location\n // changes here in the constructor in case there are any s\n // on the initial render. If there are, they will replace/push when\n // they mount and since cDM fires in children before parents, we may\n // get a new location before the is mounted.\n this._isMounted = false;\n this._pendingLocation = null;\n\n if (!props.staticContext) {\n this.unlisten = props.history.listen(location => {\n this._pendingLocation = location;\n });\n }\n }\n\n componentDidMount() {\n this._isMounted = true;\n\n if (this.unlisten) {\n // Any pre-mount location changes have been captured at\n // this point, so unregister the listener.\n this.unlisten();\n }\n if (!this.props.staticContext) {\n this.unlisten = this.props.history.listen(location => {\n if (this._isMounted) {\n this.setState({ location });\n }\n });\n }\n if (this._pendingLocation) {\n this.setState({ location: this._pendingLocation });\n }\n }\n\n componentWillUnmount() {\n if (this.unlisten) {\n this.unlisten();\n this._isMounted = false;\n this._pendingLocation = null;\n }\n }\n\n render() {\n return (\n \n \n \n );\n }\n}\n\nif (__DEV__) {\n Router.propTypes = {\n children: PropTypes.node,\n history: PropTypes.object.isRequired,\n staticContext: PropTypes.object\n };\n\n Router.prototype.componentDidUpdate = function(prevProps) {\n warning(\n prevProps.history === this.props.history,\n \"You cannot change \"\n );\n };\n}\n\nexport default Router;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createMemoryHistory as createHistory } from \"history\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router.js\";\n\n/**\n * The public API for a that stores location in memory.\n */\nclass MemoryRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return ;\n }\n}\n\nif (__DEV__) {\n MemoryRouter.propTypes = {\n initialEntries: PropTypes.array,\n initialIndex: PropTypes.number,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number,\n children: PropTypes.node\n };\n\n MemoryRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \" ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { MemoryRouter as Router }`.\"\n );\n };\n}\n\nexport default MemoryRouter;\n","import React from \"react\";\n\nclass Lifecycle extends React.Component {\n componentDidMount() {\n if (this.props.onMount) this.props.onMount.call(this, this);\n }\n\n componentDidUpdate(prevProps) {\n if (this.props.onUpdate) this.props.onUpdate.call(this, this, prevProps);\n }\n\n componentWillUnmount() {\n if (this.props.onUnmount) this.props.onUnmount.call(this, this);\n }\n\n render() {\n return null;\n }\n}\n\nexport default Lifecycle;\n","import pathToRegexp from \"path-to-regexp\";\n\nconst cache = {};\nconst cacheLimit = 10000;\nlet cacheCount = 0;\n\nfunction compilePath(path, options) {\n const cacheKey = `${options.end}${options.strict}${options.sensitive}`;\n const pathCache = cache[cacheKey] || (cache[cacheKey] = {});\n\n if (pathCache[path]) return pathCache[path];\n\n const keys = [];\n const regexp = pathToRegexp(path, keys, options);\n const result = { regexp, keys };\n\n if (cacheCount < cacheLimit) {\n pathCache[path] = result;\n cacheCount++;\n }\n\n return result;\n}\n\n/**\n * Public API for matching a URL pathname to a path.\n */\nfunction matchPath(pathname, options = {}) {\n if (typeof options === \"string\" || Array.isArray(options)) {\n options = { path: options };\n }\n\n const { path, exact = false, strict = false, sensitive = false } = options;\n\n const paths = [].concat(path);\n\n return paths.reduce((matched, path) => {\n if (!path && path !== \"\") return null;\n if (matched) return matched;\n\n const { regexp, keys } = compilePath(path, {\n end: exact,\n strict,\n sensitive\n });\n const match = regexp.exec(pathname);\n\n if (!match) return null;\n\n const [url, ...values] = match;\n const isExact = pathname === url;\n\n if (exact && !isExact) return null;\n\n return {\n path, // the path used to match\n url: path === \"/\" && url === \"\" ? \"/\" : url, // the matched portion of the URL\n isExact, // whether or not we matched exactly\n params: keys.reduce((memo, key, index) => {\n memo[key.name] = values[index];\n return memo;\n }, {})\n };\n }, null);\n}\n\nexport default matchPath;\n","import React from \"react\";\nimport { isValidElementType } from \"react-is\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext.js\";\nimport matchPath from \"./matchPath.js\";\n\nfunction isEmptyChildren(children) {\n return React.Children.count(children) === 0;\n}\n\nfunction evalChildrenDev(children, props, path) {\n const value = children(props);\n\n warning(\n value !== undefined,\n \"You returned `undefined` from the `children` function of \" +\n `, but you ` +\n \"should have returned a React element or `null`\"\n );\n\n return value || null;\n}\n\n/**\n * The public API for matching a single path and rendering.\n */\nclass Route extends React.Component {\n render() {\n return (\n \n {context => {\n invariant(context, \"You should not use outside a \");\n\n const location = this.props.location || context.location;\n const match = this.props.computedMatch\n ? this.props.computedMatch // already computed the match for us\n : this.props.path\n ? matchPath(location.pathname, this.props)\n : context.match;\n\n const props = { ...context, location, match };\n\n let { children, component, render } = this.props;\n\n // Preact uses an empty array as children by\n // default, so use null if that's the case.\n if (Array.isArray(children) && isEmptyChildren(children)) {\n children = null;\n }\n\n return (\n \n {props.match\n ? children\n ? typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : children\n : component\n ? React.createElement(component, props)\n : render\n ? render(props)\n : null\n : typeof children === \"function\"\n ? __DEV__\n ? evalChildrenDev(children, props, this.props.path)\n : children(props)\n : null}\n \n );\n }}\n \n );\n }\n}\n\nif (__DEV__) {\n Route.propTypes = {\n children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),\n component: (props, propName) => {\n if (props[propName] && !isValidElementType(props[propName])) {\n return new Error(\n `Invalid prop 'component' supplied to 'Route': the prop is not a valid React component`\n );\n }\n },\n exact: PropTypes.bool,\n location: PropTypes.object,\n path: PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.arrayOf(PropTypes.string)\n ]),\n render: PropTypes.func,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool\n };\n\n Route.prototype.componentDidMount = function() {\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.component\n ),\n \"You should not use and in the same route; will be ignored\"\n );\n\n warning(\n !(\n this.props.children &&\n !isEmptyChildren(this.props.children) &&\n this.props.render\n ),\n \"You should not use and in the same route; will be ignored\"\n );\n\n warning(\n !(this.props.component && this.props.render),\n \"You should not use and in the same route; will be ignored\"\n );\n };\n\n Route.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n ' elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n ' elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Route;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport { createLocation, createPath } from \"history\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport Router from \"./Router.js\";\n\nfunction addLeadingSlash(path) {\n return path.charAt(0) === \"/\" ? path : \"/\" + path;\n}\n\nfunction addBasename(basename, location) {\n if (!basename) return location;\n\n return {\n ...location,\n pathname: addLeadingSlash(basename) + location.pathname\n };\n}\n\nfunction stripBasename(basename, location) {\n if (!basename) return location;\n\n const base = addLeadingSlash(basename);\n\n if (location.pathname.indexOf(base) !== 0) return location;\n\n return {\n ...location,\n pathname: location.pathname.substr(base.length)\n };\n}\n\nfunction createURL(location) {\n return typeof location === \"string\" ? location : createPath(location);\n}\n\nfunction staticHandler(methodName) {\n return () => {\n invariant(false, \"You cannot %s with \", methodName);\n };\n}\n\nfunction noop() {}\n\n/**\n * The public top-level API for a \"static\" , so-called because it\n * can't actually change the current location. Instead, it just records\n * location changes in a context object. Useful mainly in testing and\n * server-rendering scenarios.\n */\nclass StaticRouter extends React.Component {\n navigateTo(location, action) {\n const { basename = \"\", context = {} } = this.props;\n context.action = action;\n context.location = addBasename(basename, createLocation(location));\n context.url = createURL(context.location);\n }\n\n handlePush = location => this.navigateTo(location, \"PUSH\");\n handleReplace = location => this.navigateTo(location, \"REPLACE\");\n handleListen = () => noop;\n handleBlock = () => noop;\n\n render() {\n const { basename = \"\", context = {}, location = \"/\", ...rest } = this.props;\n\n const history = {\n createHref: path => addLeadingSlash(basename + createURL(path)),\n action: \"POP\",\n location: stripBasename(basename, createLocation(location)),\n push: this.handlePush,\n replace: this.handleReplace,\n go: staticHandler(\"go\"),\n goBack: staticHandler(\"goBack\"),\n goForward: staticHandler(\"goForward\"),\n listen: this.handleListen,\n block: this.handleBlock\n };\n\n return ;\n }\n}\n\nif (__DEV__) {\n StaticRouter.propTypes = {\n basename: PropTypes.string,\n context: PropTypes.object,\n location: PropTypes.oneOfType([PropTypes.string, PropTypes.object])\n };\n\n StaticRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \" ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { StaticRouter as Router }`.\"\n );\n };\n}\n\nexport default StaticRouter;\n","import React from \"react\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport warning from \"tiny-warning\";\n\nimport RouterContext from \"./RouterContext.js\";\nimport matchPath from \"./matchPath.js\";\n\n/**\n * The public API for rendering the first that matches.\n */\nclass Switch extends React.Component {\n render() {\n return (\n \n {context => {\n invariant(context, \"You should not use outside a \");\n\n const location = this.props.location || context.location;\n\n let element, match;\n\n // We use React.Children.forEach instead of React.Children.toArray().find()\n // here because toArray adds keys to all child elements and we do not want\n // to trigger an unmount/remount for two s that render the same\n // component at different URLs.\n React.Children.forEach(this.props.children, child => {\n if (match == null && React.isValidElement(child)) {\n element = child;\n\n const path = child.props.path || child.props.from;\n\n match = path\n ? matchPath(location.pathname, { ...child.props, path })\n : context.match;\n }\n });\n\n return match\n ? React.cloneElement(element, { location, computedMatch: match })\n : null;\n }}\n \n );\n }\n}\n\nif (__DEV__) {\n Switch.propTypes = {\n children: PropTypes.node,\n location: PropTypes.object\n };\n\n Switch.prototype.componentDidUpdate = function(prevProps) {\n warning(\n !(this.props.location && !prevProps.location),\n ' elements should not change from uncontrolled to controlled (or vice versa). You initially used no \"location\" prop and then provided one on a subsequent render.'\n );\n\n warning(\n !(!this.props.location && prevProps.location),\n ' elements should not change from controlled to uncontrolled (or vice versa). You provided a \"location\" prop initially but omitted it on a subsequent render.'\n );\n };\n}\n\nexport default Switch;\n","import React from \"react\";\nimport invariant from \"tiny-invariant\";\n\nimport RouterContext from \"./RouterContext.js\";\nimport HistoryContext from \"./HistoryContext.js\";\nimport matchPath from \"./matchPath.js\";\n\nconst useContext = React.useContext;\n\nexport function useHistory() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useHistory()\"\n );\n }\n\n return useContext(HistoryContext);\n}\n\nexport function useLocation() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useLocation()\"\n );\n }\n\n return useContext(RouterContext).location;\n}\n\nexport function useParams() {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useParams()\"\n );\n }\n\n const match = useContext(RouterContext).match;\n return match ? match.params : {};\n}\n\nexport function useRouteMatch(path) {\n if (__DEV__) {\n invariant(\n typeof useContext === \"function\",\n \"You must use React >= 16.8 in order to use useRouteMatch()\"\n );\n }\n\n const location = useLocation();\n const match = useContext(RouterContext).match;\n return path ? matchPath(location.pathname, path) : match;\n}\n","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createBrowserHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a that uses HTML5 history.\n */\nclass BrowserRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return ;\n }\n}\n\nif (__DEV__) {\n BrowserRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n forceRefresh: PropTypes.bool,\n getUserConfirmation: PropTypes.func,\n keyLength: PropTypes.number\n };\n\n BrowserRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \" ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { BrowserRouter as Router }`.\"\n );\n };\n}\n\nexport default BrowserRouter;\n","import React from \"react\";\nimport { Router } from \"react-router\";\nimport { createHashHistory as createHistory } from \"history\";\nimport PropTypes from \"prop-types\";\nimport warning from \"tiny-warning\";\n\n/**\n * The public API for a that uses window.location.hash.\n */\nclass HashRouter extends React.Component {\n history = createHistory(this.props);\n\n render() {\n return ;\n }\n}\n\nif (__DEV__) {\n HashRouter.propTypes = {\n basename: PropTypes.string,\n children: PropTypes.node,\n getUserConfirmation: PropTypes.func,\n hashType: PropTypes.oneOf([\"hashbang\", \"noslash\", \"slash\"])\n };\n\n HashRouter.prototype.componentDidMount = function() {\n warning(\n !this.props.history,\n \" ignores the history prop. To use a custom history, \" +\n \"use `import { Router }` instead of `import { HashRouter as Router }`.\"\n );\n };\n}\n\nexport default HashRouter;\n","import { createLocation } from \"history\";\n\nexport const resolveToLocation = (to, currentLocation) =>\n typeof to === \"function\" ? to(currentLocation) : to;\n\nexport const normalizeToLocation = (to, currentLocation) => {\n return typeof to === \"string\"\n ? createLocation(to, null, null, currentLocation)\n : to;\n};\n","import React from \"react\";\nimport { __RouterContext as RouterContext } from \"react-router\";\nimport { createPath } from 'history';\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport {\n resolveToLocation,\n normalizeToLocation\n} from \"./utils/locationUtils.js\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction isModifiedEvent(event) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\n\nconst LinkAnchor = forwardRef(\n (\n {\n innerRef, // TODO: deprecate\n navigate,\n onClick,\n ...rest\n },\n forwardedRef\n ) => {\n const { target } = rest;\n\n let props = {\n ...rest,\n onClick: event => {\n try {\n if (onClick) onClick(event);\n } catch (ex) {\n event.preventDefault();\n throw ex;\n }\n\n if (\n !event.defaultPrevented && // onClick prevented default\n event.button === 0 && // ignore everything but left clicks\n (!target || target === \"_self\") && // let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event) // ignore clicks with modifier keys\n ) {\n event.preventDefault();\n navigate();\n }\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.ref = innerRef;\n }\n\n /* eslint-disable-next-line jsx-a11y/anchor-has-content */\n return ;\n }\n);\n\nif (__DEV__) {\n LinkAnchor.displayName = \"LinkAnchor\";\n}\n\n/**\n * The public API for rendering a history-aware .\n */\nconst Link = forwardRef(\n (\n {\n component = LinkAnchor,\n replace,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n \n {context => {\n invariant(context, \"You should not use outside a \");\n\n const { history } = context;\n\n const location = normalizeToLocation(\n resolveToLocation(to, context.location),\n context.location\n );\n\n const href = location ? history.createHref(location) : \"\";\n const props = {\n ...rest,\n href,\n navigate() {\n const location = resolveToLocation(to, context.location);\n const isDuplicateNavigation = createPath(context.location) === createPath(normalizeToLocation(location));\n const method = (replace || isDuplicateNavigation) ? history.replace : history.push;\n\n method(location);\n }\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return React.createElement(component, props);\n }}\n \n );\n }\n);\n\nif (__DEV__) {\n const toType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.object,\n PropTypes.func\n ]);\n const refType = PropTypes.oneOfType([\n PropTypes.string,\n PropTypes.func,\n PropTypes.shape({ current: PropTypes.any })\n ]);\n\n Link.displayName = \"Link\";\n\n Link.propTypes = {\n innerRef: refType,\n onClick: PropTypes.func,\n replace: PropTypes.bool,\n target: PropTypes.string,\n to: toType.isRequired\n };\n}\n\nexport default Link;\n","import React from \"react\";\nimport { __RouterContext as RouterContext, matchPath } from \"react-router\";\nimport PropTypes from \"prop-types\";\nimport invariant from \"tiny-invariant\";\nimport Link from \"./Link.js\";\nimport {\n resolveToLocation,\n normalizeToLocation\n} from \"./utils/locationUtils.js\";\n\n// React 15 compat\nconst forwardRefShim = C => C;\nlet { forwardRef } = React;\nif (typeof forwardRef === \"undefined\") {\n forwardRef = forwardRefShim;\n}\n\nfunction joinClassnames(...classnames) {\n return classnames.filter(i => i).join(\" \");\n}\n\n/**\n * A wrapper that knows if it's \"active\" or not.\n */\nconst NavLink = forwardRef(\n (\n {\n \"aria-current\": ariaCurrent = \"page\",\n activeClassName = \"active\", // TODO: deprecate\n activeStyle, // TODO: deprecate\n className: classNameProp,\n exact,\n isActive: isActiveProp,\n location: locationProp,\n sensitive,\n strict,\n style: styleProp,\n to,\n innerRef, // TODO: deprecate\n ...rest\n },\n forwardedRef\n ) => {\n return (\n \n {context => {\n invariant(context, \"You should not use outside a \");\n\n const currentLocation = locationProp || context.location;\n const toLocation = normalizeToLocation(\n resolveToLocation(to, currentLocation),\n currentLocation\n );\n const { pathname: path } = toLocation;\n // Regex taken from: https://github.com/pillarjs/path-to-regexp/blob/master/index.js#L202\n const escapedPath =\n path && path.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g, \"\\\\$1\");\n\n const match = escapedPath\n ? matchPath(currentLocation.pathname, {\n path: escapedPath,\n exact,\n sensitive,\n strict\n })\n : null;\n const isActive = !!(isActiveProp\n ? isActiveProp(match, currentLocation)\n : match);\n\n let className =\n typeof classNameProp === \"function\"\n ? classNameProp(isActive)\n : classNameProp;\n\n let style =\n typeof styleProp === \"function\" ? styleProp(isActive) : styleProp;\n\n if (isActive) {\n className = joinClassnames(className, activeClassName);\n style = { ...style, ...activeStyle };\n }\n\n const props = {\n \"aria-current\": (isActive && ariaCurrent) || null,\n className,\n style,\n to: toLocation,\n ...rest\n };\n\n // React 15 compat\n if (forwardRefShim !== forwardRef) {\n props.ref = forwardedRef || innerRef;\n } else {\n props.innerRef = innerRef;\n }\n\n return ;\n }}\n \n );\n }\n);\n\nif (__DEV__) {\n NavLink.displayName = \"NavLink\";\n\n const ariaCurrentType = PropTypes.oneOf([\n \"page\",\n \"step\",\n \"location\",\n \"date\",\n \"time\",\n \"true\",\n \"false\"\n ]);\n\n NavLink.propTypes = {\n ...Link.propTypes,\n \"aria-current\": ariaCurrentType,\n activeClassName: PropTypes.string,\n activeStyle: PropTypes.object,\n className: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n exact: PropTypes.bool,\n isActive: PropTypes.func,\n location: PropTypes.object,\n sensitive: PropTypes.bool,\n strict: PropTypes.bool,\n style: PropTypes.oneOfType([PropTypes.object, PropTypes.func])\n };\n}\n\nexport default NavLink;\n","import PropTypes from 'prop-types'; // https://github.com/twbs/bootstrap/blob/v4.0.0-alpha.4/js/src/modal.js#L436-L443\n\nexport function getScrollbarWidth() {\n var scrollDiv = document.createElement('div'); // .modal-scrollbar-measure styles // https://github.com/twbs/bootstrap/blob/v4.0.0-alpha.4/scss/_modal.scss#L106-L113\n\n scrollDiv.style.position = 'absolute';\n scrollDiv.style.top = '-9999px';\n scrollDiv.style.width = '50px';\n scrollDiv.style.height = '50px';\n scrollDiv.style.overflow = 'scroll';\n document.body.appendChild(scrollDiv);\n var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;\n document.body.removeChild(scrollDiv);\n return scrollbarWidth;\n}\nexport function setScrollbarWidth(padding) {\n document.body.style.paddingRight = padding > 0 ? padding + \"px\" : null;\n}\nexport function isBodyOverflowing() {\n return document.body.clientWidth < window.innerWidth;\n}\nexport function getOriginalBodyPadding() {\n var style = window.getComputedStyle(document.body, null);\n return parseInt(style && style.getPropertyValue('padding-right') || 0, 10);\n}\nexport function conditionallyUpdateScrollbar() {\n var scrollbarWidth = getScrollbarWidth(); // https://github.com/twbs/bootstrap/blob/v4.0.0-alpha.6/js/src/modal.js#L433\n\n var fixedContent = document.querySelectorAll('.fixed-top, .fixed-bottom, .is-fixed, .sticky-top')[0];\n var bodyPadding = fixedContent ? parseInt(fixedContent.style.paddingRight || 0, 10) : 0;\n\n if (isBodyOverflowing()) {\n setScrollbarWidth(bodyPadding + scrollbarWidth);\n }\n}\nvar globalCssModule;\nexport function setGlobalCssModule(cssModule) {\n globalCssModule = cssModule;\n}\nexport function mapToCssModules(className, cssModule) {\n if (className === void 0) {\n className = '';\n }\n\n if (cssModule === void 0) {\n cssModule = globalCssModule;\n }\n\n if (!cssModule) return className;\n return className.split(' ').map(function (c) {\n return cssModule[c] || c;\n }).join(' ');\n}\n/**\n * Returns a new object with the key/value pairs from `obj` that are not in the array `omitKeys`.\n */\n\nexport function omit(obj, omitKeys) {\n var result = {};\n Object.keys(obj).forEach(function (key) {\n if (omitKeys.indexOf(key) === -1) {\n result[key] = obj[key];\n }\n });\n return result;\n}\n/**\n * Returns a filtered copy of an object with only the specified keys.\n */\n\nexport function pick(obj, keys) {\n var pickKeys = Array.isArray(keys) ? keys : [keys];\n var length = pickKeys.length;\n var key;\n var result = {};\n\n while (length > 0) {\n length -= 1;\n key = pickKeys[length];\n result[key] = obj[key];\n }\n\n return result;\n}\nvar warned = {};\nexport function warnOnce(message) {\n if (!warned[message]) {\n /* istanbul ignore else */\n if (typeof console !== 'undefined') {\n console.error(message); // eslint-disable-line no-console\n }\n\n warned[message] = true;\n }\n}\nexport function deprecated(propType, explanation) {\n return function validate(props, propName, componentName) {\n if (props[propName] !== null && typeof props[propName] !== 'undefined') {\n warnOnce(\"\\\"\" + propName + \"\\\" property of \\\"\" + componentName + \"\\\" has been deprecated.\\n\" + explanation);\n }\n\n for (var _len = arguments.length, rest = new Array(_len > 3 ? _len - 3 : 0), _key = 3; _key < _len; _key++) {\n rest[_key - 3] = arguments[_key];\n }\n\n return propType.apply(void 0, [props, propName, componentName].concat(rest));\n };\n} // Shim Element if needed (e.g. in Node environment)\n\nvar Element = typeof window === 'object' && window.Element || function () {};\n\nexport function DOMElement(props, propName, componentName) {\n if (!(props[propName] instanceof Element)) {\n return new Error('Invalid prop `' + propName + '` supplied to `' + componentName + '`. Expected prop to be an instance of Element. Validation failed.');\n }\n}\nexport var targetPropType = PropTypes.oneOfType([PropTypes.string, PropTypes.func, DOMElement, PropTypes.shape({\n current: PropTypes.any\n})]);\nexport var tagPropType = PropTypes.oneOfType([PropTypes.func, PropTypes.string, PropTypes.shape({\n $$typeof: PropTypes.symbol,\n render: PropTypes.func\n}), PropTypes.arrayOf(PropTypes.oneOfType([PropTypes.func, PropTypes.string, PropTypes.shape({\n $$typeof: PropTypes.symbol,\n render: PropTypes.func\n})]))]);\n/* eslint key-spacing: [\"error\", { afterColon: true, align: \"value\" }] */\n// These are all setup to match what is in the bootstrap _variables.scss\n// https://github.com/twbs/bootstrap/blob/v4-dev/scss/_variables.scss\n\nexport var TransitionTimeouts = {\n Fade: 150,\n // $transition-fade\n Collapse: 350,\n // $transition-collapse\n Modal: 300,\n // $modal-transition\n Carousel: 600 // $carousel-transition\n\n}; // Duplicated Transition.propType keys to ensure that Reactstrap builds\n// for distribution properly exclude these keys for nested child HTML attributes\n// since `react-transition-group` removes propTypes in production builds.\n\nexport var TransitionPropTypeKeys = ['in', 'mountOnEnter', 'unmountOnExit', 'appear', 'enter', 'exit', 'timeout', 'onEnter', 'onEntering', 'onEntered', 'onExit', 'onExiting', 'onExited'];\nexport var TransitionStatuses = {\n ENTERING: 'entering',\n ENTERED: 'entered',\n EXITING: 'exiting',\n EXITED: 'exited'\n};\nexport var keyCodes = {\n esc: 27,\n space: 32,\n enter: 13,\n tab: 9,\n up: 38,\n down: 40,\n home: 36,\n end: 35,\n n: 78,\n p: 80\n};\nexport var PopperPlacements = ['auto-start', 'auto', 'auto-end', 'top-start', 'top', 'top-end', 'right-start', 'right', 'right-end', 'bottom-end', 'bottom', 'bottom-start', 'left-end', 'left', 'left-start'];\nexport var canUseDOM = !!(typeof window !== 'undefined' && window.document && window.document.createElement);\nexport function isReactRefObj(target) {\n if (target && typeof target === 'object') {\n return 'current' in target;\n }\n\n return false;\n}\n\nfunction getTag(value) {\n if (value == null) {\n return value === undefined ? '[object Undefined]' : '[object Null]';\n }\n\n return Object.prototype.toString.call(value);\n}\n\nexport function toNumber(value) {\n var type = typeof value;\n var NAN = 0 / 0;\n\n if (type === 'number') {\n return value;\n }\n\n if (type === 'symbol' || type === 'object' && getTag(value) === '[object Symbol]') {\n return NAN;\n }\n\n if (isObject(value)) {\n var other = typeof value.valueOf === 'function' ? value.valueOf() : value;\n value = isObject(other) ? \"\" + other : other;\n }\n\n if (type !== 'string') {\n return value === 0 ? value : +value;\n }\n\n value = value.replace(/^\\s+|\\s+$/g, '');\n var isBinary = /^0b[01]+$/i.test(value);\n return isBinary || /^0o[0-7]+$/i.test(value) ? parseInt(value.slice(2), isBinary ? 2 : 8) : /^[-+]0x[0-9a-f]+$/i.test(value) ? NAN : +value;\n}\nexport function isObject(value) {\n var type = typeof value;\n return value != null && (type === 'object' || type === 'function');\n}\nexport function isFunction(value) {\n if (!isObject(value)) {\n return false;\n }\n\n var tag = getTag(value);\n return tag === '[object Function]' || tag === '[object AsyncFunction]' || tag === '[object GeneratorFunction]' || tag === '[object Proxy]';\n}\nexport function findDOMElements(target) {\n if (isReactRefObj(target)) {\n return target.current;\n }\n\n if (isFunction(target)) {\n return target();\n }\n\n if (typeof target === 'string' && canUseDOM) {\n var selection = document.querySelectorAll(target);\n\n if (!selection.length) {\n selection = document.querySelectorAll(\"#\" + target);\n }\n\n if (!selection.length) {\n throw new Error(\"The target '\" + target + \"' could not be identified in the dom, tip: check spelling\");\n }\n\n return selection;\n }\n\n return target;\n}\nexport function isArrayOrNodeList(els) {\n if (els === null) {\n return false;\n }\n\n return Array.isArray(els) || canUseDOM && typeof els.length === 'number';\n}\nexport function getTarget(target, allElements) {\n var els = findDOMElements(target);\n\n if (allElements) {\n if (isArrayOrNodeList(els)) {\n return els;\n }\n\n if (els === null) {\n return [];\n }\n\n return [els];\n } else {\n if (isArrayOrNodeList(els)) {\n return els[0];\n }\n\n return els;\n }\n}\nexport var defaultToggleEvents = ['touchstart', 'click'];\nexport function addMultipleEventListeners(_els, handler, _events, useCapture) {\n var els = _els;\n\n if (!isArrayOrNodeList(els)) {\n els = [els];\n }\n\n var events = _events;\n\n if (typeof events === 'string') {\n events = events.split(/\\s+/);\n }\n\n if (!isArrayOrNodeList(els) || typeof handler !== 'function' || !Array.isArray(events)) {\n throw new Error(\"\\n The first argument of this function must be DOM node or an array on DOM nodes or NodeList.\\n The second must be a function.\\n The third is a string or an array of strings that represents DOM events\\n \");\n }\n\n Array.prototype.forEach.call(events, function (event) {\n Array.prototype.forEach.call(els, function (el) {\n el.addEventListener(event, handler, useCapture);\n });\n });\n return function removeEvents() {\n Array.prototype.forEach.call(events, function (event) {\n Array.prototype.forEach.call(els, function (el) {\n el.removeEventListener(event, handler, useCapture);\n });\n });\n };\n}\nexport var focusableElements = ['a[href]', 'area[href]', 'input:not([disabled]):not([type=hidden])', 'select:not([disabled])', 'textarea:not([disabled])', 'button:not([disabled])', 'object', 'embed', '[tabindex]:not(.modal)', 'audio[controls]', 'video[controls]', '[contenteditable]:not([contenteditable=\"false\"])'];","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"fluid\", \"tag\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n tag: tagPropType,\n fluid: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n className: PropTypes.string,\n cssModule: PropTypes.object\n};\nvar defaultProps = {\n tag: 'div'\n};\n\nvar Container = function Container(props) {\n var className = props.className,\n cssModule = props.cssModule,\n fluid = props.fluid,\n Tag = props.tag,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var containerClass = 'container';\n\n if (fluid === true) {\n containerClass = 'container-fluid';\n } else if (fluid) {\n containerClass = \"container-\" + fluid;\n }\n\n var classes = mapToCssModules(classNames(className, containerClass), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n className: classes\n }));\n};\n\nContainer.propTypes = propTypes;\nContainer.defaultProps = defaultProps;\nexport default Container;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"expand\", \"className\", \"cssModule\", \"light\", \"dark\", \"fixed\", \"sticky\", \"color\", \"tag\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n light: PropTypes.bool,\n dark: PropTypes.bool,\n full: PropTypes.bool,\n fixed: PropTypes.string,\n sticky: PropTypes.string,\n color: PropTypes.string,\n role: PropTypes.string,\n tag: tagPropType,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n expand: PropTypes.oneOfType([PropTypes.bool, PropTypes.string])\n};\nvar defaultProps = {\n tag: 'nav',\n expand: false\n};\n\nvar getExpandClass = function getExpandClass(expand) {\n if (expand === false) {\n return false;\n } else if (expand === true || expand === 'xs') {\n return 'navbar-expand';\n }\n\n return \"navbar-expand-\" + expand;\n};\n\nvar Navbar = function Navbar(props) {\n var _classNames;\n\n var expand = props.expand,\n className = props.className,\n cssModule = props.cssModule,\n light = props.light,\n dark = props.dark,\n fixed = props.fixed,\n sticky = props.sticky,\n color = props.color,\n Tag = props.tag,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var classes = mapToCssModules(classNames(className, 'navbar', getExpandClass(expand), (_classNames = {\n 'navbar-light': light,\n 'navbar-dark': dark\n }, _classNames[\"bg-\" + color] = color, _classNames[\"fixed-\" + fixed] = fixed, _classNames[\"sticky-\" + sticky] = sticky, _classNames)), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n className: classes\n }));\n};\n\nNavbar.propTypes = propTypes;\nNavbar.defaultProps = defaultProps;\nexport default Navbar;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"tag\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n tag: tagPropType,\n className: PropTypes.string,\n cssModule: PropTypes.object\n};\nvar defaultProps = {\n tag: 'a'\n};\n\nvar NavbarBrand = function NavbarBrand(props) {\n var className = props.className,\n cssModule = props.cssModule,\n Tag = props.tag,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var classes = mapToCssModules(classNames(className, 'navbar-brand'), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n className: classes\n }));\n};\n\nNavbarBrand.propTypes = propTypes;\nNavbarBrand.defaultProps = defaultProps;\nexport default NavbarBrand;","function _assertThisInitialized(e) {\n if (void 0 === e) throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\");\n return e;\n}\nexport { _assertThisInitialized as default };","function _typeof(o) {\n \"@babel/helpers - typeof\";\n\n return _typeof = \"function\" == typeof Symbol && \"symbol\" == typeof Symbol.iterator ? function (o) {\n return typeof o;\n } : function (o) {\n return o && \"function\" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? \"symbol\" : typeof o;\n }, _typeof(o);\n}\nexport { _typeof as default };","import _typeof from \"./typeof.js\";\nimport toPrimitive from \"./toPrimitive.js\";\nfunction toPropertyKey(t) {\n var i = toPrimitive(t, \"string\");\n return \"symbol\" == _typeof(i) ? i : i + \"\";\n}\nexport { toPropertyKey as default };","import _typeof from \"./typeof.js\";\nfunction toPrimitive(t, r) {\n if (\"object\" != _typeof(t) || !t) return t;\n var e = t[Symbol.toPrimitive];\n if (void 0 !== e) {\n var i = e.call(t, r || \"default\");\n if (\"object\" != _typeof(i)) return i;\n throw new TypeError(\"@@toPrimitive must return a primitive value.\");\n }\n return (\"string\" === r ? String : Number)(t);\n}\nexport { toPrimitive as default };","import toPropertyKey from \"./toPropertyKey.js\";\nfunction _defineProperty(e, r, t) {\n return (r = toPropertyKey(r)) in e ? Object.defineProperty(e, r, {\n value: t,\n enumerable: !0,\n configurable: !0,\n writable: !0\n }) : e[r] = t, e;\n}\nexport { _defineProperty as default };","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nvar _excluded = [\"tag\", \"isOpen\", \"className\", \"navbar\", \"cssModule\", \"children\", \"innerRef\"];\n\nvar _transitionStatusToCl;\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { Transition } from 'react-transition-group';\nimport { mapToCssModules, omit, pick, TransitionTimeouts, TransitionPropTypeKeys, TransitionStatuses, tagPropType } from './utils';\n\nvar propTypes = _objectSpread(_objectSpread({}, Transition.propTypes), {}, {\n isOpen: PropTypes.bool,\n children: PropTypes.oneOfType([PropTypes.arrayOf(PropTypes.node), PropTypes.node]),\n tag: tagPropType,\n className: PropTypes.node,\n navbar: PropTypes.bool,\n cssModule: PropTypes.object,\n innerRef: PropTypes.oneOfType([PropTypes.func, PropTypes.string, PropTypes.object])\n});\n\nvar defaultProps = _objectSpread(_objectSpread({}, Transition.defaultProps), {}, {\n isOpen: false,\n appear: false,\n enter: true,\n exit: true,\n tag: 'div',\n timeout: TransitionTimeouts.Collapse\n});\n\nvar transitionStatusToClassHash = (_transitionStatusToCl = {}, _transitionStatusToCl[TransitionStatuses.ENTERING] = 'collapsing', _transitionStatusToCl[TransitionStatuses.ENTERED] = 'collapse show', _transitionStatusToCl[TransitionStatuses.EXITING] = 'collapsing', _transitionStatusToCl[TransitionStatuses.EXITED] = 'collapse', _transitionStatusToCl);\n\nfunction getTransitionClass(status) {\n return transitionStatusToClassHash[status] || 'collapse';\n}\n\nfunction getHeight(node) {\n return node.scrollHeight;\n}\n\nvar Collapse = /*#__PURE__*/function (_Component) {\n _inheritsLoose(Collapse, _Component);\n\n function Collapse(props) {\n var _this;\n\n _this = _Component.call(this, props) || this;\n _this.state = {\n height: null\n };\n ['onEntering', 'onEntered', 'onExit', 'onExiting', 'onExited'].forEach(function (name) {\n _this[name] = _this[name].bind(_assertThisInitialized(_this));\n });\n return _this;\n }\n\n var _proto = Collapse.prototype;\n\n _proto.onEntering = function onEntering(node, isAppearing) {\n this.setState({\n height: getHeight(node)\n });\n this.props.onEntering(node, isAppearing);\n };\n\n _proto.onEntered = function onEntered(node, isAppearing) {\n this.setState({\n height: null\n });\n this.props.onEntered(node, isAppearing);\n };\n\n _proto.onExit = function onExit(node) {\n this.setState({\n height: getHeight(node)\n });\n this.props.onExit(node);\n };\n\n _proto.onExiting = function onExiting(node) {\n // getting this variable triggers a reflow\n var _unused = node.offsetHeight; // eslint-disable-line no-unused-vars\n\n this.setState({\n height: 0\n });\n this.props.onExiting(node);\n };\n\n _proto.onExited = function onExited(node) {\n this.setState({\n height: null\n });\n this.props.onExited(node);\n };\n\n _proto.render = function render() {\n var _this2 = this;\n\n var _this$props = this.props,\n Tag = _this$props.tag,\n isOpen = _this$props.isOpen,\n className = _this$props.className,\n navbar = _this$props.navbar,\n cssModule = _this$props.cssModule,\n children = _this$props.children,\n innerRef = _this$props.innerRef,\n otherProps = _objectWithoutPropertiesLoose(_this$props, _excluded);\n\n var height = this.state.height;\n var transitionProps = pick(otherProps, TransitionPropTypeKeys);\n var childProps = omit(otherProps, TransitionPropTypeKeys);\n return /*#__PURE__*/React.createElement(Transition, _extends({}, transitionProps, {\n in: isOpen,\n onEntering: this.onEntering,\n onEntered: this.onEntered,\n onExit: this.onExit,\n onExiting: this.onExiting,\n onExited: this.onExited\n }), function (status) {\n var collapseClass = getTransitionClass(status);\n var classes = mapToCssModules(classNames(className, collapseClass, navbar && 'navbar-collapse'), cssModule);\n var style = height === null ? null : {\n height: height\n };\n return /*#__PURE__*/React.createElement(Tag, _extends({}, childProps, {\n style: _objectSpread(_objectSpread({}, childProps.style), style),\n className: classes,\n ref: _this2.props.innerRef\n }), children);\n });\n };\n\n return Collapse;\n}(Component);\n\nCollapse.propTypes = propTypes;\nCollapse.defaultProps = defaultProps;\nexport default Collapse;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"tabs\", \"pills\", \"vertical\", \"horizontal\", \"justified\", \"fill\", \"navbar\", \"card\", \"tag\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n tabs: PropTypes.bool,\n pills: PropTypes.bool,\n vertical: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n horizontal: PropTypes.string,\n justified: PropTypes.bool,\n fill: PropTypes.bool,\n navbar: PropTypes.bool,\n card: PropTypes.bool,\n tag: tagPropType,\n className: PropTypes.string,\n cssModule: PropTypes.object\n};\nvar defaultProps = {\n tag: 'ul',\n vertical: false\n};\n\nvar getVerticalClass = function getVerticalClass(vertical) {\n if (vertical === false) {\n return false;\n } else if (vertical === true || vertical === 'xs') {\n return 'flex-column';\n }\n\n return \"flex-\" + vertical + \"-column\";\n};\n\nvar Nav = function Nav(props) {\n var className = props.className,\n cssModule = props.cssModule,\n tabs = props.tabs,\n pills = props.pills,\n vertical = props.vertical,\n horizontal = props.horizontal,\n justified = props.justified,\n fill = props.fill,\n navbar = props.navbar,\n card = props.card,\n Tag = props.tag,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var classes = mapToCssModules(classNames(className, navbar ? 'navbar-nav' : 'nav', horizontal ? \"justify-content-\" + horizontal : false, getVerticalClass(vertical), {\n 'nav-tabs': tabs,\n 'card-header-tabs': card && tabs,\n 'nav-pills': pills,\n 'card-header-pills': card && pills,\n 'nav-justified': justified,\n 'nav-fill': fill\n }), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n className: classes\n }));\n};\n\nNav.propTypes = propTypes;\nNav.defaultProps = defaultProps;\nexport default Nav;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"active\", \"tag\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n tag: tagPropType,\n active: PropTypes.bool,\n className: PropTypes.string,\n cssModule: PropTypes.object\n};\nvar defaultProps = {\n tag: 'li'\n};\n\nvar NavItem = function NavItem(props) {\n var className = props.className,\n cssModule = props.cssModule,\n active = props.active,\n Tag = props.tag,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var classes = mapToCssModules(classNames(className, 'nav-item', active ? 'active' : false), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n className: classes\n }));\n};\n\nNavItem.propTypes = propTypes;\nNavItem.defaultProps = defaultProps;\nexport default NavItem;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"active\", \"tag\", \"innerRef\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n tag: tagPropType,\n innerRef: PropTypes.oneOfType([PropTypes.object, PropTypes.func, PropTypes.string]),\n disabled: PropTypes.bool,\n active: PropTypes.bool,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n onClick: PropTypes.func,\n href: PropTypes.any\n};\nvar defaultProps = {\n tag: 'a'\n};\n\nvar NavLink = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(NavLink, _React$Component);\n\n function NavLink(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n _this.onClick = _this.onClick.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n var _proto = NavLink.prototype;\n\n _proto.onClick = function onClick(e) {\n if (this.props.disabled) {\n e.preventDefault();\n return;\n }\n\n if (this.props.href === '#') {\n e.preventDefault();\n }\n\n if (this.props.onClick) {\n this.props.onClick(e);\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n className = _this$props.className,\n cssModule = _this$props.cssModule,\n active = _this$props.active,\n Tag = _this$props.tag,\n innerRef = _this$props.innerRef,\n attributes = _objectWithoutPropertiesLoose(_this$props, _excluded);\n\n var classes = mapToCssModules(classNames(className, 'nav-link', {\n disabled: attributes.disabled,\n active: active\n }), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n ref: innerRef,\n onClick: this.onClick,\n className: classes\n }));\n };\n\n return NavLink;\n}(React.Component);\n\nNavLink.propTypes = propTypes;\nNavLink.defaultProps = defaultProps;\nexport default NavLink;","import _inheritsLoose from \"@babel/runtime/helpers/inheritsLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport * as React from 'react';\nimport createContext from '@hypnosphi/create-react-context';\nexport var ManagerReferenceNodeContext = createContext();\nexport var ManagerReferenceNodeSetterContext = createContext();\n\nvar Manager =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(Manager, _React$Component);\n\n function Manager() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"referenceNode\", void 0);\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"setReferenceNode\", function (newReferenceNode) {\n if (newReferenceNode && _this.referenceNode !== newReferenceNode) {\n _this.referenceNode = newReferenceNode;\n\n _this.forceUpdate();\n }\n });\n\n return _this;\n }\n\n var _proto = Manager.prototype;\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.referenceNode = null;\n };\n\n _proto.render = function render() {\n return React.createElement(ManagerReferenceNodeContext.Provider, {\n value: this.referenceNode\n }, React.createElement(ManagerReferenceNodeSetterContext.Provider, {\n value: this.setReferenceNode\n }, this.props.children));\n };\n\n return Manager;\n}(React.Component);\n\nexport { Manager as default };","import React from 'react';\n/**\n * DropdownContext\n * {\n * toggle: PropTypes.func.isRequired,\n * isOpen: PropTypes.bool.isRequired,\n * direction: PropTypes.oneOf(['up', 'down', 'left', 'right']).isRequired,\n * inNavbar: PropTypes.bool.isRequired,\n * disabled: PropTypes.bool\n * }\n */\n\nexport var DropdownContext = /*#__PURE__*/React.createContext({});","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"direction\", \"isOpen\", \"group\", \"size\", \"nav\", \"setActiveFromChild\", \"active\", \"addonType\", \"tag\", \"menuRole\"];\n\n/* eslint react/no-find-dom-node: 0 */\n// https://github.com/yannickcr/eslint-plugin-react/blob/master/docs/rules/no-find-dom-node.md\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { Manager } from 'react-popper';\nimport classNames from 'classnames';\nimport { DropdownContext } from './DropdownContext';\nimport { mapToCssModules, omit, keyCodes, tagPropType } from './utils';\nvar propTypes = {\n a11y: PropTypes.bool,\n disabled: PropTypes.bool,\n direction: PropTypes.oneOf(['up', 'down', 'left', 'right']),\n group: PropTypes.bool,\n isOpen: PropTypes.bool,\n nav: PropTypes.bool,\n active: PropTypes.bool,\n addonType: PropTypes.oneOfType([PropTypes.bool, PropTypes.oneOf(['prepend', 'append'])]),\n size: PropTypes.string,\n tag: tagPropType,\n toggle: PropTypes.func,\n children: PropTypes.node,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n inNavbar: PropTypes.bool,\n setActiveFromChild: PropTypes.bool,\n menuRole: PropTypes.oneOf(['listbox', 'menu'])\n};\nvar defaultProps = {\n a11y: true,\n isOpen: false,\n direction: 'down',\n nav: false,\n active: false,\n addonType: false,\n inNavbar: false,\n setActiveFromChild: false\n};\nvar preventDefaultKeys = [keyCodes.space, keyCodes.enter, keyCodes.up, keyCodes.down, keyCodes.end, keyCodes.home];\n\nvar Dropdown = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Dropdown, _React$Component);\n\n function Dropdown(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n _this.addEvents = _this.addEvents.bind(_assertThisInitialized(_this));\n _this.handleDocumentClick = _this.handleDocumentClick.bind(_assertThisInitialized(_this));\n _this.handleKeyDown = _this.handleKeyDown.bind(_assertThisInitialized(_this));\n _this.removeEvents = _this.removeEvents.bind(_assertThisInitialized(_this));\n _this.toggle = _this.toggle.bind(_assertThisInitialized(_this));\n _this.handleMenuRef = _this.handleMenuRef.bind(_assertThisInitialized(_this));\n _this.containerRef = /*#__PURE__*/React.createRef();\n _this.menuRef = /*#__PURE__*/React.createRef();\n return _this;\n }\n\n var _proto = Dropdown.prototype;\n\n _proto.handleMenuRef = function handleMenuRef(menuRef) {\n this.menuRef.current = menuRef;\n };\n\n _proto.getContextValue = function getContextValue() {\n return {\n toggle: this.toggle,\n isOpen: this.props.isOpen,\n direction: this.props.direction === 'down' && this.props.dropup ? 'up' : this.props.direction,\n inNavbar: this.props.inNavbar,\n disabled: this.props.disabled,\n // Callback that should be called by DropdownMenu to provide a ref to\n // a HTML tag that's used for the DropdownMenu\n onMenuRef: this.handleMenuRef,\n menuRole: this.props.menuRole\n };\n };\n\n _proto.componentDidMount = function componentDidMount() {\n this.handleProps();\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n if (this.props.isOpen !== prevProps.isOpen) {\n this.handleProps();\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.removeEvents();\n };\n\n _proto.getContainer = function getContainer() {\n return this.containerRef.current;\n };\n\n _proto.getMenu = function getMenu() {\n return this.menuRef.current;\n };\n\n _proto.getMenuCtrl = function getMenuCtrl() {\n if (this._$menuCtrl) return this._$menuCtrl;\n this._$menuCtrl = this.getContainer().querySelector('[aria-expanded]');\n return this._$menuCtrl;\n };\n\n _proto.getItemType = function getItemType() {\n if (this.context.menuRole === 'listbox') {\n return 'option';\n }\n\n return 'menuitem';\n };\n\n _proto.getMenuItems = function getMenuItems() {\n // In a real menu with a child DropdownMenu, `this.getMenu()` should never\n // be null, but it is sometimes null in tests. To mitigate that, we just\n // use `this.getContainer()` as the fallback `menuContainer`.\n var menuContainer = this.getMenu() || this.getContainer();\n return [].slice.call(menuContainer.querySelectorAll(\"[role=\\\"\" + this.getItemType() + \"\\\"]\"));\n };\n\n _proto.addEvents = function addEvents() {\n var _this2 = this;\n\n ['click', 'touchstart', 'keyup'].forEach(function (event) {\n return document.addEventListener(event, _this2.handleDocumentClick, true);\n });\n };\n\n _proto.removeEvents = function removeEvents() {\n var _this3 = this;\n\n ['click', 'touchstart', 'keyup'].forEach(function (event) {\n return document.removeEventListener(event, _this3.handleDocumentClick, true);\n });\n };\n\n _proto.handleDocumentClick = function handleDocumentClick(e) {\n if (e && (e.which === 3 || e.type === 'keyup' && e.which !== keyCodes.tab)) return;\n var container = this.getContainer();\n var menu = this.getMenu();\n var clickIsInContainer = container.contains(e.target) && container !== e.target;\n var clickIsInMenu = menu && menu.contains(e.target) && menu !== e.target;\n\n if ((clickIsInContainer || clickIsInMenu) && (e.type !== 'keyup' || e.which === keyCodes.tab)) {\n return;\n }\n\n this.toggle(e);\n };\n\n _proto.handleKeyDown = function handleKeyDown(e) {\n var _this4 = this;\n\n var isTargetMenuItem = e.target.getAttribute('role') === 'menuitem' || e.target.getAttribute('role') === 'option';\n var isTargetMenuCtrl = this.getMenuCtrl() === e.target;\n var isTab = keyCodes.tab === e.which;\n\n if (/input|textarea/i.test(e.target.tagName) || isTab && !this.props.a11y || isTab && !(isTargetMenuItem || isTargetMenuCtrl)) {\n return;\n }\n\n if (preventDefaultKeys.indexOf(e.which) !== -1 || e.which >= 48 && e.which <= 90) {\n e.preventDefault();\n }\n\n if (this.props.disabled) return;\n\n if (isTargetMenuCtrl) {\n if ([keyCodes.space, keyCodes.enter, keyCodes.up, keyCodes.down].indexOf(e.which) > -1) {\n // Open the menu (if not open) and focus the first menu item\n if (!this.props.isOpen) {\n this.toggle(e);\n }\n\n setTimeout(function () {\n return _this4.getMenuItems()[0].focus();\n });\n } else if (this.props.isOpen && isTab) {\n // Focus the first menu item if tabbing from an open menu. We need this\n // for cases where the DropdownMenu sets a custom container, which may\n // not be the natural next item to tab to from the DropdownToggle.\n e.preventDefault();\n this.getMenuItems()[0].focus();\n } else if (this.props.isOpen && e.which === keyCodes.esc) {\n this.toggle(e);\n }\n }\n\n if (this.props.isOpen && isTargetMenuItem) {\n if ([keyCodes.tab, keyCodes.esc].indexOf(e.which) > -1) {\n this.toggle(e);\n this.getMenuCtrl().focus();\n } else if ([keyCodes.space, keyCodes.enter].indexOf(e.which) > -1) {\n e.target.click();\n this.getMenuCtrl().focus();\n } else if ([keyCodes.down, keyCodes.up].indexOf(e.which) > -1 || [keyCodes.n, keyCodes.p].indexOf(e.which) > -1 && e.ctrlKey) {\n var $menuitems = this.getMenuItems();\n var index = $menuitems.indexOf(e.target);\n\n if (keyCodes.up === e.which || keyCodes.p === e.which && e.ctrlKey) {\n index = index !== 0 ? index - 1 : $menuitems.length - 1;\n } else if (keyCodes.down === e.which || keyCodes.n === e.which && e.ctrlKey) {\n index = index === $menuitems.length - 1 ? 0 : index + 1;\n }\n\n $menuitems[index].focus();\n } else if (keyCodes.end === e.which) {\n var _$menuitems = this.getMenuItems();\n\n _$menuitems[_$menuitems.length - 1].focus();\n } else if (keyCodes.home === e.which) {\n var _$menuitems2 = this.getMenuItems();\n\n _$menuitems2[0].focus();\n } else if (e.which >= 48 && e.which <= 90) {\n var _$menuitems3 = this.getMenuItems();\n\n var charPressed = String.fromCharCode(e.which).toLowerCase();\n\n for (var i = 0; i < _$menuitems3.length; i += 1) {\n var firstLetter = _$menuitems3[i].textContent && _$menuitems3[i].textContent[0].toLowerCase();\n\n if (firstLetter === charPressed) {\n _$menuitems3[i].focus();\n\n break;\n }\n }\n }\n }\n };\n\n _proto.handleProps = function handleProps() {\n if (this.props.isOpen) {\n this.addEvents();\n } else {\n this.removeEvents();\n }\n };\n\n _proto.toggle = function toggle(e) {\n if (this.props.disabled) {\n return e && e.preventDefault();\n }\n\n return this.props.toggle(e);\n };\n\n _proto.render = function render() {\n var _classNames, _ref;\n\n var _omit = omit(this.props, ['toggle', 'disabled', 'inNavbar', 'a11y']),\n className = _omit.className,\n cssModule = _omit.cssModule,\n direction = _omit.direction,\n isOpen = _omit.isOpen,\n group = _omit.group,\n size = _omit.size,\n nav = _omit.nav,\n setActiveFromChild = _omit.setActiveFromChild,\n active = _omit.active,\n addonType = _omit.addonType,\n tag = _omit.tag,\n menuRole = _omit.menuRole,\n attrs = _objectWithoutPropertiesLoose(_omit, _excluded);\n\n var Tag = tag || (nav ? 'li' : 'div');\n var subItemIsActive = false;\n\n if (setActiveFromChild) {\n React.Children.map(this.props.children[1].props.children, function (dropdownItem) {\n if (dropdownItem && dropdownItem.props.active) subItemIsActive = true;\n });\n }\n\n var classes = mapToCssModules(classNames(className, direction !== 'down' && \"drop\" + direction, nav && active ? 'active' : false, setActiveFromChild && subItemIsActive ? 'active' : false, (_classNames = {}, _classNames[\"input-group-\" + addonType] = addonType, _classNames['btn-group'] = group, _classNames[\"btn-group-\" + size] = !!size, _classNames.dropdown = !group && !addonType, _classNames.show = isOpen, _classNames['nav-item'] = nav, _classNames)), cssModule);\n return /*#__PURE__*/React.createElement(DropdownContext.Provider, {\n value: this.getContextValue()\n }, /*#__PURE__*/React.createElement(Manager, null, /*#__PURE__*/React.createElement(Tag, _extends({}, attrs, (_ref = {}, _ref[typeof Tag === 'string' ? 'ref' : 'innerRef'] = this.containerRef, _ref), {\n onKeyDown: this.handleKeyDown,\n className: classes\n }))));\n };\n\n return Dropdown;\n}(React.Component);\n\nDropdown.propTypes = propTypes;\nDropdown.defaultProps = defaultProps;\nexport default Dropdown;","import _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport Dropdown from './Dropdown';\nimport { omit } from './utils';\nvar omitKeys = ['defaultOpen'];\n\nvar UncontrolledDropdown = /*#__PURE__*/function (_Component) {\n _inheritsLoose(UncontrolledDropdown, _Component);\n\n function UncontrolledDropdown(props) {\n var _this;\n\n _this = _Component.call(this, props) || this;\n _this.state = {\n isOpen: props.defaultOpen || false\n };\n _this.toggle = _this.toggle.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n var _proto = UncontrolledDropdown.prototype;\n\n _proto.toggle = function toggle(e) {\n var _this2 = this;\n\n var isOpen = !this.state.isOpen;\n this.setState({\n isOpen: isOpen\n }, function () {\n if (_this2.props.onToggle) {\n _this2.props.onToggle(e, isOpen);\n }\n });\n };\n\n _proto.render = function render() {\n return /*#__PURE__*/React.createElement(Dropdown, _extends({\n isOpen: this.state.isOpen,\n toggle: this.toggle\n }, omit(this.props, omitKeys)));\n };\n\n return UncontrolledDropdown;\n}(Component);\n\nexport { UncontrolledDropdown as default };\nUncontrolledDropdown.propTypes = _objectSpread({\n defaultOpen: PropTypes.bool,\n onToggle: PropTypes.func\n}, Dropdown.propTypes);","/**\n * Takes an argument and if it's an array, returns the first item in the array,\n * otherwise returns the argument. Used for Preact compatibility.\n */\nexport var unwrapArray = function unwrapArray(arg) {\n return Array.isArray(arg) ? arg[0] : arg;\n};\n/**\n * Takes a maybe-undefined function and arbitrary args and invokes the function\n * only if it is defined.\n */\n\nexport var safeInvoke = function safeInvoke(fn) {\n if (typeof fn === \"function\") {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return fn.apply(void 0, args);\n }\n};\n/**\n * Does a shallow equality check of two objects by comparing the reference\n * equality of each value.\n */\n\nexport var shallowEqual = function shallowEqual(objA, objB) {\n var aKeys = Object.keys(objA);\n var bKeys = Object.keys(objB);\n\n if (bKeys.length !== aKeys.length) {\n return false;\n }\n\n for (var i = 0; i < bKeys.length; i++) {\n var key = aKeys[i];\n\n if (objA[key] !== objB[key]) {\n return false;\n }\n }\n\n return true;\n};\n/**\n * Sets a ref using either a ref callback or a ref object\n */\n\nexport var setRef = function setRef(ref, node) {\n // if its a function call it\n if (typeof ref === \"function\") {\n return safeInvoke(ref, node);\n } // otherwise we should treat it as a ref object\n else if (ref != null) {\n ref.current = node;\n }\n};","import _extends from \"@babel/runtime/helpers/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/inheritsLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport * as React from 'react';\nimport warning from 'warning';\nimport { ManagerReferenceNodeSetterContext } from './Manager';\nimport { safeInvoke, unwrapArray, setRef } from './utils';\n\nvar InnerReference =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(InnerReference, _React$Component);\n\n function InnerReference() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"refHandler\", function (node) {\n setRef(_this.props.innerRef, node);\n safeInvoke(_this.props.setReferenceNode, node);\n });\n\n return _this;\n }\n\n var _proto = InnerReference.prototype;\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n setRef(this.props.innerRef, null);\n };\n\n _proto.render = function render() {\n warning(Boolean(this.props.setReferenceNode), '`Reference` should not be used outside of a `Manager` component.');\n return unwrapArray(this.props.children)({\n ref: this.refHandler\n });\n };\n\n return InnerReference;\n}(React.Component);\n\nexport default function Reference(props) {\n return React.createElement(ManagerReferenceNodeSetterContext.Consumer, null, function (setReferenceNode) {\n return React.createElement(InnerReference, _extends({\n setReferenceNode: setReferenceNode\n }, props));\n });\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nvar _excluded = [\"active\", \"aria-label\", \"block\", \"className\", \"close\", \"cssModule\", \"color\", \"outline\", \"size\", \"tag\", \"innerRef\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n active: PropTypes.bool,\n 'aria-label': PropTypes.string,\n block: PropTypes.bool,\n color: PropTypes.string,\n disabled: PropTypes.bool,\n outline: PropTypes.bool,\n tag: tagPropType,\n innerRef: PropTypes.oneOfType([PropTypes.object, PropTypes.func, PropTypes.string]),\n onClick: PropTypes.func,\n size: PropTypes.string,\n children: PropTypes.node,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n close: PropTypes.bool\n};\nvar defaultProps = {\n color: 'secondary',\n tag: 'button'\n};\n\nvar Button = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Button, _React$Component);\n\n function Button(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n _this.onClick = _this.onClick.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n var _proto = Button.prototype;\n\n _proto.onClick = function onClick(e) {\n if (this.props.disabled) {\n e.preventDefault();\n return;\n }\n\n if (this.props.onClick) {\n return this.props.onClick(e);\n }\n };\n\n _proto.render = function render() {\n var _this$props = this.props,\n active = _this$props.active,\n ariaLabel = _this$props['aria-label'],\n block = _this$props.block,\n className = _this$props.className,\n close = _this$props.close,\n cssModule = _this$props.cssModule,\n color = _this$props.color,\n outline = _this$props.outline,\n size = _this$props.size,\n Tag = _this$props.tag,\n innerRef = _this$props.innerRef,\n attributes = _objectWithoutPropertiesLoose(_this$props, _excluded);\n\n if (close && typeof attributes.children === 'undefined') {\n attributes.children = /*#__PURE__*/React.createElement(\"span\", {\n \"aria-hidden\": true\n }, \"\\xD7\");\n }\n\n var btnOutlineColor = \"btn\" + (outline ? '-outline' : '') + \"-\" + color;\n var classes = mapToCssModules(classNames(className, {\n close: close\n }, close || 'btn', close || btnOutlineColor, size ? \"btn-\" + size : false, block ? 'btn-block' : false, {\n active: active,\n disabled: this.props.disabled\n }), cssModule);\n\n if (attributes.href && Tag === 'button') {\n Tag = 'a';\n }\n\n var defaultAriaLabel = close ? 'Close' : null;\n return /*#__PURE__*/React.createElement(Tag, _extends({\n type: Tag === 'button' && attributes.onClick ? 'button' : undefined\n }, attributes, {\n className: classes,\n ref: innerRef,\n onClick: this.onClick,\n \"aria-label\": ariaLabel || defaultAriaLabel\n }));\n };\n\n return Button;\n}(React.Component);\n\nButton.propTypes = propTypes;\nButton.defaultProps = defaultProps;\nexport default Button;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nvar _excluded = [\"className\", \"color\", \"cssModule\", \"caret\", \"split\", \"nav\", \"tag\", \"innerRef\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { Reference } from 'react-popper';\nimport { DropdownContext } from './DropdownContext';\nimport { mapToCssModules, tagPropType } from './utils';\nimport Button from './Button';\nvar propTypes = {\n caret: PropTypes.bool,\n color: PropTypes.string,\n children: PropTypes.node,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n disabled: PropTypes.bool,\n onClick: PropTypes.func,\n 'aria-haspopup': PropTypes.bool,\n split: PropTypes.bool,\n tag: tagPropType,\n nav: PropTypes.bool\n};\nvar defaultProps = {\n color: 'secondary',\n 'aria-haspopup': true\n};\n\nvar DropdownToggle = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(DropdownToggle, _React$Component);\n\n function DropdownToggle(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n _this.onClick = _this.onClick.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n var _proto = DropdownToggle.prototype;\n\n _proto.onClick = function onClick(e) {\n if (this.props.disabled || this.context.disabled) {\n e.preventDefault();\n return;\n }\n\n if (this.props.nav && !this.props.tag) {\n e.preventDefault();\n }\n\n if (this.props.onClick) {\n this.props.onClick(e);\n }\n\n this.context.toggle(e);\n };\n\n _proto.getRole = function getRole() {\n return this.context.menuRole || this.props['aria-haspopup'];\n };\n\n _proto.render = function render() {\n var _this2 = this;\n\n var _this$props = this.props,\n className = _this$props.className,\n color = _this$props.color,\n cssModule = _this$props.cssModule,\n caret = _this$props.caret,\n split = _this$props.split,\n nav = _this$props.nav,\n tag = _this$props.tag,\n innerRef = _this$props.innerRef,\n props = _objectWithoutPropertiesLoose(_this$props, _excluded);\n\n var ariaLabel = props['aria-label'] || 'Toggle Dropdown';\n var classes = mapToCssModules(classNames(className, {\n 'dropdown-toggle': caret || split,\n 'dropdown-toggle-split': split,\n 'nav-link': nav\n }), cssModule);\n var children = typeof props.children !== 'undefined' ? props.children : /*#__PURE__*/React.createElement(\"span\", {\n className: \"sr-only\"\n }, ariaLabel);\n var Tag;\n\n if (nav && !tag) {\n Tag = 'a';\n props.href = '#';\n } else if (!tag) {\n Tag = Button;\n props.color = color;\n props.cssModule = cssModule;\n } else {\n Tag = tag;\n }\n\n if (this.context.inNavbar) {\n return /*#__PURE__*/React.createElement(Tag, _extends({}, props, {\n className: classes,\n onClick: this.onClick,\n \"aria-expanded\": this.context.isOpen,\n \"aria-haspopup\": this.getRole(),\n children: children\n }));\n }\n\n return /*#__PURE__*/React.createElement(Reference, {\n innerRef: innerRef\n }, function (_ref) {\n var _ref2;\n\n var ref = _ref.ref;\n return /*#__PURE__*/React.createElement(Tag, _extends({}, props, (_ref2 = {}, _ref2[typeof Tag === 'string' ? 'ref' : 'innerRef'] = ref, _ref2), {\n className: classes,\n onClick: _this2.onClick,\n \"aria-expanded\": _this2.context.isOpen,\n \"aria-haspopup\": _this2.getRole(),\n children: children\n }));\n });\n };\n\n return DropdownToggle;\n}(React.Component);\n\nDropdownToggle.propTypes = propTypes;\nDropdownToggle.defaultProps = defaultProps;\nDropdownToggle.contextType = DropdownContext;\nexport default DropdownToggle;","export default typeof window !== 'undefined' && typeof document !== 'undefined' && typeof navigator !== 'undefined';\n","import isBrowser from './isBrowser';\n\nconst timeoutDuration = (function(){\n const longerTimeoutBrowsers = ['Edge', 'Trident', 'Firefox'];\n for (let i = 0; i < longerTimeoutBrowsers.length; i += 1) {\n if (isBrowser && navigator.userAgent.indexOf(longerTimeoutBrowsers[i]) >= 0) {\n return 1;\n }\n }\n return 0;\n}());\n\nexport function microtaskDebounce(fn) {\n let called = false\n return () => {\n if (called) {\n return\n }\n called = true\n window.Promise.resolve().then(() => {\n called = false\n fn()\n })\n }\n}\n\nexport function taskDebounce(fn) {\n let scheduled = false;\n return () => {\n if (!scheduled) {\n scheduled = true;\n setTimeout(() => {\n scheduled = false;\n fn();\n }, timeoutDuration);\n }\n };\n}\n\nconst supportsMicroTasks = isBrowser && window.Promise\n\n\n/**\n* Create a debounced version of a method, that's asynchronously deferred\n* but called in the minimum time possible.\n*\n* @method\n* @memberof Popper.Utils\n* @argument {Function} fn\n* @returns {Function}\n*/\nexport default (supportsMicroTasks\n ? microtaskDebounce\n : taskDebounce);\n","/**\n * Check if the given variable is a function\n * @method\n * @memberof Popper.Utils\n * @argument {Any} functionToCheck - variable to check\n * @returns {Boolean} answer to: is a function?\n */\nexport default function isFunction(functionToCheck) {\n const getType = {};\n return (\n functionToCheck &&\n getType.toString.call(functionToCheck) === '[object Function]'\n );\n}\n","/**\n * Get CSS computed property of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Eement} element\n * @argument {String} property\n */\nexport default function getStyleComputedProperty(element, property) {\n if (element.nodeType !== 1) {\n return [];\n }\n // NOTE: 1 DOM access here\n const window = element.ownerDocument.defaultView;\n const css = window.getComputedStyle(element, null);\n return property ? css[property] : css;\n}\n","/**\n * Returns the parentNode or the host of the element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} parent\n */\nexport default function getParentNode(element) {\n if (element.nodeName === 'HTML') {\n return element;\n }\n return element.parentNode || element.host;\n}\n","import getStyleComputedProperty from './getStyleComputedProperty';\nimport getParentNode from './getParentNode';\n\n/**\n * Returns the scrolling parent of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} scroll parent\n */\nexport default function getScrollParent(element) {\n // Return body, `getScroll` will take care to get the correct `scrollTop` from it\n if (!element) {\n return document.body\n }\n\n switch (element.nodeName) {\n case 'HTML':\n case 'BODY':\n return element.ownerDocument.body\n case '#document':\n return element.body\n }\n\n // Firefox want us to check `-x` and `-y` variations as well\n const { overflow, overflowX, overflowY } = getStyleComputedProperty(element);\n if (/(auto|scroll|overlay)/.test(overflow + overflowY + overflowX)) {\n return element;\n }\n\n return getScrollParent(getParentNode(element));\n}\n","/**\n * Returns the reference node of the reference object, or the reference object itself.\n * @method\n * @memberof Popper.Utils\n * @param {Element|Object} reference - the reference element (the popper will be relative to this)\n * @returns {Element} parent\n */\nexport default function getReferenceNode(reference) {\n return reference && reference.referenceNode ? reference.referenceNode : reference;\n}\n","import isBrowser from './isBrowser';\n\nconst isIE11 = isBrowser && !!(window.MSInputMethodContext && document.documentMode);\nconst isIE10 = isBrowser && /MSIE 10/.test(navigator.userAgent);\n\n/**\n * Determines if the browser is Internet Explorer\n * @method\n * @memberof Popper.Utils\n * @param {Number} version to check\n * @returns {Boolean} isIE\n */\nexport default function isIE(version) {\n if (version === 11) {\n return isIE11;\n }\n if (version === 10) {\n return isIE10;\n }\n return isIE11 || isIE10;\n}\n","import getStyleComputedProperty from './getStyleComputedProperty';\nimport isIE from './isIE';\n/**\n * Returns the offset parent of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} offset parent\n */\nexport default function getOffsetParent(element) {\n if (!element) {\n return document.documentElement;\n }\n\n const noOffsetParent = isIE(10) ? document.body : null;\n\n // NOTE: 1 DOM access here\n let offsetParent = element.offsetParent || null;\n // Skip hidden elements which don't have an offsetParent\n while (offsetParent === noOffsetParent && element.nextElementSibling) {\n offsetParent = (element = element.nextElementSibling).offsetParent;\n }\n\n const nodeName = offsetParent && offsetParent.nodeName;\n\n if (!nodeName || nodeName === 'BODY' || nodeName === 'HTML') {\n return element ? element.ownerDocument.documentElement : document.documentElement;\n }\n\n // .offsetParent will return the closest TH, TD or TABLE in case\n // no offsetParent is present, I hate this job...\n if (\n ['TH', 'TD', 'TABLE'].indexOf(offsetParent.nodeName) !== -1 &&\n getStyleComputedProperty(offsetParent, 'position') === 'static'\n ) {\n return getOffsetParent(offsetParent);\n }\n\n return offsetParent;\n}\n","/**\n * Finds the root node (document, shadowDOM root) of the given element\n * @method\n * @memberof Popper.Utils\n * @argument {Element} node\n * @returns {Element} root node\n */\nexport default function getRoot(node) {\n if (node.parentNode !== null) {\n return getRoot(node.parentNode);\n }\n\n return node;\n}\n","import isOffsetContainer from './isOffsetContainer';\nimport getRoot from './getRoot';\nimport getOffsetParent from './getOffsetParent';\n\n/**\n * Finds the offset parent common to the two provided nodes\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element1\n * @argument {Element} element2\n * @returns {Element} common offset parent\n */\nexport default function findCommonOffsetParent(element1, element2) {\n // This check is needed to avoid errors in case one of the elements isn't defined for any reason\n if (!element1 || !element1.nodeType || !element2 || !element2.nodeType) {\n return document.documentElement;\n }\n\n // Here we make sure to give as \"start\" the element that comes first in the DOM\n const order =\n element1.compareDocumentPosition(element2) &\n Node.DOCUMENT_POSITION_FOLLOWING;\n const start = order ? element1 : element2;\n const end = order ? element2 : element1;\n\n // Get common ancestor container\n const range = document.createRange();\n range.setStart(start, 0);\n range.setEnd(end, 0);\n const { commonAncestorContainer } = range;\n\n // Both nodes are inside #document\n if (\n (element1 !== commonAncestorContainer &&\n element2 !== commonAncestorContainer) ||\n start.contains(end)\n ) {\n if (isOffsetContainer(commonAncestorContainer)) {\n return commonAncestorContainer;\n }\n\n return getOffsetParent(commonAncestorContainer);\n }\n\n // one of the nodes is inside shadowDOM, find which one\n const element1root = getRoot(element1);\n if (element1root.host) {\n return findCommonOffsetParent(element1root.host, element2);\n } else {\n return findCommonOffsetParent(element1, getRoot(element2).host);\n }\n}\n","import getOffsetParent from './getOffsetParent';\n\nexport default function isOffsetContainer(element) {\n const { nodeName } = element;\n if (nodeName === 'BODY') {\n return false;\n }\n return (\n nodeName === 'HTML' || getOffsetParent(element.firstElementChild) === element\n );\n}\n","/**\n * Gets the scroll value of the given element in the given side (top and left)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @argument {String} side `top` or `left`\n * @returns {number} amount of scrolled pixels\n */\nexport default function getScroll(element, side = 'top') {\n const upperSide = side === 'top' ? 'scrollTop' : 'scrollLeft';\n const nodeName = element.nodeName;\n\n if (nodeName === 'BODY' || nodeName === 'HTML') {\n const html = element.ownerDocument.documentElement;\n const scrollingElement = element.ownerDocument.scrollingElement || html;\n return scrollingElement[upperSide];\n }\n\n return element[upperSide];\n}\n","/*\n * Helper to detect borders of a given element\n * @method\n * @memberof Popper.Utils\n * @param {CSSStyleDeclaration} styles\n * Result of `getStyleComputedProperty` on the given element\n * @param {String} axis - `x` or `y`\n * @return {number} borders - The borders size of the given axis\n */\n\nexport default function getBordersSize(styles, axis) {\n const sideA = axis === 'x' ? 'Left' : 'Top';\n const sideB = sideA === 'Left' ? 'Right' : 'Bottom';\n\n return (\n parseFloat(styles[`border${sideA}Width`]) +\n parseFloat(styles[`border${sideB}Width`])\n );\n}\n","import isIE from './isIE';\n\nfunction getSize(axis, body, html, computedStyle) {\n return Math.max(\n body[`offset${axis}`],\n body[`scroll${axis}`],\n html[`client${axis}`],\n html[`offset${axis}`],\n html[`scroll${axis}`],\n isIE(10)\n ? (parseInt(html[`offset${axis}`]) + \n parseInt(computedStyle[`margin${axis === 'Height' ? 'Top' : 'Left'}`]) + \n parseInt(computedStyle[`margin${axis === 'Height' ? 'Bottom' : 'Right'}`]))\n : 0 \n );\n}\n\nexport default function getWindowSizes(document) {\n const body = document.body;\n const html = document.documentElement;\n const computedStyle = isIE(10) && getComputedStyle(html);\n\n return {\n height: getSize('Height', body, html, computedStyle),\n width: getSize('Width', body, html, computedStyle),\n };\n}\n","/**\n * Given element offsets, generate an output similar to getBoundingClientRect\n * @method\n * @memberof Popper.Utils\n * @argument {Object} offsets\n * @returns {Object} ClientRect like output\n */\nexport default function getClientRect(offsets) {\n return {\n ...offsets,\n right: offsets.left + offsets.width,\n bottom: offsets.top + offsets.height,\n };\n}\n","import getStyleComputedProperty from './getStyleComputedProperty';\nimport getBordersSize from './getBordersSize';\nimport getWindowSizes from './getWindowSizes';\nimport getScroll from './getScroll';\nimport getClientRect from './getClientRect';\nimport isIE from './isIE';\n\n/**\n * Get bounding client rect of given element\n * @method\n * @memberof Popper.Utils\n * @param {HTMLElement} element\n * @return {Object} client rect\n */\nexport default function getBoundingClientRect(element) {\n let rect = {};\n\n // IE10 10 FIX: Please, don't ask, the element isn't\n // considered in DOM in some circumstances...\n // This isn't reproducible in IE10 compatibility mode of IE11\n try {\n if (isIE(10)) {\n rect = element.getBoundingClientRect();\n const scrollTop = getScroll(element, 'top');\n const scrollLeft = getScroll(element, 'left');\n rect.top += scrollTop;\n rect.left += scrollLeft;\n rect.bottom += scrollTop;\n rect.right += scrollLeft;\n }\n else {\n rect = element.getBoundingClientRect();\n }\n }\n catch(e){}\n\n const result = {\n left: rect.left,\n top: rect.top,\n width: rect.right - rect.left,\n height: rect.bottom - rect.top,\n };\n\n // subtract scrollbar size from sizes\n const sizes = element.nodeName === 'HTML' ? getWindowSizes(element.ownerDocument) : {};\n const width =\n sizes.width || element.clientWidth || result.width;\n const height =\n sizes.height || element.clientHeight || result.height;\n\n let horizScrollbar = element.offsetWidth - width;\n let vertScrollbar = element.offsetHeight - height;\n\n // if an hypothetical scrollbar is detected, we must be sure it's not a `border`\n // we make this check conditional for performance reasons\n if (horizScrollbar || vertScrollbar) {\n const styles = getStyleComputedProperty(element);\n horizScrollbar -= getBordersSize(styles, 'x');\n vertScrollbar -= getBordersSize(styles, 'y');\n\n result.width -= horizScrollbar;\n result.height -= vertScrollbar;\n }\n\n return getClientRect(result);\n}\n","import getStyleComputedProperty from './getStyleComputedProperty';\nimport includeScroll from './includeScroll';\nimport getScrollParent from './getScrollParent';\nimport getBoundingClientRect from './getBoundingClientRect';\nimport runIsIE from './isIE';\nimport getClientRect from './getClientRect';\n\nexport default function getOffsetRectRelativeToArbitraryNode(children, parent, fixedPosition = false) {\n const isIE10 = runIsIE(10);\n const isHTML = parent.nodeName === 'HTML';\n const childrenRect = getBoundingClientRect(children);\n const parentRect = getBoundingClientRect(parent);\n const scrollParent = getScrollParent(children);\n\n const styles = getStyleComputedProperty(parent);\n const borderTopWidth = parseFloat(styles.borderTopWidth);\n const borderLeftWidth = parseFloat(styles.borderLeftWidth);\n\n // In cases where the parent is fixed, we must ignore negative scroll in offset calc\n if(fixedPosition && isHTML) {\n parentRect.top = Math.max(parentRect.top, 0);\n parentRect.left = Math.max(parentRect.left, 0);\n }\n let offsets = getClientRect({\n top: childrenRect.top - parentRect.top - borderTopWidth,\n left: childrenRect.left - parentRect.left - borderLeftWidth,\n width: childrenRect.width,\n height: childrenRect.height,\n });\n offsets.marginTop = 0;\n offsets.marginLeft = 0;\n\n // Subtract margins of documentElement in case it's being used as parent\n // we do this only on HTML because it's the only element that behaves\n // differently when margins are applied to it. The margins are included in\n // the box of the documentElement, in the other cases not.\n if (!isIE10 && isHTML) {\n const marginTop = parseFloat(styles.marginTop);\n const marginLeft = parseFloat(styles.marginLeft);\n\n offsets.top -= borderTopWidth - marginTop;\n offsets.bottom -= borderTopWidth - marginTop;\n offsets.left -= borderLeftWidth - marginLeft;\n offsets.right -= borderLeftWidth - marginLeft;\n\n // Attach marginTop and marginLeft because in some circumstances we may need them\n offsets.marginTop = marginTop;\n offsets.marginLeft = marginLeft;\n }\n\n if (\n isIE10 && !fixedPosition\n ? parent.contains(scrollParent)\n : parent === scrollParent && scrollParent.nodeName !== 'BODY'\n ) {\n offsets = includeScroll(offsets, parent);\n }\n\n return offsets;\n}\n","import getScroll from './getScroll';\n\n/*\n * Sum or subtract the element scroll values (left and top) from a given rect object\n * @method\n * @memberof Popper.Utils\n * @param {Object} rect - Rect object you want to change\n * @param {HTMLElement} element - The element from the function reads the scroll values\n * @param {Boolean} subtract - set to true if you want to subtract the scroll values\n * @return {Object} rect - The modifier rect object\n */\nexport default function includeScroll(rect, element, subtract = false) {\n const scrollTop = getScroll(element, 'top');\n const scrollLeft = getScroll(element, 'left');\n const modifier = subtract ? -1 : 1;\n rect.top += scrollTop * modifier;\n rect.bottom += scrollTop * modifier;\n rect.left += scrollLeft * modifier;\n rect.right += scrollLeft * modifier;\n return rect;\n}\n","import getStyleComputedProperty from './getStyleComputedProperty';\nimport getParentNode from './getParentNode';\n\n/**\n * Check if the given element is fixed or is inside a fixed parent\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @argument {Element} customContainer\n * @returns {Boolean} answer to \"isFixed?\"\n */\nexport default function isFixed(element) {\n const nodeName = element.nodeName;\n if (nodeName === 'BODY' || nodeName === 'HTML') {\n return false;\n }\n if (getStyleComputedProperty(element, 'position') === 'fixed') {\n return true;\n }\n const parentNode = getParentNode(element);\n if (!parentNode) {\n return false;\n }\n return isFixed(parentNode);\n}\n","import getStyleComputedProperty from './getStyleComputedProperty';\nimport isIE from './isIE';\n/**\n * Finds the first parent of an element that has a transformed property defined\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Element} first transformed parent or documentElement\n */\n\nexport default function getFixedPositionOffsetParent(element) {\n // This check is needed to avoid errors in case one of the elements isn't defined for any reason\n if (!element || !element.parentElement || isIE()) {\n return document.documentElement;\n }\n let el = element.parentElement;\n while (el && getStyleComputedProperty(el, 'transform') === 'none') {\n el = el.parentElement;\n }\n return el || document.documentElement;\n\n}\n","import getScrollParent from './getScrollParent';\nimport getParentNode from './getParentNode';\nimport getReferenceNode from './getReferenceNode';\nimport findCommonOffsetParent from './findCommonOffsetParent';\nimport getOffsetRectRelativeToArbitraryNode from './getOffsetRectRelativeToArbitraryNode';\nimport getViewportOffsetRectRelativeToArtbitraryNode from './getViewportOffsetRectRelativeToArtbitraryNode';\nimport getWindowSizes from './getWindowSizes';\nimport isFixed from './isFixed';\nimport getFixedPositionOffsetParent from './getFixedPositionOffsetParent';\n\n/**\n * Computed the boundaries limits and return them\n * @method\n * @memberof Popper.Utils\n * @param {HTMLElement} popper\n * @param {HTMLElement} reference\n * @param {number} padding\n * @param {HTMLElement} boundariesElement - Element used to define the boundaries\n * @param {Boolean} fixedPosition - Is in fixed position mode\n * @returns {Object} Coordinates of the boundaries\n */\nexport default function getBoundaries(\n popper,\n reference,\n padding,\n boundariesElement,\n fixedPosition = false\n) {\n // NOTE: 1 DOM access here\n\n let boundaries = { top: 0, left: 0 };\n const offsetParent = fixedPosition ? getFixedPositionOffsetParent(popper) : findCommonOffsetParent(popper, getReferenceNode(reference));\n\n // Handle viewport case\n if (boundariesElement === 'viewport' ) {\n boundaries = getViewportOffsetRectRelativeToArtbitraryNode(offsetParent, fixedPosition);\n }\n\n else {\n // Handle other cases based on DOM element used as boundaries\n let boundariesNode;\n if (boundariesElement === 'scrollParent') {\n boundariesNode = getScrollParent(getParentNode(reference));\n if (boundariesNode.nodeName === 'BODY') {\n boundariesNode = popper.ownerDocument.documentElement;\n }\n } else if (boundariesElement === 'window') {\n boundariesNode = popper.ownerDocument.documentElement;\n } else {\n boundariesNode = boundariesElement;\n }\n\n const offsets = getOffsetRectRelativeToArbitraryNode(\n boundariesNode,\n offsetParent,\n fixedPosition\n );\n\n // In case of HTML, we need a different computation\n if (boundariesNode.nodeName === 'HTML' && !isFixed(offsetParent)) {\n const { height, width } = getWindowSizes(popper.ownerDocument);\n boundaries.top += offsets.top - offsets.marginTop;\n boundaries.bottom = height + offsets.top;\n boundaries.left += offsets.left - offsets.marginLeft;\n boundaries.right = width + offsets.left;\n } else {\n // for all the other DOM elements, this one is good\n boundaries = offsets;\n }\n }\n\n // Add paddings\n padding = padding || 0;\n const isPaddingNumber = typeof padding === 'number';\n boundaries.left += isPaddingNumber ? padding : padding.left || 0; \n boundaries.top += isPaddingNumber ? padding : padding.top || 0; \n boundaries.right -= isPaddingNumber ? padding : padding.right || 0; \n boundaries.bottom -= isPaddingNumber ? padding : padding.bottom || 0; \n\n return boundaries;\n}\n","import getOffsetRectRelativeToArbitraryNode from './getOffsetRectRelativeToArbitraryNode';\nimport getScroll from './getScroll';\nimport getClientRect from './getClientRect';\n\nexport default function getViewportOffsetRectRelativeToArtbitraryNode(element, excludeScroll = false) {\n const html = element.ownerDocument.documentElement;\n const relativeOffset = getOffsetRectRelativeToArbitraryNode(element, html);\n const width = Math.max(html.clientWidth, window.innerWidth || 0);\n const height = Math.max(html.clientHeight, window.innerHeight || 0);\n\n const scrollTop = !excludeScroll ? getScroll(html) : 0;\n const scrollLeft = !excludeScroll ? getScroll(html, 'left') : 0;\n\n const offset = {\n top: scrollTop - relativeOffset.top + relativeOffset.marginTop,\n left: scrollLeft - relativeOffset.left + relativeOffset.marginLeft,\n width,\n height,\n };\n\n return getClientRect(offset);\n}\n","import getBoundaries from '../utils/getBoundaries';\n\nfunction getArea({ width, height }) {\n return width * height;\n}\n\n/**\n * Utility used to transform the `auto` placement to the placement with more\n * available space.\n * @method\n * @memberof Popper.Utils\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function computeAutoPlacement(\n placement,\n refRect,\n popper,\n reference,\n boundariesElement,\n padding = 0\n) {\n if (placement.indexOf('auto') === -1) {\n return placement;\n }\n\n const boundaries = getBoundaries(\n popper,\n reference,\n padding,\n boundariesElement\n );\n\n const rects = {\n top: {\n width: boundaries.width,\n height: refRect.top - boundaries.top,\n },\n right: {\n width: boundaries.right - refRect.right,\n height: boundaries.height,\n },\n bottom: {\n width: boundaries.width,\n height: boundaries.bottom - refRect.bottom,\n },\n left: {\n width: refRect.left - boundaries.left,\n height: boundaries.height,\n },\n };\n\n const sortedAreas = Object.keys(rects)\n .map(key => ({\n key,\n ...rects[key],\n area: getArea(rects[key]),\n }))\n .sort((a, b) => b.area - a.area);\n\n const filteredAreas = sortedAreas.filter(\n ({ width, height }) =>\n width >= popper.clientWidth && height >= popper.clientHeight\n );\n\n const computedPlacement = filteredAreas.length > 0\n ? filteredAreas[0].key\n : sortedAreas[0].key;\n\n const variation = placement.split('-')[1];\n\n return computedPlacement + (variation ? `-${variation}` : '');\n}\n","import findCommonOffsetParent from './findCommonOffsetParent';\nimport getOffsetRectRelativeToArbitraryNode from './getOffsetRectRelativeToArbitraryNode';\nimport getFixedPositionOffsetParent from './getFixedPositionOffsetParent';\nimport getReferenceNode from './getReferenceNode';\n\n/**\n * Get offsets to the reference element\n * @method\n * @memberof Popper.Utils\n * @param {Object} state\n * @param {Element} popper - the popper element\n * @param {Element} reference - the reference element (the popper will be relative to this)\n * @param {Element} fixedPosition - is in fixed position mode\n * @returns {Object} An object containing the offsets which will be applied to the popper\n */\nexport default function getReferenceOffsets(state, popper, reference, fixedPosition = null) {\n const commonOffsetParent = fixedPosition ? getFixedPositionOffsetParent(popper) : findCommonOffsetParent(popper, getReferenceNode(reference));\n return getOffsetRectRelativeToArbitraryNode(reference, commonOffsetParent, fixedPosition);\n}\n","/**\n * Get the outer sizes of the given element (offset size + margins)\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element\n * @returns {Object} object containing width and height properties\n */\nexport default function getOuterSizes(element) {\n const window = element.ownerDocument.defaultView;\n const styles = window.getComputedStyle(element);\n const x = parseFloat(styles.marginTop || 0) + parseFloat(styles.marginBottom || 0);\n const y = parseFloat(styles.marginLeft || 0) + parseFloat(styles.marginRight || 0);\n const result = {\n width: element.offsetWidth + y,\n height: element.offsetHeight + x,\n };\n return result;\n}\n","/**\n * Get the opposite placement of the given one\n * @method\n * @memberof Popper.Utils\n * @argument {String} placement\n * @returns {String} flipped placement\n */\nexport default function getOppositePlacement(placement) {\n const hash = { left: 'right', right: 'left', bottom: 'top', top: 'bottom' };\n return placement.replace(/left|right|bottom|top/g, matched => hash[matched]);\n}\n","import getOuterSizes from './getOuterSizes';\nimport getOppositePlacement from './getOppositePlacement';\n\n/**\n * Get offsets to the popper\n * @method\n * @memberof Popper.Utils\n * @param {Object} position - CSS position the Popper will get applied\n * @param {HTMLElement} popper - the popper element\n * @param {Object} referenceOffsets - the reference offsets (the popper will be relative to this)\n * @param {String} placement - one of the valid placement options\n * @returns {Object} popperOffsets - An object containing the offsets which will be applied to the popper\n */\nexport default function getPopperOffsets(popper, referenceOffsets, placement) {\n placement = placement.split('-')[0];\n\n // Get popper node sizes\n const popperRect = getOuterSizes(popper);\n\n // Add position, width and height to our offsets object\n const popperOffsets = {\n width: popperRect.width,\n height: popperRect.height,\n };\n\n // depending by the popper placement we have to compute its offsets slightly differently\n const isHoriz = ['right', 'left'].indexOf(placement) !== -1;\n const mainSide = isHoriz ? 'top' : 'left';\n const secondarySide = isHoriz ? 'left' : 'top';\n const measurement = isHoriz ? 'height' : 'width';\n const secondaryMeasurement = !isHoriz ? 'height' : 'width';\n\n popperOffsets[mainSide] =\n referenceOffsets[mainSide] +\n referenceOffsets[measurement] / 2 -\n popperRect[measurement] / 2;\n if (placement === secondarySide) {\n popperOffsets[secondarySide] =\n referenceOffsets[secondarySide] - popperRect[secondaryMeasurement];\n } else {\n popperOffsets[secondarySide] =\n referenceOffsets[getOppositePlacement(secondarySide)];\n }\n\n return popperOffsets;\n}\n","/**\n * Mimics the `find` method of Array\n * @method\n * @memberof Popper.Utils\n * @argument {Array} arr\n * @argument prop\n * @argument value\n * @returns index or -1\n */\nexport default function find(arr, check) {\n // use native find if supported\n if (Array.prototype.find) {\n return arr.find(check);\n }\n\n // use `filter` to obtain the same behavior of `find`\n return arr.filter(check)[0];\n}\n","import isFunction from './isFunction';\nimport findIndex from './findIndex';\nimport getClientRect from '../utils/getClientRect';\n\n/**\n * Loop trough the list of modifiers and run them in order,\n * each of them will then edit the data object.\n * @method\n * @memberof Popper.Utils\n * @param {dataObject} data\n * @param {Array} modifiers\n * @param {String} ends - Optional modifier name used as stopper\n * @returns {dataObject}\n */\nexport default function runModifiers(modifiers, data, ends) {\n const modifiersToRun = ends === undefined\n ? modifiers\n : modifiers.slice(0, findIndex(modifiers, 'name', ends));\n\n modifiersToRun.forEach(modifier => {\n if (modifier['function']) { // eslint-disable-line dot-notation\n console.warn('`modifier.function` is deprecated, use `modifier.fn`!');\n }\n const fn = modifier['function'] || modifier.fn; // eslint-disable-line dot-notation\n if (modifier.enabled && isFunction(fn)) {\n // Add properties to offsets to make them a complete clientRect object\n // we do this before each modifier to make sure the previous one doesn't\n // mess with these values\n data.offsets.popper = getClientRect(data.offsets.popper);\n data.offsets.reference = getClientRect(data.offsets.reference);\n\n data = fn(data, modifier);\n }\n });\n\n return data;\n}\n","import find from './find';\n\n/**\n * Return the index of the matching object\n * @method\n * @memberof Popper.Utils\n * @argument {Array} arr\n * @argument prop\n * @argument value\n * @returns index or -1\n */\nexport default function findIndex(arr, prop, value) {\n // use native findIndex if supported\n if (Array.prototype.findIndex) {\n return arr.findIndex(cur => cur[prop] === value);\n }\n\n // use `find` + `indexOf` if `findIndex` isn't supported\n const match = find(arr, obj => obj[prop] === value);\n return arr.indexOf(match);\n}\n","import computeAutoPlacement from '../utils/computeAutoPlacement';\nimport getReferenceOffsets from '../utils/getReferenceOffsets';\nimport getPopperOffsets from '../utils/getPopperOffsets';\nimport runModifiers from '../utils/runModifiers';\n\n/**\n * Updates the position of the popper, computing the new offsets and applying\n * the new style.
\n * Prefer `scheduleUpdate` over `update` because of performance reasons.\n * @method\n * @memberof Popper\n */\nexport default function update() {\n // if popper is destroyed, don't perform any further update\n if (this.state.isDestroyed) {\n return;\n }\n\n let data = {\n instance: this,\n styles: {},\n arrowStyles: {},\n attributes: {},\n flipped: false,\n offsets: {},\n };\n\n // compute reference element offsets\n data.offsets.reference = getReferenceOffsets(\n this.state,\n this.popper,\n this.reference,\n this.options.positionFixed\n );\n\n // compute auto placement, store placement inside the data object,\n // modifiers will be able to edit `placement` if needed\n // and refer to originalPlacement to know the original value\n data.placement = computeAutoPlacement(\n this.options.placement,\n data.offsets.reference,\n this.popper,\n this.reference,\n this.options.modifiers.flip.boundariesElement,\n this.options.modifiers.flip.padding\n );\n\n // store the computed placement inside `originalPlacement`\n data.originalPlacement = data.placement;\n\n data.positionFixed = this.options.positionFixed;\n\n // compute the popper offsets\n data.offsets.popper = getPopperOffsets(\n this.popper,\n data.offsets.reference,\n data.placement\n );\n\n data.offsets.popper.position = this.options.positionFixed\n ? 'fixed'\n : 'absolute';\n\n // run the modifiers\n data = runModifiers(this.modifiers, data);\n\n // the first `update` will call `onCreate` callback\n // the other ones will call `onUpdate` callback\n if (!this.state.isCreated) {\n this.state.isCreated = true;\n this.options.onCreate(data);\n } else {\n this.options.onUpdate(data);\n }\n}\n","/**\n * Helper used to know if the given modifier is enabled.\n * @method\n * @memberof Popper.Utils\n * @returns {Boolean}\n */\nexport default function isModifierEnabled(modifiers, modifierName) {\n return modifiers.some(\n ({ name, enabled }) => enabled && name === modifierName\n );\n}\n","/**\n * Get the prefixed supported property name\n * @method\n * @memberof Popper.Utils\n * @argument {String} property (camelCase)\n * @returns {String} prefixed property (camelCase or PascalCase, depending on the vendor prefix)\n */\nexport default function getSupportedPropertyName(property) {\n const prefixes = [false, 'ms', 'Webkit', 'Moz', 'O'];\n const upperProp = property.charAt(0).toUpperCase() + property.slice(1);\n\n for (let i = 0; i < prefixes.length; i++) {\n const prefix = prefixes[i];\n const toCheck = prefix ? `${prefix}${upperProp}` : property;\n if (typeof document.body.style[toCheck] !== 'undefined') {\n return toCheck;\n }\n }\n return null;\n}\n","import isModifierEnabled from '../utils/isModifierEnabled';\nimport getSupportedPropertyName from '../utils/getSupportedPropertyName';\n\n/**\n * Destroys the popper.\n * @method\n * @memberof Popper\n */\nexport default function destroy() {\n this.state.isDestroyed = true;\n\n // touch DOM only if `applyStyle` modifier is enabled\n if (isModifierEnabled(this.modifiers, 'applyStyle')) {\n this.popper.removeAttribute('x-placement');\n this.popper.style.position = '';\n this.popper.style.top = '';\n this.popper.style.left = '';\n this.popper.style.right = '';\n this.popper.style.bottom = '';\n this.popper.style.willChange = '';\n this.popper.style[getSupportedPropertyName('transform')] = '';\n }\n\n this.disableEventListeners();\n\n // remove the popper if user explicitly asked for the deletion on destroy\n // do not use `remove` because IE11 doesn't support it\n if (this.options.removeOnDestroy) {\n this.popper.parentNode.removeChild(this.popper);\n }\n return this;\n}\n","/**\n * Get the window associated with the element\n * @argument {Element} element\n * @returns {Window}\n */\nexport default function getWindow(element) {\n const ownerDocument = element.ownerDocument;\n return ownerDocument ? ownerDocument.defaultView : window;\n}\n","import getScrollParent from './getScrollParent';\nimport getWindow from './getWindow';\n\nfunction attachToScrollParents(scrollParent, event, callback, scrollParents) {\n const isBody = scrollParent.nodeName === 'BODY';\n const target = isBody ? scrollParent.ownerDocument.defaultView : scrollParent;\n target.addEventListener(event, callback, { passive: true });\n\n if (!isBody) {\n attachToScrollParents(\n getScrollParent(target.parentNode),\n event,\n callback,\n scrollParents\n );\n }\n scrollParents.push(target);\n}\n\n/**\n * Setup needed event listeners used to update the popper position\n * @method\n * @memberof Popper.Utils\n * @private\n */\nexport default function setupEventListeners(\n reference,\n options,\n state,\n updateBound\n) {\n // Resize event listener on window\n state.updateBound = updateBound;\n getWindow(reference).addEventListener('resize', state.updateBound, { passive: true });\n\n // Scroll event listener on scroll parents\n const scrollElement = getScrollParent(reference);\n attachToScrollParents(\n scrollElement,\n 'scroll',\n state.updateBound,\n state.scrollParents\n );\n state.scrollElement = scrollElement;\n state.eventsEnabled = true;\n\n return state;\n}\n","import setupEventListeners from '../utils/setupEventListeners';\n\n/**\n * It will add resize/scroll events and start recalculating\n * position of the popper element when they are triggered.\n * @method\n * @memberof Popper\n */\nexport default function enableEventListeners() {\n if (!this.state.eventsEnabled) {\n this.state = setupEventListeners(\n this.reference,\n this.options,\n this.state,\n this.scheduleUpdate\n );\n }\n}\n","import removeEventListeners from '../utils/removeEventListeners';\n\n/**\n * It will remove resize/scroll events and won't recalculate popper position\n * when they are triggered. It also won't trigger `onUpdate` callback anymore,\n * unless you call `update` method manually.\n * @method\n * @memberof Popper\n */\nexport default function disableEventListeners() {\n if (this.state.eventsEnabled) {\n cancelAnimationFrame(this.scheduleUpdate);\n this.state = removeEventListeners(this.reference, this.state);\n }\n}\n","import getWindow from './getWindow';\n\n/**\n * Remove event listeners used to update the popper position\n * @method\n * @memberof Popper.Utils\n * @private\n */\nexport default function removeEventListeners(reference, state) {\n // Remove resize event listener on window\n getWindow(reference).removeEventListener('resize', state.updateBound);\n\n // Remove scroll event listener on scroll parents\n state.scrollParents.forEach(target => {\n target.removeEventListener('scroll', state.updateBound);\n });\n\n // Reset state\n state.updateBound = null;\n state.scrollParents = [];\n state.scrollElement = null;\n state.eventsEnabled = false;\n return state;\n}\n","/**\n * Tells if a given input is a number\n * @method\n * @memberof Popper.Utils\n * @param {*} input to check\n * @return {Boolean}\n */\nexport default function isNumeric(n) {\n return n !== '' && !isNaN(parseFloat(n)) && isFinite(n);\n}\n","import isNumeric from './isNumeric';\n\n/**\n * Set the style to the given popper\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element - Element to apply the style to\n * @argument {Object} styles\n * Object with a list of properties and values which will be applied to the element\n */\nexport default function setStyles(element, styles) {\n Object.keys(styles).forEach(prop => {\n let unit = '';\n // add unit if the value is numeric and is one of the following\n if (\n ['width', 'height', 'top', 'right', 'bottom', 'left'].indexOf(prop) !==\n -1 &&\n isNumeric(styles[prop])\n ) {\n unit = 'px';\n }\n element.style[prop] = styles[prop] + unit;\n });\n}\n","import getSupportedPropertyName from '../utils/getSupportedPropertyName';\nimport find from '../utils/find';\nimport getOffsetParent from '../utils/getOffsetParent';\nimport getBoundingClientRect from '../utils/getBoundingClientRect';\nimport getRoundedOffsets from '../utils/getRoundedOffsets';\nimport isBrowser from '../utils/isBrowser';\n\nconst isFirefox = isBrowser && /Firefox/i.test(navigator.userAgent);\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function computeStyle(data, options) {\n const { x, y } = options;\n const { popper } = data.offsets;\n\n // Remove this legacy support in Popper.js v2\n const legacyGpuAccelerationOption = find(\n data.instance.modifiers,\n modifier => modifier.name === 'applyStyle'\n ).gpuAcceleration;\n if (legacyGpuAccelerationOption !== undefined) {\n console.warn(\n 'WARNING: `gpuAcceleration` option moved to `computeStyle` modifier and will not be supported in future versions of Popper.js!'\n );\n }\n const gpuAcceleration =\n legacyGpuAccelerationOption !== undefined\n ? legacyGpuAccelerationOption\n : options.gpuAcceleration;\n\n const offsetParent = getOffsetParent(data.instance.popper);\n const offsetParentRect = getBoundingClientRect(offsetParent);\n\n // Styles\n const styles = {\n position: popper.position,\n };\n\n const offsets = getRoundedOffsets(\n data,\n window.devicePixelRatio < 2 || !isFirefox\n );\n\n const sideA = x === 'bottom' ? 'top' : 'bottom';\n const sideB = y === 'right' ? 'left' : 'right';\n\n // if gpuAcceleration is set to `true` and transform is supported,\n // we use `translate3d` to apply the position to the popper we\n // automatically use the supported prefixed version if needed\n const prefixedProperty = getSupportedPropertyName('transform');\n\n // now, let's make a step back and look at this code closely (wtf?)\n // If the content of the popper grows once it's been positioned, it\n // may happen that the popper gets misplaced because of the new content\n // overflowing its reference element\n // To avoid this problem, we provide two options (x and y), which allow\n // the consumer to define the offset origin.\n // If we position a popper on top of a reference element, we can set\n // `x` to `top` to make the popper grow towards its top instead of\n // its bottom.\n let left, top;\n if (sideA === 'bottom') {\n // when offsetParent is the positioning is relative to the bottom of the screen (excluding the scrollbar)\n // and not the bottom of the html element\n if (offsetParent.nodeName === 'HTML') {\n top = -offsetParent.clientHeight + offsets.bottom;\n } else {\n top = -offsetParentRect.height + offsets.bottom;\n }\n } else {\n top = offsets.top;\n }\n if (sideB === 'right') {\n if (offsetParent.nodeName === 'HTML') {\n left = -offsetParent.clientWidth + offsets.right;\n } else {\n left = -offsetParentRect.width + offsets.right;\n }\n } else {\n left = offsets.left;\n }\n if (gpuAcceleration && prefixedProperty) {\n styles[prefixedProperty] = `translate3d(${left}px, ${top}px, 0)`;\n styles[sideA] = 0;\n styles[sideB] = 0;\n styles.willChange = 'transform';\n } else {\n // othwerise, we use the standard `top`, `left`, `bottom` and `right` properties\n const invertTop = sideA === 'bottom' ? -1 : 1;\n const invertLeft = sideB === 'right' ? -1 : 1;\n styles[sideA] = top * invertTop;\n styles[sideB] = left * invertLeft;\n styles.willChange = `${sideA}, ${sideB}`;\n }\n\n // Attributes\n const attributes = {\n 'x-placement': data.placement,\n };\n\n // Update `data` attributes, styles and arrowStyles\n data.attributes = { ...attributes, ...data.attributes };\n data.styles = { ...styles, ...data.styles };\n data.arrowStyles = { ...data.offsets.arrow, ...data.arrowStyles };\n\n return data;\n}\n","import find from './find';\n\n/**\n * Helper used to know if the given modifier depends from another one.
\n * It checks if the needed modifier is listed and enabled.\n * @method\n * @memberof Popper.Utils\n * @param {Array} modifiers - list of modifiers\n * @param {String} requestingName - name of requesting modifier\n * @param {String} requestedName - name of requested modifier\n * @returns {Boolean}\n */\nexport default function isModifierRequired(\n modifiers,\n requestingName,\n requestedName\n) {\n const requesting = find(modifiers, ({ name }) => name === requestingName);\n\n const isRequired =\n !!requesting &&\n modifiers.some(modifier => {\n return (\n modifier.name === requestedName &&\n modifier.enabled &&\n modifier.order < requesting.order\n );\n });\n\n if (!isRequired) {\n const requesting = `\\`${requestingName}\\``;\n const requested = `\\`${requestedName}\\``;\n console.warn(\n `${requested} modifier is required by ${requesting} modifier in order to work, be sure to include it before ${requesting}!`\n );\n }\n return isRequired;\n}\n","/**\n * List of accepted placements to use as values of the `placement` option.
\n * Valid placements are:\n * - `auto`\n * - `top`\n * - `right`\n * - `bottom`\n * - `left`\n *\n * Each placement can have a variation from this list:\n * - `-start`\n * - `-end`\n *\n * Variations are interpreted easily if you think of them as the left to right\n * written languages. Horizontally (`top` and `bottom`), `start` is left and `end`\n * is right.
\n * Vertically (`left` and `right`), `start` is top and `end` is bottom.\n *\n * Some valid examples are:\n * - `top-end` (on top of reference, right aligned)\n * - `right-start` (on right of reference, top aligned)\n * - `bottom` (on bottom, centered)\n * - `auto-end` (on the side with more space available, alignment depends by placement)\n *\n * @static\n * @type {Array}\n * @enum {String}\n * @readonly\n * @method placements\n * @memberof Popper\n */\nexport default [\n 'auto-start',\n 'auto',\n 'auto-end',\n 'top-start',\n 'top',\n 'top-end',\n 'right-start',\n 'right',\n 'right-end',\n 'bottom-end',\n 'bottom',\n 'bottom-start',\n 'left-end',\n 'left',\n 'left-start',\n];\n","import placements from '../methods/placements';\n\n// Get rid of `auto` `auto-start` and `auto-end`\nconst validPlacements = placements.slice(3);\n\n/**\n * Given an initial placement, returns all the subsequent placements\n * clockwise (or counter-clockwise).\n *\n * @method\n * @memberof Popper.Utils\n * @argument {String} placement - A valid placement (it accepts variations)\n * @argument {Boolean} counter - Set to true to walk the placements counterclockwise\n * @returns {Array} placements including their variations\n */\nexport default function clockwise(placement, counter = false) {\n const index = validPlacements.indexOf(placement);\n const arr = validPlacements\n .slice(index + 1)\n .concat(validPlacements.slice(0, index));\n return counter ? arr.reverse() : arr;\n}\n","import getOppositePlacement from '../utils/getOppositePlacement';\nimport getOppositeVariation from '../utils/getOppositeVariation';\nimport getPopperOffsets from '../utils/getPopperOffsets';\nimport runModifiers from '../utils/runModifiers';\nimport getBoundaries from '../utils/getBoundaries';\nimport isModifierEnabled from '../utils/isModifierEnabled';\nimport clockwise from '../utils/clockwise';\n\nconst BEHAVIORS = {\n FLIP: 'flip',\n CLOCKWISE: 'clockwise',\n COUNTERCLOCKWISE: 'counterclockwise',\n};\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function flip(data, options) {\n // if `inner` modifier is enabled, we can't use the `flip` modifier\n if (isModifierEnabled(data.instance.modifiers, 'inner')) {\n return data;\n }\n\n if (data.flipped && data.placement === data.originalPlacement) {\n // seems like flip is trying to loop, probably there's not enough space on any of the flippable sides\n return data;\n }\n\n const boundaries = getBoundaries(\n data.instance.popper,\n data.instance.reference,\n options.padding,\n options.boundariesElement,\n data.positionFixed\n );\n\n let placement = data.placement.split('-')[0];\n let placementOpposite = getOppositePlacement(placement);\n let variation = data.placement.split('-')[1] || '';\n\n let flipOrder = [];\n\n switch (options.behavior) {\n case BEHAVIORS.FLIP:\n flipOrder = [placement, placementOpposite];\n break;\n case BEHAVIORS.CLOCKWISE:\n flipOrder = clockwise(placement);\n break;\n case BEHAVIORS.COUNTERCLOCKWISE:\n flipOrder = clockwise(placement, true);\n break;\n default:\n flipOrder = options.behavior;\n }\n\n flipOrder.forEach((step, index) => {\n if (placement !== step || flipOrder.length === index + 1) {\n return data;\n }\n\n placement = data.placement.split('-')[0];\n placementOpposite = getOppositePlacement(placement);\n\n const popperOffsets = data.offsets.popper;\n const refOffsets = data.offsets.reference;\n\n // using floor because the reference offsets may contain decimals we are not going to consider here\n const floor = Math.floor;\n const overlapsRef =\n (placement === 'left' &&\n floor(popperOffsets.right) > floor(refOffsets.left)) ||\n (placement === 'right' &&\n floor(popperOffsets.left) < floor(refOffsets.right)) ||\n (placement === 'top' &&\n floor(popperOffsets.bottom) > floor(refOffsets.top)) ||\n (placement === 'bottom' &&\n floor(popperOffsets.top) < floor(refOffsets.bottom));\n\n const overflowsLeft = floor(popperOffsets.left) < floor(boundaries.left);\n const overflowsRight = floor(popperOffsets.right) > floor(boundaries.right);\n const overflowsTop = floor(popperOffsets.top) < floor(boundaries.top);\n const overflowsBottom =\n floor(popperOffsets.bottom) > floor(boundaries.bottom);\n\n const overflowsBoundaries =\n (placement === 'left' && overflowsLeft) ||\n (placement === 'right' && overflowsRight) ||\n (placement === 'top' && overflowsTop) ||\n (placement === 'bottom' && overflowsBottom);\n\n // flip the variation if required\n const isVertical = ['top', 'bottom'].indexOf(placement) !== -1;\n\n // flips variation if reference element overflows boundaries\n const flippedVariationByRef =\n !!options.flipVariations &&\n ((isVertical && variation === 'start' && overflowsLeft) ||\n (isVertical && variation === 'end' && overflowsRight) ||\n (!isVertical && variation === 'start' && overflowsTop) ||\n (!isVertical && variation === 'end' && overflowsBottom));\n\n // flips variation if popper content overflows boundaries\n const flippedVariationByContent =\n !!options.flipVariationsByContent &&\n ((isVertical && variation === 'start' && overflowsRight) ||\n (isVertical && variation === 'end' && overflowsLeft) ||\n (!isVertical && variation === 'start' && overflowsBottom) ||\n (!isVertical && variation === 'end' && overflowsTop));\n\n const flippedVariation = flippedVariationByRef || flippedVariationByContent;\n\n if (overlapsRef || overflowsBoundaries || flippedVariation) {\n // this boolean to detect any flip loop\n data.flipped = true;\n\n if (overlapsRef || overflowsBoundaries) {\n placement = flipOrder[index + 1];\n }\n\n if (flippedVariation) {\n variation = getOppositeVariation(variation);\n }\n\n data.placement = placement + (variation ? '-' + variation : '');\n\n // this object contains `position`, we want to preserve it along with\n // any additional property we may add in the future\n data.offsets.popper = {\n ...data.offsets.popper,\n ...getPopperOffsets(\n data.instance.popper,\n data.offsets.reference,\n data.placement\n ),\n };\n\n data = runModifiers(data.instance.modifiers, data, 'flip');\n }\n });\n return data;\n}\n","import isNumeric from '../utils/isNumeric';\nimport getClientRect from '../utils/getClientRect';\nimport find from '../utils/find';\n\n/**\n * Converts a string containing value + unit into a px value number\n * @function\n * @memberof {modifiers~offset}\n * @private\n * @argument {String} str - Value + unit string\n * @argument {String} measurement - `height` or `width`\n * @argument {Object} popperOffsets\n * @argument {Object} referenceOffsets\n * @returns {Number|String}\n * Value in pixels, or original string if no values were extracted\n */\nexport function toValue(str, measurement, popperOffsets, referenceOffsets) {\n // separate value from unit\n const split = str.match(/((?:\\-|\\+)?\\d*\\.?\\d*)(.*)/);\n const value = +split[1];\n const unit = split[2];\n\n // If it's not a number it's an operator, I guess\n if (!value) {\n return str;\n }\n\n if (unit.indexOf('%') === 0) {\n let element;\n switch (unit) {\n case '%p':\n element = popperOffsets;\n break;\n case '%':\n case '%r':\n default:\n element = referenceOffsets;\n }\n\n const rect = getClientRect(element);\n return rect[measurement] / 100 * value;\n } else if (unit === 'vh' || unit === 'vw') {\n // if is a vh or vw, we calculate the size based on the viewport\n let size;\n if (unit === 'vh') {\n size = Math.max(\n document.documentElement.clientHeight,\n window.innerHeight || 0\n );\n } else {\n size = Math.max(\n document.documentElement.clientWidth,\n window.innerWidth || 0\n );\n }\n return size / 100 * value;\n } else {\n // if is an explicit pixel unit, we get rid of the unit and keep the value\n // if is an implicit unit, it's px, and we return just the value\n return value;\n }\n}\n\n/**\n * Parse an `offset` string to extrapolate `x` and `y` numeric offsets.\n * @function\n * @memberof {modifiers~offset}\n * @private\n * @argument {String} offset\n * @argument {Object} popperOffsets\n * @argument {Object} referenceOffsets\n * @argument {String} basePlacement\n * @returns {Array} a two cells array with x and y offsets in numbers\n */\nexport function parseOffset(\n offset,\n popperOffsets,\n referenceOffsets,\n basePlacement\n) {\n const offsets = [0, 0];\n\n // Use height if placement is left or right and index is 0 otherwise use width\n // in this way the first offset will use an axis and the second one\n // will use the other one\n const useHeight = ['right', 'left'].indexOf(basePlacement) !== -1;\n\n // Split the offset string to obtain a list of values and operands\n // The regex addresses values with the plus or minus sign in front (+10, -20, etc)\n const fragments = offset.split(/(\\+|\\-)/).map(frag => frag.trim());\n\n // Detect if the offset string contains a pair of values or a single one\n // they could be separated by comma or space\n const divider = fragments.indexOf(\n find(fragments, frag => frag.search(/,|\\s/) !== -1)\n );\n\n if (fragments[divider] && fragments[divider].indexOf(',') === -1) {\n console.warn(\n 'Offsets separated by white space(s) are deprecated, use a comma (,) instead.'\n );\n }\n\n // If divider is found, we divide the list of values and operands to divide\n // them by ofset X and Y.\n const splitRegex = /\\s*,\\s*|\\s+/;\n let ops = divider !== -1\n ? [\n fragments\n .slice(0, divider)\n .concat([fragments[divider].split(splitRegex)[0]]),\n [fragments[divider].split(splitRegex)[1]].concat(\n fragments.slice(divider + 1)\n ),\n ]\n : [fragments];\n\n // Convert the values with units to absolute pixels to allow our computations\n ops = ops.map((op, index) => {\n // Most of the units rely on the orientation of the popper\n const measurement = (index === 1 ? !useHeight : useHeight)\n ? 'height'\n : 'width';\n let mergeWithPrevious = false;\n return (\n op\n // This aggregates any `+` or `-` sign that aren't considered operators\n // e.g.: 10 + +5 => [10, +, +5]\n .reduce((a, b) => {\n if (a[a.length - 1] === '' && ['+', '-'].indexOf(b) !== -1) {\n a[a.length - 1] = b;\n mergeWithPrevious = true;\n return a;\n } else if (mergeWithPrevious) {\n a[a.length - 1] += b;\n mergeWithPrevious = false;\n return a;\n } else {\n return a.concat(b);\n }\n }, [])\n // Here we convert the string values into number values (in px)\n .map(str => toValue(str, measurement, popperOffsets, referenceOffsets))\n );\n });\n\n // Loop trough the offsets arrays and execute the operations\n ops.forEach((op, index) => {\n op.forEach((frag, index2) => {\n if (isNumeric(frag)) {\n offsets[index] += frag * (op[index2 - 1] === '-' ? -1 : 1);\n }\n });\n });\n return offsets;\n}\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @argument {Number|String} options.offset=0\n * The offset value as described in the modifier description\n * @returns {Object} The data object, properly modified\n */\nexport default function offset(data, { offset }) {\n const { placement, offsets: { popper, reference } } = data;\n const basePlacement = placement.split('-')[0];\n\n let offsets;\n if (isNumeric(+offset)) {\n offsets = [+offset, 0];\n } else {\n offsets = parseOffset(offset, popper, reference, basePlacement);\n }\n\n if (basePlacement === 'left') {\n popper.top += offsets[0];\n popper.left -= offsets[1];\n } else if (basePlacement === 'right') {\n popper.top += offsets[0];\n popper.left += offsets[1];\n } else if (basePlacement === 'top') {\n popper.left += offsets[0];\n popper.top -= offsets[1];\n } else if (basePlacement === 'bottom') {\n popper.left += offsets[0];\n popper.top += offsets[1];\n }\n\n data.popper = popper;\n return data;\n}\n","import applyStyle, { applyStyleOnLoad } from './applyStyle';\nimport computeStyle from './computeStyle';\nimport arrow from './arrow';\nimport flip from './flip';\nimport keepTogether from './keepTogether';\nimport offset from './offset';\nimport preventOverflow from './preventOverflow';\nimport shift from './shift';\nimport hide from './hide';\nimport inner from './inner';\n\n/**\n * Modifier function, each modifier can have a function of this type assigned\n * to its `fn` property.
\n * These functions will be called on each update, this means that you must\n * make sure they are performant enough to avoid performance bottlenecks.\n *\n * @function ModifierFn\n * @argument {dataObject} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {dataObject} The data object, properly modified\n */\n\n/**\n * Modifiers are plugins used to alter the behavior of your poppers.
\n * Popper.js uses a set of 9 modifiers to provide all the basic functionalities\n * needed by the library.\n *\n * Usually you don't want to override the `order`, `fn` and `onLoad` props.\n * All the other properties are configurations that could be tweaked.\n * @namespace modifiers\n */\nexport default {\n /**\n * Modifier used to shift the popper on the start or end of its reference\n * element.
\n * It will read the variation of the `placement` property.
\n * It can be one either `-end` or `-start`.\n * @memberof modifiers\n * @inner\n */\n shift: {\n /** @prop {number} order=100 - Index used to define the order of execution */\n order: 100,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: shift,\n },\n\n /**\n * The `offset` modifier can shift your popper on both its axis.\n *\n * It accepts the following units:\n * - `px` or unit-less, interpreted as pixels\n * - `%` or `%r`, percentage relative to the length of the reference element\n * - `%p`, percentage relative to the length of the popper element\n * - `vw`, CSS viewport width unit\n * - `vh`, CSS viewport height unit\n *\n * For length is intended the main axis relative to the placement of the popper.
\n * This means that if the placement is `top` or `bottom`, the length will be the\n * `width`. In case of `left` or `right`, it will be the `height`.\n *\n * You can provide a single value (as `Number` or `String`), or a pair of values\n * as `String` divided by a comma or one (or more) white spaces.
\n * The latter is a deprecated method because it leads to confusion and will be\n * removed in v2.
\n * Additionally, it accepts additions and subtractions between different units.\n * Note that multiplications and divisions aren't supported.\n *\n * Valid examples are:\n * ```\n * 10\n * '10%'\n * '10, 10'\n * '10%, 10'\n * '10 + 10%'\n * '10 - 5vh + 3%'\n * '-10px + 5vh, 5px - 6%'\n * ```\n * > **NB**: If you desire to apply offsets to your poppers in a way that may make them overlap\n * > with their reference element, unfortunately, you will have to disable the `flip` modifier.\n * > You can read more on this at this [issue](https://github.com/FezVrasta/popper.js/issues/373).\n *\n * @memberof modifiers\n * @inner\n */\n offset: {\n /** @prop {number} order=200 - Index used to define the order of execution */\n order: 200,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: offset,\n /** @prop {Number|String} offset=0\n * The offset value as described in the modifier description\n */\n offset: 0,\n },\n\n /**\n * Modifier used to prevent the popper from being positioned outside the boundary.\n *\n * A scenario exists where the reference itself is not within the boundaries.
\n * We can say it has \"escaped the boundaries\" — or just \"escaped\".
\n * In this case we need to decide whether the popper should either:\n *\n * - detach from the reference and remain \"trapped\" in the boundaries, or\n * - if it should ignore the boundary and \"escape with its reference\"\n *\n * When `escapeWithReference` is set to`true` and reference is completely\n * outside its boundaries, the popper will overflow (or completely leave)\n * the boundaries in order to remain attached to the edge of the reference.\n *\n * @memberof modifiers\n * @inner\n */\n preventOverflow: {\n /** @prop {number} order=300 - Index used to define the order of execution */\n order: 300,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: preventOverflow,\n /**\n * @prop {Array} [priority=['left','right','top','bottom']]\n * Popper will try to prevent overflow following these priorities by default,\n * then, it could overflow on the left and on top of the `boundariesElement`\n */\n priority: ['left', 'right', 'top', 'bottom'],\n /**\n * @prop {number} padding=5\n * Amount of pixel used to define a minimum distance between the boundaries\n * and the popper. This makes sure the popper always has a little padding\n * between the edges of its container\n */\n padding: 5,\n /**\n * @prop {String|HTMLElement} boundariesElement='scrollParent'\n * Boundaries used by the modifier. Can be `scrollParent`, `window`,\n * `viewport` or any DOM element.\n */\n boundariesElement: 'scrollParent',\n },\n\n /**\n * Modifier used to make sure the reference and its popper stay near each other\n * without leaving any gap between the two. Especially useful when the arrow is\n * enabled and you want to ensure that it points to its reference element.\n * It cares only about the first axis. You can still have poppers with margin\n * between the popper and its reference element.\n * @memberof modifiers\n * @inner\n */\n keepTogether: {\n /** @prop {number} order=400 - Index used to define the order of execution */\n order: 400,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: keepTogether,\n },\n\n /**\n * This modifier is used to move the `arrowElement` of the popper to make\n * sure it is positioned between the reference element and its popper element.\n * It will read the outer size of the `arrowElement` node to detect how many\n * pixels of conjunction are needed.\n *\n * It has no effect if no `arrowElement` is provided.\n * @memberof modifiers\n * @inner\n */\n arrow: {\n /** @prop {number} order=500 - Index used to define the order of execution */\n order: 500,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: arrow,\n /** @prop {String|HTMLElement} element='[x-arrow]' - Selector or node used as arrow */\n element: '[x-arrow]',\n },\n\n /**\n * Modifier used to flip the popper's placement when it starts to overlap its\n * reference element.\n *\n * Requires the `preventOverflow` modifier before it in order to work.\n *\n * **NOTE:** this modifier will interrupt the current update cycle and will\n * restart it if it detects the need to flip the placement.\n * @memberof modifiers\n * @inner\n */\n flip: {\n /** @prop {number} order=600 - Index used to define the order of execution */\n order: 600,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: flip,\n /**\n * @prop {String|Array} behavior='flip'\n * The behavior used to change the popper's placement. It can be one of\n * `flip`, `clockwise`, `counterclockwise` or an array with a list of valid\n * placements (with optional variations)\n */\n behavior: 'flip',\n /**\n * @prop {number} padding=5\n * The popper will flip if it hits the edges of the `boundariesElement`\n */\n padding: 5,\n /**\n * @prop {String|HTMLElement} boundariesElement='viewport'\n * The element which will define the boundaries of the popper position.\n * The popper will never be placed outside of the defined boundaries\n * (except if `keepTogether` is enabled)\n */\n boundariesElement: 'viewport',\n /**\n * @prop {Boolean} flipVariations=false\n * The popper will switch placement variation between `-start` and `-end` when\n * the reference element overlaps its boundaries.\n *\n * The original placement should have a set variation.\n */\n flipVariations: false,\n /**\n * @prop {Boolean} flipVariationsByContent=false\n * The popper will switch placement variation between `-start` and `-end` when\n * the popper element overlaps its reference boundaries.\n *\n * The original placement should have a set variation.\n */\n flipVariationsByContent: false,\n },\n\n /**\n * Modifier used to make the popper flow toward the inner of the reference element.\n * By default, when this modifier is disabled, the popper will be placed outside\n * the reference element.\n * @memberof modifiers\n * @inner\n */\n inner: {\n /** @prop {number} order=700 - Index used to define the order of execution */\n order: 700,\n /** @prop {Boolean} enabled=false - Whether the modifier is enabled or not */\n enabled: false,\n /** @prop {ModifierFn} */\n fn: inner,\n },\n\n /**\n * Modifier used to hide the popper when its reference element is outside of the\n * popper boundaries. It will set a `x-out-of-boundaries` attribute which can\n * be used to hide with a CSS selector the popper when its reference is\n * out of boundaries.\n *\n * Requires the `preventOverflow` modifier before it in order to work.\n * @memberof modifiers\n * @inner\n */\n hide: {\n /** @prop {number} order=800 - Index used to define the order of execution */\n order: 800,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: hide,\n },\n\n /**\n * Computes the style that will be applied to the popper element to gets\n * properly positioned.\n *\n * Note that this modifier will not touch the DOM, it just prepares the styles\n * so that `applyStyle` modifier can apply it. This separation is useful\n * in case you need to replace `applyStyle` with a custom implementation.\n *\n * This modifier has `850` as `order` value to maintain backward compatibility\n * with previous versions of Popper.js. Expect the modifiers ordering method\n * to change in future major versions of the library.\n *\n * @memberof modifiers\n * @inner\n */\n computeStyle: {\n /** @prop {number} order=850 - Index used to define the order of execution */\n order: 850,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: computeStyle,\n /**\n * @prop {Boolean} gpuAcceleration=true\n * If true, it uses the CSS 3D transformation to position the popper.\n * Otherwise, it will use the `top` and `left` properties\n */\n gpuAcceleration: true,\n /**\n * @prop {string} [x='bottom']\n * Where to anchor the X axis (`bottom` or `top`). AKA X offset origin.\n * Change this if your popper should grow in a direction different from `bottom`\n */\n x: 'bottom',\n /**\n * @prop {string} [x='left']\n * Where to anchor the Y axis (`left` or `right`). AKA Y offset origin.\n * Change this if your popper should grow in a direction different from `right`\n */\n y: 'right',\n },\n\n /**\n * Applies the computed styles to the popper element.\n *\n * All the DOM manipulations are limited to this modifier. This is useful in case\n * you want to integrate Popper.js inside a framework or view library and you\n * want to delegate all the DOM manipulations to it.\n *\n * Note that if you disable this modifier, you must make sure the popper element\n * has its position set to `absolute` before Popper.js can do its work!\n *\n * Just disable this modifier and define your own to achieve the desired effect.\n *\n * @memberof modifiers\n * @inner\n */\n applyStyle: {\n /** @prop {number} order=900 - Index used to define the order of execution */\n order: 900,\n /** @prop {Boolean} enabled=true - Whether the modifier is enabled or not */\n enabled: true,\n /** @prop {ModifierFn} */\n fn: applyStyle,\n /** @prop {Function} */\n onLoad: applyStyleOnLoad,\n /**\n * @deprecated since version 1.10.0, the property moved to `computeStyle` modifier\n * @prop {Boolean} gpuAcceleration=true\n * If true, it uses the CSS 3D transformation to position the popper.\n * Otherwise, it will use the `top` and `left` properties\n */\n gpuAcceleration: undefined,\n },\n};\n\n/**\n * The `dataObject` is an object containing all the information used by Popper.js.\n * This object is passed to modifiers and to the `onCreate` and `onUpdate` callbacks.\n * @name dataObject\n * @property {Object} data.instance The Popper.js instance\n * @property {String} data.placement Placement applied to popper\n * @property {String} data.originalPlacement Placement originally defined on init\n * @property {Boolean} data.flipped True if popper has been flipped by flip modifier\n * @property {Boolean} data.hide True if the reference element is out of boundaries, useful to know when to hide the popper\n * @property {HTMLElement} data.arrowElement Node used as arrow by arrow modifier\n * @property {Object} data.styles Any CSS property defined here will be applied to the popper. It expects the JavaScript nomenclature (eg. `marginBottom`)\n * @property {Object} data.arrowStyles Any CSS property defined here will be applied to the popper arrow. It expects the JavaScript nomenclature (eg. `marginBottom`)\n * @property {Object} data.boundaries Offsets of the popper boundaries\n * @property {Object} data.offsets The measurements of popper, reference and arrow elements\n * @property {Object} data.offsets.popper `top`, `left`, `width`, `height` values\n * @property {Object} data.offsets.reference `top`, `left`, `width`, `height` values\n * @property {Object} data.offsets.arrow] `top` and `left` offsets, only one of them will be different from 0\n */\n","/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function shift(data) {\n const placement = data.placement;\n const basePlacement = placement.split('-')[0];\n const shiftvariation = placement.split('-')[1];\n\n // if shift shiftvariation is specified, run the modifier\n if (shiftvariation) {\n const { reference, popper } = data.offsets;\n const isVertical = ['bottom', 'top'].indexOf(basePlacement) !== -1;\n const side = isVertical ? 'left' : 'top';\n const measurement = isVertical ? 'width' : 'height';\n\n const shiftOffsets = {\n start: { [side]: reference[side] },\n end: {\n [side]: reference[side] + reference[measurement] - popper[measurement],\n },\n };\n\n data.offsets.popper = { ...popper, ...shiftOffsets[shiftvariation] };\n }\n\n return data;\n}\n","import getOffsetParent from '../utils/getOffsetParent';\nimport getBoundaries from '../utils/getBoundaries';\nimport getSupportedPropertyName from '../utils/getSupportedPropertyName';\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function preventOverflow(data, options) {\n let boundariesElement =\n options.boundariesElement || getOffsetParent(data.instance.popper);\n\n // If offsetParent is the reference element, we really want to\n // go one step up and use the next offsetParent as reference to\n // avoid to make this modifier completely useless and look like broken\n if (data.instance.reference === boundariesElement) {\n boundariesElement = getOffsetParent(boundariesElement);\n }\n\n // NOTE: DOM access here\n // resets the popper's position so that the document size can be calculated excluding\n // the size of the popper element itself\n const transformProp = getSupportedPropertyName('transform');\n const popperStyles = data.instance.popper.style; // assignment to help minification\n const { top, left, [transformProp]: transform } = popperStyles;\n popperStyles.top = '';\n popperStyles.left = '';\n popperStyles[transformProp] = '';\n\n const boundaries = getBoundaries(\n data.instance.popper,\n data.instance.reference,\n options.padding,\n boundariesElement,\n data.positionFixed\n );\n\n // NOTE: DOM access here\n // restores the original style properties after the offsets have been computed\n popperStyles.top = top;\n popperStyles.left = left;\n popperStyles[transformProp] = transform;\n\n options.boundaries = boundaries;\n\n const order = options.priority;\n let popper = data.offsets.popper;\n\n const check = {\n primary(placement) {\n let value = popper[placement];\n if (\n popper[placement] < boundaries[placement] &&\n !options.escapeWithReference\n ) {\n value = Math.max(popper[placement], boundaries[placement]);\n }\n return { [placement]: value };\n },\n secondary(placement) {\n const mainSide = placement === 'right' ? 'left' : 'top';\n let value = popper[mainSide];\n if (\n popper[placement] > boundaries[placement] &&\n !options.escapeWithReference\n ) {\n value = Math.min(\n popper[mainSide],\n boundaries[placement] -\n (placement === 'right' ? popper.width : popper.height)\n );\n }\n return { [mainSide]: value };\n },\n };\n\n order.forEach(placement => {\n const side =\n ['left', 'top'].indexOf(placement) !== -1 ? 'primary' : 'secondary';\n popper = { ...popper, ...check[side](placement) };\n });\n\n data.offsets.popper = popper;\n\n return data;\n}\n","/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function keepTogether(data) {\n const { popper, reference } = data.offsets;\n const placement = data.placement.split('-')[0];\n const floor = Math.floor;\n const isVertical = ['top', 'bottom'].indexOf(placement) !== -1;\n const side = isVertical ? 'right' : 'bottom';\n const opSide = isVertical ? 'left' : 'top';\n const measurement = isVertical ? 'width' : 'height';\n\n if (popper[side] < floor(reference[opSide])) {\n data.offsets.popper[opSide] =\n floor(reference[opSide]) - popper[measurement];\n }\n if (popper[opSide] > floor(reference[side])) {\n data.offsets.popper[opSide] = floor(reference[side]);\n }\n\n return data;\n}\n","import getClientRect from '../utils/getClientRect';\nimport getOuterSizes from '../utils/getOuterSizes';\nimport isModifierRequired from '../utils/isModifierRequired';\nimport getStyleComputedProperty from '../utils/getStyleComputedProperty';\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function arrow(data, options) {\n // arrow depends on keepTogether in order to work\n if (!isModifierRequired(data.instance.modifiers, 'arrow', 'keepTogether')) {\n return data;\n }\n\n let arrowElement = options.element;\n\n // if arrowElement is a string, suppose it's a CSS selector\n if (typeof arrowElement === 'string') {\n arrowElement = data.instance.popper.querySelector(arrowElement);\n\n // if arrowElement is not found, don't run the modifier\n if (!arrowElement) {\n return data;\n }\n } else {\n // if the arrowElement isn't a query selector we must check that the\n // provided DOM node is child of its popper node\n if (!data.instance.popper.contains(arrowElement)) {\n console.warn(\n 'WARNING: `arrow.element` must be child of its popper element!'\n );\n return data;\n }\n }\n\n const placement = data.placement.split('-')[0];\n const { popper, reference } = data.offsets;\n const isVertical = ['left', 'right'].indexOf(placement) !== -1;\n\n const len = isVertical ? 'height' : 'width';\n const sideCapitalized = isVertical ? 'Top' : 'Left';\n const side = sideCapitalized.toLowerCase();\n const altSide = isVertical ? 'left' : 'top';\n const opSide = isVertical ? 'bottom' : 'right';\n const arrowElementSize = getOuterSizes(arrowElement)[len];\n\n //\n // extends keepTogether behavior making sure the popper and its\n // reference have enough pixels in conjunction\n //\n\n // top/left side\n if (reference[opSide] - arrowElementSize < popper[side]) {\n data.offsets.popper[side] -=\n popper[side] - (reference[opSide] - arrowElementSize);\n }\n // bottom/right side\n if (reference[side] + arrowElementSize > popper[opSide]) {\n data.offsets.popper[side] +=\n reference[side] + arrowElementSize - popper[opSide];\n }\n data.offsets.popper = getClientRect(data.offsets.popper);\n\n // compute center of the popper\n const center = reference[side] + reference[len] / 2 - arrowElementSize / 2;\n\n // Compute the sideValue using the updated popper offsets\n // take popper margin in account because we don't have this info available\n const css = getStyleComputedProperty(data.instance.popper);\n const popperMarginSide = parseFloat(css[`margin${sideCapitalized}`]);\n const popperBorderSide = parseFloat(css[`border${sideCapitalized}Width`]);\n let sideValue =\n center - data.offsets.popper[side] - popperMarginSide - popperBorderSide;\n\n // prevent arrowElement from being placed not contiguously to its popper\n sideValue = Math.max(Math.min(popper[len] - arrowElementSize, sideValue), 0);\n\n data.arrowElement = arrowElement;\n data.offsets.arrow = {\n [side]: Math.round(sideValue),\n [altSide]: '', // make sure to unset any eventual altSide value from the DOM node\n };\n\n return data;\n}\n","/**\n * Get the opposite placement variation of the given one\n * @method\n * @memberof Popper.Utils\n * @argument {String} placement variation\n * @returns {String} flipped placement variation\n */\nexport default function getOppositeVariation(variation) {\n if (variation === 'end') {\n return 'start';\n } else if (variation === 'start') {\n return 'end';\n }\n return variation;\n}\n","import getClientRect from '../utils/getClientRect';\nimport getOppositePlacement from '../utils/getOppositePlacement';\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function inner(data) {\n const placement = data.placement;\n const basePlacement = placement.split('-')[0];\n const { popper, reference } = data.offsets;\n const isHoriz = ['left', 'right'].indexOf(basePlacement) !== -1;\n\n const subtractLength = ['top', 'left'].indexOf(basePlacement) === -1;\n\n popper[isHoriz ? 'left' : 'top'] =\n reference[basePlacement] -\n (subtractLength ? popper[isHoriz ? 'width' : 'height'] : 0);\n\n data.placement = getOppositePlacement(placement);\n data.offsets.popper = getClientRect(popper);\n\n return data;\n}\n","import isModifierRequired from '../utils/isModifierRequired';\nimport find from '../utils/find';\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by update method\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The data object, properly modified\n */\nexport default function hide(data) {\n if (!isModifierRequired(data.instance.modifiers, 'hide', 'preventOverflow')) {\n return data;\n }\n\n const refRect = data.offsets.reference;\n const bound = find(\n data.instance.modifiers,\n modifier => modifier.name === 'preventOverflow'\n ).boundaries;\n\n if (\n refRect.bottom < bound.top ||\n refRect.left > bound.right ||\n refRect.top > bound.bottom ||\n refRect.right < bound.left\n ) {\n // Avoid unnecessary DOM access if visibility hasn't changed\n if (data.hide === true) {\n return data;\n }\n\n data.hide = true;\n data.attributes['x-out-of-boundaries'] = '';\n } else {\n // Avoid unnecessary DOM access if visibility hasn't changed\n if (data.hide === false) {\n return data;\n }\n\n data.hide = false;\n data.attributes['x-out-of-boundaries'] = false;\n }\n\n return data;\n}\n","/**\n * @function\n * @memberof Popper.Utils\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Boolean} shouldRound - If the offsets should be rounded at all\n * @returns {Object} The popper's position offsets rounded\n *\n * The tale of pixel-perfect positioning. It's still not 100% perfect, but as\n * good as it can be within reason.\n * Discussion here: https://github.com/FezVrasta/popper.js/pull/715\n *\n * Low DPI screens cause a popper to be blurry if not using full pixels (Safari\n * as well on High DPI screens).\n *\n * Firefox prefers no rounding for positioning and does not have blurriness on\n * high DPI screens.\n *\n * Only horizontal placement and left/right values need to be considered.\n */\nexport default function getRoundedOffsets(data, shouldRound) {\n const { popper, reference } = data.offsets;\n const { round, floor } = Math;\n const noRound = v => v;\n \n const referenceWidth = round(reference.width);\n const popperWidth = round(popper.width);\n \n const isVertical = ['left', 'right'].indexOf(data.placement) !== -1;\n const isVariation = data.placement.indexOf('-') !== -1;\n const sameWidthParity = referenceWidth % 2 === popperWidth % 2;\n const bothOddWidth = referenceWidth % 2 === 1 && popperWidth % 2 === 1;\n\n const horizontalToInteger = !shouldRound\n ? noRound\n : isVertical || isVariation || sameWidthParity\n ? round\n : floor;\n const verticalToInteger = !shouldRound ? noRound : round;\n\n return {\n left: horizontalToInteger(\n bothOddWidth && !isVariation && shouldRound\n ? popper.left - 1\n : popper.left\n ),\n top: verticalToInteger(popper.top),\n bottom: verticalToInteger(popper.bottom),\n right: horizontalToInteger(popper.right),\n };\n}\n","import setStyles from '../utils/setStyles';\nimport setAttributes from '../utils/setAttributes';\nimport getReferenceOffsets from '../utils/getReferenceOffsets';\nimport computeAutoPlacement from '../utils/computeAutoPlacement';\n\n/**\n * @function\n * @memberof Modifiers\n * @argument {Object} data - The data object generated by `update` method\n * @argument {Object} data.styles - List of style properties - values to apply to popper element\n * @argument {Object} data.attributes - List of attribute properties - values to apply to popper element\n * @argument {Object} options - Modifiers configuration and options\n * @returns {Object} The same data object\n */\nexport default function applyStyle(data) {\n // any property present in `data.styles` will be applied to the popper,\n // in this way we can make the 3rd party modifiers add custom styles to it\n // Be aware, modifiers could override the properties defined in the previous\n // lines of this modifier!\n setStyles(data.instance.popper, data.styles);\n\n // any property present in `data.attributes` will be applied to the popper,\n // they will be set as HTML attributes of the element\n setAttributes(data.instance.popper, data.attributes);\n\n // if arrowElement is defined and arrowStyles has some properties\n if (data.arrowElement && Object.keys(data.arrowStyles).length) {\n setStyles(data.arrowElement, data.arrowStyles);\n }\n\n return data;\n}\n\n/**\n * Set the x-placement attribute before everything else because it could be used\n * to add margins to the popper margins needs to be calculated to get the\n * correct popper offsets.\n * @method\n * @memberof Popper.modifiers\n * @param {HTMLElement} reference - The reference element used to position the popper\n * @param {HTMLElement} popper - The HTML element used as popper\n * @param {Object} options - Popper.js options\n */\nexport function applyStyleOnLoad(\n reference,\n popper,\n options,\n modifierOptions,\n state\n) {\n // compute reference element offsets\n const referenceOffsets = getReferenceOffsets(state, popper, reference, options.positionFixed);\n\n // compute auto placement, store placement inside the data object,\n // modifiers will be able to edit `placement` if needed\n // and refer to originalPlacement to know the original value\n const placement = computeAutoPlacement(\n options.placement,\n referenceOffsets,\n popper,\n reference,\n options.modifiers.flip.boundariesElement,\n options.modifiers.flip.padding\n );\n\n popper.setAttribute('x-placement', placement);\n\n // Apply `position` to popper before anything else because\n // without the position applied we can't guarantee correct computations\n setStyles(popper, { position: options.positionFixed ? 'fixed' : 'absolute' });\n\n return options;\n}\n","/**\n * Set the attributes to the given popper\n * @method\n * @memberof Popper.Utils\n * @argument {Element} element - Element to apply the attributes to\n * @argument {Object} styles\n * Object with a list of properties and values which will be applied to the element\n */\nexport default function setAttributes(element, attributes) {\n Object.keys(attributes).forEach(function(prop) {\n const value = attributes[prop];\n if (value !== false) {\n element.setAttribute(prop, attributes[prop]);\n } else {\n element.removeAttribute(prop);\n }\n });\n}\n","import modifiers from '../modifiers/index';\n\n/**\n * Default options provided to Popper.js constructor.
\n * These can be overridden using the `options` argument of Popper.js.
\n * To override an option, simply pass an object with the same\n * structure of the `options` object, as the 3rd argument. For example:\n * ```\n * new Popper(ref, pop, {\n * modifiers: {\n * preventOverflow: { enabled: false }\n * }\n * })\n * ```\n * @type {Object}\n * @static\n * @memberof Popper\n */\nexport default {\n /**\n * Popper's placement.\n * @prop {Popper.placements} placement='bottom'\n */\n placement: 'bottom',\n\n /**\n * Set this to true if you want popper to position it self in 'fixed' mode\n * @prop {Boolean} positionFixed=false\n */\n positionFixed: false,\n\n /**\n * Whether events (resize, scroll) are initially enabled.\n * @prop {Boolean} eventsEnabled=true\n */\n eventsEnabled: true,\n\n /**\n * Set to true if you want to automatically remove the popper when\n * you call the `destroy` method.\n * @prop {Boolean} removeOnDestroy=false\n */\n removeOnDestroy: false,\n\n /**\n * Callback called when the popper is created.
\n * By default, it is set to no-op.
\n * Access Popper.js instance with `data.instance`.\n * @prop {onCreate}\n */\n onCreate: () => {},\n\n /**\n * Callback called when the popper is updated. This callback is not called\n * on the initialization/creation of the popper, but only on subsequent\n * updates.
\n * By default, it is set to no-op.
\n * Access Popper.js instance with `data.instance`.\n * @prop {onUpdate}\n */\n onUpdate: () => {},\n\n /**\n * List of modifiers used to modify the offsets before they are applied to the popper.\n * They provide most of the functionalities of Popper.js.\n * @prop {modifiers}\n */\n modifiers,\n};\n\n/**\n * @callback onCreate\n * @param {dataObject} data\n */\n\n/**\n * @callback onUpdate\n * @param {dataObject} data\n */\n","// Utils\nimport debounce from './utils/debounce';\nimport isFunction from './utils/isFunction';\n\n// Methods\nimport update from './methods/update';\nimport destroy from './methods/destroy';\nimport enableEventListeners from './methods/enableEventListeners';\nimport disableEventListeners from './methods/disableEventListeners';\nimport Defaults from './methods/defaults';\nimport placements from './methods/placements';\n\nexport default class Popper {\n /**\n * Creates a new Popper.js instance.\n * @class Popper\n * @param {Element|referenceObject} reference - The reference element used to position the popper\n * @param {Element} popper - The HTML / XML element used as the popper\n * @param {Object} options - Your custom options to override the ones defined in [Defaults](#defaults)\n * @return {Object} instance - The generated Popper.js instance\n */\n constructor(reference, popper, options = {}) {\n // make update() debounced, so that it only runs at most once-per-tick\n this.update = debounce(this.update.bind(this));\n\n // with {} we create a new object with the options inside it\n this.options = { ...Popper.Defaults, ...options };\n\n // init state\n this.state = {\n isDestroyed: false,\n isCreated: false,\n scrollParents: [],\n };\n\n // get reference and popper elements (allow jQuery wrappers)\n this.reference = reference && reference.jquery ? reference[0] : reference;\n this.popper = popper && popper.jquery ? popper[0] : popper;\n\n // Deep merge modifiers options\n this.options.modifiers = {};\n Object.keys({\n ...Popper.Defaults.modifiers,\n ...options.modifiers,\n }).forEach(name => {\n this.options.modifiers[name] = {\n // If it's a built-in modifier, use it as base\n ...(Popper.Defaults.modifiers[name] || {}),\n // If there are custom options, override and merge with default ones\n ...(options.modifiers ? options.modifiers[name] : {}),\n };\n });\n\n // Refactoring modifiers' list (Object => Array)\n this.modifiers = Object.keys(this.options.modifiers)\n .map(name => ({\n name,\n ...this.options.modifiers[name],\n }))\n // sort the modifiers by order\n .sort((a, b) => a.order - b.order);\n\n // modifiers have the ability to execute arbitrary code when Popper.js get inited\n // such code is executed in the same order of its modifier\n // they could add new properties to their options configuration\n // BE AWARE: don't add options to `options.modifiers.name` but to `modifierOptions`!\n this.modifiers.forEach(modifierOptions => {\n if (modifierOptions.enabled && isFunction(modifierOptions.onLoad)) {\n modifierOptions.onLoad(\n this.reference,\n this.popper,\n this.options,\n modifierOptions,\n this.state\n );\n }\n });\n\n // fire the first update to position the popper in the right place\n this.update();\n\n const eventsEnabled = this.options.eventsEnabled;\n if (eventsEnabled) {\n // setup event listeners, they will take care of update the position in specific situations\n this.enableEventListeners();\n }\n\n this.state.eventsEnabled = eventsEnabled;\n }\n\n // We can't use class properties because they don't get listed in the\n // class prototype and break stuff like Sinon stubs\n update() {\n return update.call(this);\n }\n destroy() {\n return destroy.call(this);\n }\n enableEventListeners() {\n return enableEventListeners.call(this);\n }\n disableEventListeners() {\n return disableEventListeners.call(this);\n }\n\n /**\n * Schedules an update. It will run on the next UI update available.\n * @method scheduleUpdate\n * @memberof Popper\n */\n scheduleUpdate = () => requestAnimationFrame(this.update);\n\n /**\n * Collection of utilities useful when writing custom modifiers.\n * Starting from version 1.7, this method is available only if you\n * include `popper-utils.js` before `popper.js`.\n *\n * **DEPRECATION**: This way to access PopperUtils is deprecated\n * and will be removed in v2! Use the PopperUtils module directly instead.\n * Due to the high instability of the methods contained in Utils, we can't\n * guarantee them to follow semver. Use them at your own risk!\n * @static\n * @private\n * @type {Object}\n * @deprecated since version 1.8\n * @member Utils\n * @memberof Popper\n */\n static Utils = (typeof window !== 'undefined' ? window : global).PopperUtils;\n\n static placements = placements;\n\n static Defaults = Defaults;\n}\n\n/**\n * The `referenceObject` is an object that provides an interface compatible with Popper.js\n * and lets you use it as replacement of a real DOM node.
\n * You can use this method to position a popper relatively to a set of coordinates\n * in case you don't have a DOM node to use as reference.\n *\n * ```\n * new Popper(referenceObject, popperNode);\n * ```\n *\n * NB: This feature isn't supported in Internet Explorer 10.\n * @name referenceObject\n * @property {Function} data.getBoundingClientRect\n * A function that returns a set of coordinates compatible with the native `getBoundingClientRect` method.\n * @property {number} data.clientWidth\n * An ES6 getter that will return the width of the virtual reference element.\n * @property {number} data.clientHeight\n * An ES6 getter that will return the height of the virtual reference element.\n */\n","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/objectWithoutPropertiesLoose\";\nimport _extends from \"@babel/runtime/helpers/extends\";\nimport _inheritsLoose from \"@babel/runtime/helpers/inheritsLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/assertThisInitialized\";\nimport _defineProperty from \"@babel/runtime/helpers/defineProperty\";\nimport deepEqual from \"deep-equal\";\nimport * as React from 'react';\nimport PopperJS from 'popper.js';\nimport { ManagerReferenceNodeContext } from './Manager';\nimport { unwrapArray, setRef, shallowEqual } from './utils';\nvar initialStyle = {\n position: 'absolute',\n top: 0,\n left: 0,\n opacity: 0,\n pointerEvents: 'none'\n};\nvar initialArrowStyle = {};\nexport var InnerPopper =\n/*#__PURE__*/\nfunction (_React$Component) {\n _inheritsLoose(InnerPopper, _React$Component);\n\n function InnerPopper() {\n var _this;\n\n for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n args[_key] = arguments[_key];\n }\n\n _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"state\", {\n data: undefined,\n placement: undefined\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"popperInstance\", void 0);\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"popperNode\", null);\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"arrowNode\", null);\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"setPopperNode\", function (popperNode) {\n if (!popperNode || _this.popperNode === popperNode) return;\n setRef(_this.props.innerRef, popperNode);\n _this.popperNode = popperNode;\n\n _this.updatePopperInstance();\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"setArrowNode\", function (arrowNode) {\n _this.arrowNode = arrowNode;\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"updateStateModifier\", {\n enabled: true,\n order: 900,\n fn: function fn(data) {\n var placement = data.placement;\n\n _this.setState({\n data: data,\n placement: placement\n });\n\n return data;\n }\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"getOptions\", function () {\n return {\n placement: _this.props.placement,\n eventsEnabled: _this.props.eventsEnabled,\n positionFixed: _this.props.positionFixed,\n modifiers: _extends({}, _this.props.modifiers, {\n arrow: _extends({}, _this.props.modifiers && _this.props.modifiers.arrow, {\n enabled: !!_this.arrowNode,\n element: _this.arrowNode\n }),\n applyStyle: {\n enabled: false\n },\n updateStateModifier: _this.updateStateModifier\n })\n };\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"getPopperStyle\", function () {\n return !_this.popperNode || !_this.state.data ? initialStyle : _extends({\n position: _this.state.data.offsets.popper.position\n }, _this.state.data.styles);\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"getPopperPlacement\", function () {\n return !_this.state.data ? undefined : _this.state.placement;\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"getArrowStyle\", function () {\n return !_this.arrowNode || !_this.state.data ? initialArrowStyle : _this.state.data.arrowStyles;\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"getOutOfBoundariesState\", function () {\n return _this.state.data ? _this.state.data.hide : undefined;\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"destroyPopperInstance\", function () {\n if (!_this.popperInstance) return;\n\n _this.popperInstance.destroy();\n\n _this.popperInstance = null;\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"updatePopperInstance\", function () {\n _this.destroyPopperInstance();\n\n var _assertThisInitialize = _assertThisInitialized(_assertThisInitialized(_this)),\n popperNode = _assertThisInitialize.popperNode;\n\n var referenceElement = _this.props.referenceElement;\n if (!referenceElement || !popperNode) return;\n _this.popperInstance = new PopperJS(referenceElement, popperNode, _this.getOptions());\n });\n\n _defineProperty(_assertThisInitialized(_assertThisInitialized(_this)), \"scheduleUpdate\", function () {\n if (_this.popperInstance) {\n _this.popperInstance.scheduleUpdate();\n }\n });\n\n return _this;\n }\n\n var _proto = InnerPopper.prototype;\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps, prevState) {\n // If the Popper.js options have changed, update the instance (destroy + create)\n if (this.props.placement !== prevProps.placement || this.props.referenceElement !== prevProps.referenceElement || this.props.positionFixed !== prevProps.positionFixed || !deepEqual(this.props.modifiers, prevProps.modifiers, {\n strict: true\n })) {\n // develop only check that modifiers isn't being updated needlessly\n if (process.env.NODE_ENV === \"development\") {\n if (this.props.modifiers !== prevProps.modifiers && this.props.modifiers != null && prevProps.modifiers != null && shallowEqual(this.props.modifiers, prevProps.modifiers)) {\n console.warn(\"'modifiers' prop reference updated even though all values appear the same.\\nConsider memoizing the 'modifiers' object to avoid needless rendering.\");\n }\n }\n\n this.updatePopperInstance();\n } else if (this.props.eventsEnabled !== prevProps.eventsEnabled && this.popperInstance) {\n this.props.eventsEnabled ? this.popperInstance.enableEventListeners() : this.popperInstance.disableEventListeners();\n } // A placement difference in state means popper determined a new placement\n // apart from the props value. By the time the popper element is rendered with\n // the new position Popper has already measured it, if the place change triggers\n // a size change it will result in a misaligned popper. So we schedule an update to be sure.\n\n\n if (prevState.placement !== this.state.placement) {\n this.scheduleUpdate();\n }\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n setRef(this.props.innerRef, null);\n this.destroyPopperInstance();\n };\n\n _proto.render = function render() {\n return unwrapArray(this.props.children)({\n ref: this.setPopperNode,\n style: this.getPopperStyle(),\n placement: this.getPopperPlacement(),\n outOfBoundaries: this.getOutOfBoundariesState(),\n scheduleUpdate: this.scheduleUpdate,\n arrowProps: {\n ref: this.setArrowNode,\n style: this.getArrowStyle()\n }\n });\n };\n\n return InnerPopper;\n}(React.Component);\n\n_defineProperty(InnerPopper, \"defaultProps\", {\n placement: 'bottom',\n eventsEnabled: true,\n referenceElement: undefined,\n positionFixed: false\n});\n\nvar placements = PopperJS.placements;\nexport { placements };\nexport default function Popper(_ref) {\n var referenceElement = _ref.referenceElement,\n props = _objectWithoutPropertiesLoose(_ref, [\"referenceElement\"]);\n\n return React.createElement(ManagerReferenceNodeContext.Consumer, null, function (referenceNode) {\n return React.createElement(InnerPopper, _extends({\n referenceElement: referenceElement !== undefined ? referenceElement : referenceNode\n }, props));\n });\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _defineProperty from \"@babel/runtime/helpers/esm/defineProperty\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"right\", \"tag\", \"flip\", \"modifiers\", \"persist\", \"positionFixed\", \"container\"];\n\nfunction ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }\n\nfunction _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport ReactDOM from 'react-dom';\nimport classNames from 'classnames';\nimport { Popper } from 'react-popper';\nimport { DropdownContext } from './DropdownContext';\nimport { mapToCssModules, tagPropType, targetPropType, getTarget } from './utils';\nvar propTypes = {\n tag: tagPropType,\n children: PropTypes.node.isRequired,\n right: PropTypes.bool,\n flip: PropTypes.bool,\n modifiers: PropTypes.object,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n persist: PropTypes.bool,\n positionFixed: PropTypes.bool,\n container: targetPropType\n};\nvar defaultProps = {\n tag: 'div',\n flip: true\n};\nvar noFlipModifier = {\n flip: {\n enabled: false\n }\n};\nvar directionPositionMap = {\n up: 'top',\n left: 'left',\n right: 'right',\n down: 'bottom'\n};\n\nvar DropdownMenu = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(DropdownMenu, _React$Component);\n\n function DropdownMenu() {\n return _React$Component.apply(this, arguments) || this;\n }\n\n var _proto = DropdownMenu.prototype;\n\n _proto.getRole = function getRole() {\n if (this.context.menuRole === 'listbox') {\n return 'listbox';\n }\n\n return 'menu';\n };\n\n _proto.render = function render() {\n var _this = this;\n\n var _this$props = this.props,\n className = _this$props.className,\n cssModule = _this$props.cssModule,\n right = _this$props.right,\n tag = _this$props.tag,\n flip = _this$props.flip,\n modifiers = _this$props.modifiers,\n persist = _this$props.persist,\n positionFixed = _this$props.positionFixed,\n container = _this$props.container,\n attrs = _objectWithoutPropertiesLoose(_this$props, _excluded);\n\n var classes = mapToCssModules(classNames(className, 'dropdown-menu', {\n 'dropdown-menu-right': right,\n show: this.context.isOpen\n }), cssModule);\n var Tag = tag;\n\n if (persist || this.context.isOpen && !this.context.inNavbar) {\n var position1 = directionPositionMap[this.context.direction] || 'bottom';\n var position2 = right ? 'end' : 'start';\n var poperPlacement = position1 + \"-\" + position2;\n var poperModifiers = !flip ? _objectSpread(_objectSpread({}, modifiers), noFlipModifier) : modifiers;\n var popperPositionFixed = !!positionFixed;\n var popper = /*#__PURE__*/React.createElement(Popper, {\n placement: poperPlacement,\n modifiers: poperModifiers,\n positionFixed: popperPositionFixed\n }, function (_ref) {\n var ref = _ref.ref,\n style = _ref.style,\n placement = _ref.placement;\n\n var combinedStyle = _objectSpread(_objectSpread({}, _this.props.style), style);\n\n var handleRef = function handleRef(tagRef) {\n // Send the ref to `react-popper`\n ref(tagRef); // Send the ref to the parent Dropdown so that clicks outside\n // it will cause it to close\n\n var onMenuRef = _this.context.onMenuRef;\n if (onMenuRef) onMenuRef(tagRef);\n };\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n tabIndex: \"-1\",\n role: _this.getRole(),\n ref: handleRef\n }, attrs, {\n style: combinedStyle,\n \"aria-hidden\": !_this.context.isOpen,\n className: classes,\n \"x-placement\": placement\n }));\n });\n\n if (container) {\n return /*#__PURE__*/ReactDOM.createPortal(popper, getTarget(container));\n } else {\n return popper;\n }\n }\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n tabIndex: \"-1\",\n role: this.getRole()\n }, attrs, {\n \"aria-hidden\": !this.context.isOpen,\n className: classes,\n \"x-placement\": attrs.placement\n }));\n };\n\n return DropdownMenu;\n}(React.Component);\n\n;\nDropdownMenu.propTypes = propTypes;\nDropdownMenu.defaultProps = defaultProps;\nDropdownMenu.contextType = DropdownContext;\nexport default DropdownMenu;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _assertThisInitialized from \"@babel/runtime/helpers/esm/assertThisInitialized\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"divider\", \"tag\", \"header\", \"active\", \"text\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { DropdownContext } from './DropdownContext';\nimport { mapToCssModules, omit, tagPropType } from './utils';\nvar propTypes = {\n children: PropTypes.node,\n active: PropTypes.bool,\n disabled: PropTypes.bool,\n divider: PropTypes.bool,\n tag: tagPropType,\n header: PropTypes.bool,\n onClick: PropTypes.func,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n toggle: PropTypes.bool,\n text: PropTypes.bool\n};\nvar defaultProps = {\n tag: 'button',\n toggle: true\n};\n\nvar DropdownItem = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(DropdownItem, _React$Component);\n\n function DropdownItem(props) {\n var _this;\n\n _this = _React$Component.call(this, props) || this;\n _this.onClick = _this.onClick.bind(_assertThisInitialized(_this));\n _this.getTabIndex = _this.getTabIndex.bind(_assertThisInitialized(_this));\n return _this;\n }\n\n var _proto = DropdownItem.prototype;\n\n _proto.getRole = function getRole() {\n if (this.context.menuRole === 'listbox') {\n return 'option';\n }\n\n return 'menuitem';\n };\n\n _proto.onClick = function onClick(e) {\n var _this$props = this.props,\n disabled = _this$props.disabled,\n header = _this$props.header,\n divider = _this$props.divider,\n text = _this$props.text;\n\n if (disabled || header || divider || text) {\n e.preventDefault();\n return;\n }\n\n if (this.props.onClick) {\n this.props.onClick(e);\n }\n\n if (this.props.toggle) {\n this.context.toggle(e);\n }\n };\n\n _proto.getTabIndex = function getTabIndex() {\n var _this$props2 = this.props,\n disabled = _this$props2.disabled,\n header = _this$props2.header,\n divider = _this$props2.divider,\n text = _this$props2.text;\n\n if (disabled || header || divider || text) {\n return '-1';\n }\n\n return '0';\n };\n\n _proto.render = function render() {\n var tabIndex = this.getTabIndex();\n var role = tabIndex > -1 ? this.getRole() : undefined;\n\n var _omit = omit(this.props, ['toggle']),\n className = _omit.className,\n cssModule = _omit.cssModule,\n divider = _omit.divider,\n Tag = _omit.tag,\n header = _omit.header,\n active = _omit.active,\n text = _omit.text,\n props = _objectWithoutPropertiesLoose(_omit, _excluded);\n\n var classes = mapToCssModules(classNames(className, {\n disabled: props.disabled,\n 'dropdown-item': !divider && !header && !text,\n active: active,\n 'dropdown-header': header,\n 'dropdown-divider': divider,\n 'dropdown-item-text': text\n }), cssModule);\n\n if (Tag === 'button') {\n if (header) {\n Tag = 'h6';\n } else if (divider) {\n Tag = 'div';\n } else if (props.href) {\n Tag = 'a';\n } else if (text) {\n Tag = 'span';\n }\n }\n\n return /*#__PURE__*/React.createElement(Tag, _extends({\n type: Tag === 'button' && (props.onClick || this.props.toggle) ? 'button' : undefined\n }, props, {\n tabIndex: tabIndex,\n role: role,\n className: classes,\n onClick: this.onClick\n }));\n };\n\n return DropdownItem;\n}(React.Component);\n\nDropdownItem.propTypes = propTypes;\nDropdownItem.defaultProps = defaultProps;\nDropdownItem.contextType = DropdownContext;\nexport default DropdownItem;","import React from \"react\";\nimport \"bootstrap/dist/css/bootstrap.min.css\";\nimport {Navbar, Container, Collapse, NavbarBrand, Nav, NavItem, NavLink, UncontrolledDropdown, DropdownToggle, DropdownItem, DropdownMenu } from \"reactstrap\";\n\nexport default function AppNavBar() {\n return (\n
\n \n \n Home\n \n \n \n \n \n
\n );\n}","import React, { Component } from 'react';\nimport { Container } from 'reactstrap';\nimport '.././App.css';\nimport AppNavbar from '.././AppNavbar';\nimport logo from './img/robot-logo.png';\n\nclass Home extends Component {\n\n render() {\n return (\n
\n \n \n
\n \"logo\"/\n

iRonoc

\n

Web Application Development | Software Engineering | Data Engineering | Cloud Deployments | DevOps

\n
\n
\n
\n );\n }\n}\n\nexport default Home;\n","import React, { Component } from 'react';\nimport { Container } from 'reactstrap';\nimport '.././App.css';\nimport AppNavbar from '.././AppNavbar';\n\nclass About extends Component {\n\n render() {\n return (\n
\n \n \n
\n \n \"View\n \n
\n

Welcome, I'm Conor Heffron, a Software Engineer hailing from County Meath, Ireland.\n With over ten years of professional experience, I specialize in writing clean code and\n developing high-performance applications. As a passionate Full Stack Developer, I am constantly\n expanding my technical expertise across various tech stacks, languages, frameworks, and\n tools in the realm of Software, Data, and DevOps. Let's connect and explore exciting\n opportunities together! See above & below for contact details and further information.

\n
\n \n
\n \n
\n );\n }\n}\n\nexport default About;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"size\", \"vertical\", \"tag\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n tag: tagPropType,\n 'aria-label': PropTypes.string,\n className: PropTypes.string,\n cssModule: PropTypes.object,\n role: PropTypes.string,\n size: PropTypes.string,\n vertical: PropTypes.bool\n};\nvar defaultProps = {\n tag: 'div',\n role: 'group'\n};\n\nvar ButtonGroup = function ButtonGroup(props) {\n var className = props.className,\n cssModule = props.cssModule,\n size = props.size,\n vertical = props.vertical,\n Tag = props.tag,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var classes = mapToCssModules(classNames(className, size ? 'btn-group-' + size : false, vertical ? 'btn-group-vertical' : 'btn-group'), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n className: classes\n }));\n};\n\nButtonGroup.propTypes = propTypes;\nButtonGroup.defaultProps = defaultProps;\nexport default ButtonGroup;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"tag\", \"size\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n tag: tagPropType,\n size: PropTypes.string,\n className: PropTypes.string,\n cssModule: PropTypes.object\n};\nvar defaultProps = {\n tag: 'div'\n};\n\nvar InputGroup = function InputGroup(props) {\n var className = props.className,\n cssModule = props.cssModule,\n Tag = props.tag,\n size = props.size,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var classes = mapToCssModules(classNames(className, 'input-group', size ? \"input-group-\" + size : null), cssModule);\n return /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n className: classes\n }));\n};\n\nInputGroup.propTypes = propTypes;\nInputGroup.defaultProps = defaultProps;\nexport default InputGroup;","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nvar _excluded = [\"className\", \"cssModule\", \"size\", \"bordered\", \"borderless\", \"striped\", \"dark\", \"hover\", \"responsive\", \"tag\", \"responsiveTag\", \"innerRef\"];\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport classNames from 'classnames';\nimport { mapToCssModules, tagPropType } from './utils';\nvar propTypes = {\n className: PropTypes.string,\n cssModule: PropTypes.object,\n size: PropTypes.string,\n bordered: PropTypes.bool,\n borderless: PropTypes.bool,\n striped: PropTypes.bool,\n dark: PropTypes.bool,\n hover: PropTypes.bool,\n responsive: PropTypes.oneOfType([PropTypes.bool, PropTypes.string]),\n tag: tagPropType,\n responsiveTag: tagPropType,\n innerRef: PropTypes.oneOfType([PropTypes.func, PropTypes.string, PropTypes.object])\n};\nvar defaultProps = {\n tag: 'table',\n responsiveTag: 'div'\n};\n\nvar Table = function Table(props) {\n var className = props.className,\n cssModule = props.cssModule,\n size = props.size,\n bordered = props.bordered,\n borderless = props.borderless,\n striped = props.striped,\n dark = props.dark,\n hover = props.hover,\n responsive = props.responsive,\n Tag = props.tag,\n ResponsiveTag = props.responsiveTag,\n innerRef = props.innerRef,\n attributes = _objectWithoutPropertiesLoose(props, _excluded);\n\n var classes = mapToCssModules(classNames(className, 'table', size ? 'table-' + size : false, bordered ? 'table-bordered' : false, borderless ? 'table-borderless' : false, striped ? 'table-striped' : false, dark ? 'table-dark' : false, hover ? 'table-hover' : false), cssModule);\n var table = /*#__PURE__*/React.createElement(Tag, _extends({}, attributes, {\n ref: innerRef,\n className: classes\n }));\n\n if (responsive) {\n var responsiveClassName = mapToCssModules(responsive === true ? 'table-responsive' : \"table-responsive-\" + responsive, cssModule);\n return /*#__PURE__*/React.createElement(ResponsiveTag, {\n className: responsiveClassName\n }, table);\n }\n\n return table;\n};\n\nTable.propTypes = propTypes;\nTable.defaultProps = defaultProps;\nexport default Table;","import classNames from 'classnames';\nimport * as React from 'react';\nimport PropTypes from 'prop-types';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst propTypes = {\n /**\n * Specify whether the feedback is for valid or invalid fields\n *\n * @type {('valid'|'invalid')}\n */\n type: PropTypes.string,\n /** Display feedback as a tooltip. */\n tooltip: PropTypes.bool,\n as: PropTypes.elementType\n};\nconst Feedback = /*#__PURE__*/React.forwardRef(\n// Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n({\n as: Component = 'div',\n className,\n type = 'valid',\n tooltip = false,\n ...props\n}, ref) => /*#__PURE__*/_jsx(Component, {\n ...props,\n ref: ref,\n className: classNames(className, `${type}-${tooltip ? 'tooltip' : 'feedback'}`)\n}));\nFeedback.displayName = 'Feedback';\nFeedback.propTypes = propTypes;\nexport default Feedback;","\"use client\";\n\nimport * as React from 'react';\n\n// TODO\n\nconst FormContext = /*#__PURE__*/React.createContext({});\nexport default FormContext;","\"use client\";\n\nimport * as React from 'react';\nimport { useContext, useMemo } from 'react';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport const DEFAULT_BREAKPOINTS = ['xxl', 'xl', 'lg', 'md', 'sm', 'xs'];\nexport const DEFAULT_MIN_BREAKPOINT = 'xs';\nconst ThemeContext = /*#__PURE__*/React.createContext({\n prefixes: {},\n breakpoints: DEFAULT_BREAKPOINTS,\n minBreakpoint: DEFAULT_MIN_BREAKPOINT\n});\nconst {\n Consumer,\n Provider\n} = ThemeContext;\nfunction ThemeProvider({\n prefixes = {},\n breakpoints = DEFAULT_BREAKPOINTS,\n minBreakpoint = DEFAULT_MIN_BREAKPOINT,\n dir,\n children\n}) {\n const contextValue = useMemo(() => ({\n prefixes: {\n ...prefixes\n },\n breakpoints,\n minBreakpoint,\n dir\n }), [prefixes, breakpoints, minBreakpoint, dir]);\n return /*#__PURE__*/_jsx(Provider, {\n value: contextValue,\n children: children\n });\n}\nexport function useBootstrapPrefix(prefix, defaultPrefix) {\n const {\n prefixes\n } = useContext(ThemeContext);\n return prefix || prefixes[defaultPrefix] || defaultPrefix;\n}\nexport function useBootstrapBreakpoints() {\n const {\n breakpoints\n } = useContext(ThemeContext);\n return breakpoints;\n}\nexport function useBootstrapMinBreakpoint() {\n const {\n minBreakpoint\n } = useContext(ThemeContext);\n return minBreakpoint;\n}\nexport function useIsRTL() {\n const {\n dir\n } = useContext(ThemeContext);\n return dir === 'rtl';\n}\nfunction createBootstrapComponent(Component, opts) {\n if (typeof opts === 'string') opts = {\n prefix: opts\n };\n const isClassy = Component.prototype && Component.prototype.isReactComponent;\n // If it's a functional component make sure we don't break it with a ref\n const {\n prefix,\n forwardRefAs = isClassy ? 'ref' : 'innerRef'\n } = opts;\n const Wrapped = /*#__PURE__*/React.forwardRef(({\n ...props\n }, ref) => {\n props[forwardRefAs] = ref;\n const bsPrefix = useBootstrapPrefix(props.bsPrefix, prefix);\n return /*#__PURE__*/_jsx(Component, {\n ...props,\n bsPrefix: bsPrefix\n });\n });\n Wrapped.displayName = `Bootstrap(${Component.displayName || Component.name})`;\n return Wrapped;\n}\nexport { createBootstrapComponent, Consumer as ThemeConsumer };\nexport default ThemeProvider;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useContext } from 'react';\nimport FormContext from './FormContext';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormCheckInput = /*#__PURE__*/React.forwardRef(({\n id,\n bsPrefix,\n className,\n type = 'checkbox',\n isValid = false,\n isInvalid = false,\n // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n as: Component = 'input',\n ...props\n}, ref) => {\n const {\n controlId\n } = useContext(FormContext);\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-check-input');\n return /*#__PURE__*/_jsx(Component, {\n ...props,\n ref: ref,\n type: type,\n id: id || controlId,\n className: classNames(className, bsPrefix, isValid && 'is-valid', isInvalid && 'is-invalid')\n });\n});\nFormCheckInput.displayName = 'FormCheckInput';\nexport default FormCheckInput;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useContext } from 'react';\nimport FormContext from './FormContext';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormCheckLabel = /*#__PURE__*/React.forwardRef(({\n bsPrefix,\n className,\n htmlFor,\n ...props\n}, ref) => {\n const {\n controlId\n } = useContext(FormContext);\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-check-label');\n return /*#__PURE__*/_jsx(\"label\", {\n ...props,\n ref: ref,\n htmlFor: htmlFor || controlId,\n className: classNames(className, bsPrefix)\n });\n});\nFormCheckLabel.displayName = 'FormCheckLabel';\nexport default FormCheckLabel;","import * as React from 'react';\n\n/**\n * Iterates through children that are typically specified as `props.children`,\n * but only maps over children that are \"valid elements\".\n *\n * The mapFunction provided index will be normalised to the components mapped,\n * so an invalid component would not increase the index.\n *\n */\nfunction map(children, func) {\n let index = 0;\n return React.Children.map(children, child => /*#__PURE__*/React.isValidElement(child) ? func(child, index++) : child);\n}\n\n/**\n * Iterates through children that are \"valid elements\".\n *\n * The provided forEachFunc(child, index) will be called for each\n * leaf child with the index reflecting the position relative to \"valid components\".\n */\nfunction forEach(children, func) {\n let index = 0;\n React.Children.forEach(children, child => {\n if ( /*#__PURE__*/React.isValidElement(child)) func(child, index++);\n });\n}\n\n/**\n * Finds whether a component's `children` prop includes a React element of the\n * specified type.\n */\nfunction hasChildOfType(children, type) {\n return React.Children.toArray(children).some(child => /*#__PURE__*/React.isValidElement(child) && child.type === type);\n}\nexport { map, forEach, hasChildOfType };","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useContext, useMemo } from 'react';\nimport Feedback from './Feedback';\nimport FormCheckInput from './FormCheckInput';\nimport FormCheckLabel from './FormCheckLabel';\nimport FormContext from './FormContext';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { hasChildOfType } from './ElementChildren';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { Fragment as _Fragment } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nconst FormCheck = /*#__PURE__*/React.forwardRef(({\n id,\n bsPrefix,\n bsSwitchPrefix,\n inline = false,\n reverse = false,\n disabled = false,\n isValid = false,\n isInvalid = false,\n feedbackTooltip = false,\n feedback,\n feedbackType,\n className,\n style,\n title = '',\n type = 'checkbox',\n label,\n children,\n // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n as = 'input',\n ...props\n}, ref) => {\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-check');\n bsSwitchPrefix = useBootstrapPrefix(bsSwitchPrefix, 'form-switch');\n const {\n controlId\n } = useContext(FormContext);\n const innerFormContext = useMemo(() => ({\n controlId: id || controlId\n }), [controlId, id]);\n const hasLabel = !children && label != null && label !== false || hasChildOfType(children, FormCheckLabel);\n const input = /*#__PURE__*/_jsx(FormCheckInput, {\n ...props,\n type: type === 'switch' ? 'checkbox' : type,\n ref: ref,\n isValid: isValid,\n isInvalid: isInvalid,\n disabled: disabled,\n as: as\n });\n return /*#__PURE__*/_jsx(FormContext.Provider, {\n value: innerFormContext,\n children: /*#__PURE__*/_jsx(\"div\", {\n style: style,\n className: classNames(className, hasLabel && bsPrefix, inline && `${bsPrefix}-inline`, reverse && `${bsPrefix}-reverse`, type === 'switch' && bsSwitchPrefix),\n children: children || /*#__PURE__*/_jsxs(_Fragment, {\n children: [input, hasLabel && /*#__PURE__*/_jsx(FormCheckLabel, {\n title: title,\n children: label\n }), feedback && /*#__PURE__*/_jsx(Feedback, {\n type: feedbackType,\n tooltip: feedbackTooltip,\n children: feedback\n })]\n })\n })\n });\n});\nFormCheck.displayName = 'FormCheck';\nexport default Object.assign(FormCheck, {\n Input: FormCheckInput,\n Label: FormCheckLabel\n});","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useContext } from 'react';\nimport warning from 'warning';\nimport Feedback from './Feedback';\nimport FormContext from './FormContext';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormControl = /*#__PURE__*/React.forwardRef(({\n bsPrefix,\n type,\n size,\n htmlSize,\n id,\n className,\n isValid = false,\n isInvalid = false,\n plaintext,\n readOnly,\n // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n as: Component = 'input',\n ...props\n}, ref) => {\n const {\n controlId\n } = useContext(FormContext);\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-control');\n process.env.NODE_ENV !== \"production\" ? warning(controlId == null || !id, '`controlId` is ignored on `` when `id` is specified.') : void 0;\n return /*#__PURE__*/_jsx(Component, {\n ...props,\n type: type,\n size: htmlSize,\n ref: ref,\n readOnly: readOnly,\n id: id || controlId,\n className: classNames(className, plaintext ? `${bsPrefix}-plaintext` : bsPrefix, size && `${bsPrefix}-${size}`, type === 'color' && `${bsPrefix}-color`, isValid && 'is-valid', isInvalid && 'is-invalid')\n });\n});\nFormControl.displayName = 'FormControl';\nexport default Object.assign(FormControl, {\n Feedback\n});","\"use client\";\n\nimport * as React from 'react';\nimport classNames from 'classnames';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormFloating = /*#__PURE__*/React.forwardRef(({\n className,\n bsPrefix,\n as: Component = 'div',\n ...props\n}, ref) => {\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-floating');\n return /*#__PURE__*/_jsx(Component, {\n ref: ref,\n className: classNames(className, bsPrefix),\n ...props\n });\n});\nFormFloating.displayName = 'FormFloating';\nexport default FormFloating;","import * as React from 'react';\nimport { useMemo } from 'react';\nimport FormContext from './FormContext';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormGroup = /*#__PURE__*/React.forwardRef(({\n controlId,\n // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n as: Component = 'div',\n ...props\n}, ref) => {\n const context = useMemo(() => ({\n controlId\n }), [controlId]);\n return /*#__PURE__*/_jsx(FormContext.Provider, {\n value: context,\n children: /*#__PURE__*/_jsx(Component, {\n ...props,\n ref: ref\n })\n });\n});\nFormGroup.displayName = 'FormGroup';\nexport default FormGroup;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useBootstrapPrefix, useBootstrapBreakpoints, useBootstrapMinBreakpoint } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport function useCol({\n as,\n bsPrefix,\n className,\n ...props\n}) {\n bsPrefix = useBootstrapPrefix(bsPrefix, 'col');\n const breakpoints = useBootstrapBreakpoints();\n const minBreakpoint = useBootstrapMinBreakpoint();\n const spans = [];\n const classes = [];\n breakpoints.forEach(brkPoint => {\n const propValue = props[brkPoint];\n delete props[brkPoint];\n let span;\n let offset;\n let order;\n if (typeof propValue === 'object' && propValue != null) {\n ({\n span,\n offset,\n order\n } = propValue);\n } else {\n span = propValue;\n }\n const infix = brkPoint !== minBreakpoint ? `-${brkPoint}` : '';\n if (span) spans.push(span === true ? `${bsPrefix}${infix}` : `${bsPrefix}${infix}-${span}`);\n if (order != null) classes.push(`order${infix}-${order}`);\n if (offset != null) classes.push(`offset${infix}-${offset}`);\n });\n return [{\n ...props,\n className: classNames(className, ...spans, ...classes)\n }, {\n as,\n bsPrefix,\n spans\n }];\n}\nconst Col = /*#__PURE__*/React.forwardRef(\n// Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n(props, ref) => {\n const [{\n className,\n ...colProps\n }, {\n as: Component = 'div',\n bsPrefix,\n spans\n }] = useCol(props);\n return /*#__PURE__*/_jsx(Component, {\n ...colProps,\n ref: ref,\n className: classNames(className, !spans.length && bsPrefix)\n });\n});\nCol.displayName = 'Col';\nexport default Col;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useContext } from 'react';\nimport warning from 'warning';\nimport Col from './Col';\nimport FormContext from './FormContext';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormLabel = /*#__PURE__*/React.forwardRef(({\n // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n as: Component = 'label',\n bsPrefix,\n column = false,\n visuallyHidden = false,\n className,\n htmlFor,\n ...props\n}, ref) => {\n const {\n controlId\n } = useContext(FormContext);\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-label');\n let columnClass = 'col-form-label';\n if (typeof column === 'string') columnClass = `${columnClass} ${columnClass}-${column}`;\n const classes = classNames(className, bsPrefix, visuallyHidden && 'visually-hidden', column && columnClass);\n process.env.NODE_ENV !== \"production\" ? warning(controlId == null || !htmlFor, '`controlId` is ignored on `` when `htmlFor` is specified.') : void 0;\n htmlFor = htmlFor || controlId;\n if (column) return /*#__PURE__*/_jsx(Col, {\n ref: ref,\n as: \"label\",\n className: classes,\n htmlFor: htmlFor,\n ...props\n });\n return (\n /*#__PURE__*/\n // eslint-disable-next-line jsx-a11y/label-has-for, jsx-a11y/label-has-associated-control\n _jsx(Component, {\n ref: ref,\n className: classes,\n htmlFor: htmlFor,\n ...props\n })\n );\n});\nFormLabel.displayName = 'FormLabel';\nexport default FormLabel;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useContext } from 'react';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport FormContext from './FormContext';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormRange = /*#__PURE__*/React.forwardRef(({\n bsPrefix,\n className,\n id,\n ...props\n}, ref) => {\n const {\n controlId\n } = useContext(FormContext);\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-range');\n return /*#__PURE__*/_jsx(\"input\", {\n ...props,\n type: \"range\",\n ref: ref,\n className: classNames(className, bsPrefix),\n id: id || controlId\n });\n});\nFormRange.displayName = 'FormRange';\nexport default FormRange;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useContext } from 'react';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport FormContext from './FormContext';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormSelect = /*#__PURE__*/React.forwardRef(({\n bsPrefix,\n size,\n htmlSize,\n className,\n isValid = false,\n isInvalid = false,\n id,\n ...props\n}, ref) => {\n const {\n controlId\n } = useContext(FormContext);\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-select');\n return /*#__PURE__*/_jsx(\"select\", {\n ...props,\n size: htmlSize,\n ref: ref,\n className: classNames(className, bsPrefix, size && `${bsPrefix}-${size}`, isValid && `is-valid`, isInvalid && `is-invalid`),\n id: id || controlId\n });\n});\nFormSelect.displayName = 'FormSelect';\nexport default FormSelect;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst FormText = /*#__PURE__*/React.forwardRef(\n// Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n({\n bsPrefix,\n className,\n as: Component = 'small',\n muted,\n ...props\n}, ref) => {\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-text');\n return /*#__PURE__*/_jsx(Component, {\n ...props,\n ref: ref,\n className: classNames(className, bsPrefix, muted && 'text-muted')\n });\n});\nFormText.displayName = 'FormText';\nexport default FormText;","import * as React from 'react';\nimport FormCheck from './FormCheck';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst Switch = /*#__PURE__*/React.forwardRef((props, ref) => /*#__PURE__*/_jsx(FormCheck, {\n ...props,\n ref: ref,\n type: \"switch\"\n}));\nSwitch.displayName = 'Switch';\nexport default Object.assign(Switch, {\n Input: FormCheck.Input,\n Label: FormCheck.Label\n});","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport FormGroup from './FormGroup';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nimport { jsxs as _jsxs } from \"react/jsx-runtime\";\nconst FloatingLabel = /*#__PURE__*/React.forwardRef(({\n bsPrefix,\n className,\n children,\n controlId,\n label,\n ...props\n}, ref) => {\n bsPrefix = useBootstrapPrefix(bsPrefix, 'form-floating');\n return /*#__PURE__*/_jsxs(FormGroup, {\n ref: ref,\n className: classNames(className, bsPrefix),\n controlId: controlId,\n ...props,\n children: [children, /*#__PURE__*/_jsx(\"label\", {\n htmlFor: controlId,\n children: label\n })]\n });\n});\nFloatingLabel.displayName = 'FloatingLabel';\nexport default FloatingLabel;","import classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport * as React from 'react';\nimport FormCheck from './FormCheck';\nimport FormControl from './FormControl';\nimport FormFloating from './FormFloating';\nimport FormGroup from './FormGroup';\nimport FormLabel from './FormLabel';\nimport FormRange from './FormRange';\nimport FormSelect from './FormSelect';\nimport FormText from './FormText';\nimport Switch from './Switch';\nimport FloatingLabel from './FloatingLabel';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst propTypes = {\n /**\n * The Form `ref` will be forwarded to the underlying element,\n * which means, unless it's rendered `as` a composite component,\n * it will be a DOM node, when resolved.\n *\n * @type {ReactRef}\n * @alias ref\n */\n _ref: PropTypes.any,\n /**\n * Mark a form as having been validated. Setting it to `true` will\n * toggle any validation styles on the forms elements.\n */\n validated: PropTypes.bool,\n as: PropTypes.elementType\n};\nconst Form = /*#__PURE__*/React.forwardRef(({\n className,\n validated,\n // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n as: Component = 'form',\n ...props\n}, ref) => /*#__PURE__*/_jsx(Component, {\n ...props,\n ref: ref,\n className: classNames(className, validated && 'was-validated')\n}));\nForm.displayName = 'Form';\nForm.propTypes = propTypes;\nexport default Object.assign(Form, {\n Group: FormGroup,\n Control: FormControl,\n Floating: FormFloating,\n Check: FormCheck,\n Switch,\n Label: FormLabel,\n Text: FormText,\n Range: FormRange,\n Select: FormSelect,\n FloatingLabel\n});","import React, { Component } from 'react';\nimport { Button, ButtonGroup, Container, InputGroup, Table } from 'reactstrap';\nimport '.././App.css';\nimport Form from 'react-bootstrap/Form';\nimport AppNavbar from '.././AppNavbar';\nimport { Link } from 'react-router-dom';\n\nclass RepoDetails extends Component {\n\n constructor(props) {\n super(props);\n this.state = {repoDetailList: [], isLoading: true, value: ''};\n\n this.handleChange = this.handleChange.bind(this);\n this.onSubmit = this.onSubmit.bind(this);\n }\n\n handleChange(event) {\n const {repos, isL, value} = this.state;\n this.setState({repoDetailList: repos, isLoading: isL, value: event.target.value});\n }\n\n onSubmit(event){\n let id = this.state.value;\n this.props.history.push(`/projects/${id}`, {\n id: id\n });\n }\n\n async componentDidMount() {\n const response = await fetch(`/get-repo-detail?username=${this.props.match.params.id}`);\n console.log(response);\n const body = await response.json();\n this.setState({repoDetailList: body, isLoading: false});\n }\n\n render() {\n const {repoDetailList, isLoading} = this.state;\n\n if (isLoading) {\n return

Loading...

;\n }\n\n let gitUser = this.props.match.params.id;\n const repoList = repoDetailList.map(repo => {\n return \n {repo.fullName}\n {repo.description}\n {repo.name}\n {repo.topics}\n \n \n \n \n \n \n });\n\n return (\n
\n

\n \n
\n \n this.setState({ value: e.target.value })} type=\"text\"/>\n \n \n

GitHub Projects for username: {this.props.match.params.id}

\n \n \n \n \n \n \n \n \n \n \n {repoList}\n
RepositoryDescriptionApp URLTopicsActions
\n
\n
\n );\n }\n}\n\nexport default RepoDetails;\n","import React, { Component } from 'react';\nimport { Button, Container, InputGroup, Table } from 'reactstrap';\nimport '.././App.css';\nimport Form from 'react-bootstrap/Form';\nimport AppNavbar from '.././AppNavbar';\n\nclass RepoIssues extends Component {\n\n constructor(props) {\n super(props);\n this.state = {repoIssueList: [], isLoading: true, value: ''};\n\n this.handleChange = this.handleChange.bind(this);\n this.onSubmit = this.onSubmit.bind(this);\n }\n\n handleChange(event) {\n const {issues, isL, value} = this.state;\n this.setState({repoIssueList: issues, isLoading: isL, value: event.target.value});\n }\n\n onSubmit(event){\n let repo = this.state.value;\n let id = this.props.match.params.id;\n this.props.history.push(`/issues/${id}/${repo}`, {\n id: id,\n repo: repo\n });\n }\n\n async componentDidMount() {\n const response = await fetch(`/get-repo-issue/${this.props.match.params.id}/${this.props.match.params.repo}/`);\n const body = await response.json();\n console.log(body)\n this.setState({repoIssueList: body, isLoading: false});\n }\n\n render() {\n const {repoIssueList, isLoading} = this.state;\n if (isLoading) {\n return

Loading...

;\n }\n const repoList = repoIssueList.map(issue => {\n return \n {issue.number}\n {issue.title}\n {issue.body}\n \n });\n return (\n
\n

\n \n
\n \n this.setState({ value: e.target.value })} />\n \n \n

Issues for project {this.props.match.params.repo} and account {this.props.match.params.id}

\n \n \n \n \n \n \n \n \n {repoList}\n
Issue No.TitleDescription
\n
\n
\n );\n }\n}\n\nexport default RepoIssues;\n","import { useEffect, useRef } from 'react';\n\n/**\n * Creates a `Ref` whose value is updated in an effect, ensuring the most recent\n * value is the one rendered with. Generally only required for Concurrent mode usage\n * where previous work in `render()` may be discarded before being used.\n *\n * This is safe to access in an event handler.\n *\n * @param value The `Ref` value\n */\nfunction useCommittedRef(value) {\n const ref = useRef(value);\n useEffect(() => {\n ref.current = value;\n }, [value]);\n return ref;\n}\nexport default useCommittedRef;","import { useCallback } from 'react';\nimport useCommittedRef from './useCommittedRef';\nexport default function useEventCallback(fn) {\n const ref = useCommittedRef(fn);\n return useCallback(function (...args) {\n return ref.current && ref.current(...args);\n }, [ref]);\n}","import { useEffect, useRef } from 'react';\n\n/**\n * Runs an effect only when the dependencies have changed, skipping the\n * initial \"on mount\" run. Caution, if the dependency list never changes,\n * the effect is **never run**\n *\n * ```ts\n * const ref = useRef(null);\n *\n * // focuses an element only if the focus changes, and not on mount\n * useUpdateEffect(() => {\n * const element = ref.current?.children[focusedIdx] as HTMLElement\n *\n * element?.focus()\n *\n * }, [focusedIndex])\n * ```\n * @param effect An effect to run on mount\n *\n * @category effects\n */\nfunction useUpdateEffect(fn, deps) {\n const isFirst = useRef(true);\n useEffect(() => {\n if (isFirst.current) {\n isFirst.current = false;\n return;\n }\n return fn();\n }, deps);\n}\nexport default useUpdateEffect;","import useUpdatedRef from './useUpdatedRef';\nimport { useEffect } from 'react';\n\n/**\n * Attach a callback that fires when a component unmounts\n *\n * @param fn Handler to run when the component unmounts\n * @category effects\n */\nexport default function useWillUnmount(fn) {\n const onUnmount = useUpdatedRef(fn);\n useEffect(() => () => onUnmount.current(), []);\n}","import { useRef } from 'react';\n\n/**\n * Returns a ref that is immediately updated with the new value\n *\n * @param value The Ref value\n * @category refs\n */\nexport default function useUpdatedRef(value) {\n const valueRef = useRef(value);\n valueRef.current = value;\n return valueRef;\n}","import { useMemo, useRef } from 'react';\nimport useMounted from './useMounted';\nimport useWillUnmount from './useWillUnmount';\n\n/*\n * Browsers including Internet Explorer, Chrome, Safari, and Firefox store the\n * delay as a 32-bit signed integer internally. This causes an integer overflow\n * when using delays larger than 2,147,483,647 ms (about 24.8 days),\n * resulting in the timeout being executed immediately.\n *\n * via: https://developer.mozilla.org/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout\n */\nconst MAX_DELAY_MS = 2 ** 31 - 1;\nfunction setChainedTimeout(handleRef, fn, timeoutAtMs) {\n const delayMs = timeoutAtMs - Date.now();\n handleRef.current = delayMs <= MAX_DELAY_MS ? setTimeout(fn, delayMs) : setTimeout(() => setChainedTimeout(handleRef, fn, timeoutAtMs), MAX_DELAY_MS);\n}\n\n/**\n * Returns a controller object for setting a timeout that is properly cleaned up\n * once the component unmounts. New timeouts cancel and replace existing ones.\n *\n *\n *\n * ```tsx\n * const { set, clear } = useTimeout();\n * const [hello, showHello] = useState(false);\n * //Display hello after 5 seconds\n * set(() => showHello(true), 5000);\n * return (\n *
\n * {hello ?

Hello

: null}\n *
\n * );\n * ```\n */\nexport default function useTimeout() {\n const isMounted = useMounted();\n\n // types are confused between node and web here IDK\n const handleRef = useRef();\n useWillUnmount(() => clearTimeout(handleRef.current));\n return useMemo(() => {\n const clear = () => clearTimeout(handleRef.current);\n function set(fn, delayMs = 0) {\n if (!isMounted()) return;\n clear();\n if (delayMs <= MAX_DELAY_MS) {\n // For simplicity, if the timeout is short, just set a normal timeout.\n handleRef.current = setTimeout(fn, delayMs);\n } else {\n setChainedTimeout(handleRef, fn, Date.now() + delayMs);\n }\n }\n return {\n set,\n clear,\n handleRef\n };\n }, []);\n}","import { useRef, useEffect } from 'react';\n\n/**\n * Track whether a component is current mounted. Generally less preferable than\n * properlly canceling effects so they don't run after a component is unmounted,\n * but helpful in cases where that isn't feasible, such as a `Promise` resolution.\n *\n * @returns a function that returns the current isMounted state of the component\n *\n * ```ts\n * const [data, setData] = useState(null)\n * const isMounted = useMounted()\n *\n * useEffect(() => {\n * fetchdata().then((newData) => {\n * if (isMounted()) {\n * setData(newData);\n * }\n * })\n * })\n * ```\n */\nexport default function useMounted() {\n const mounted = useRef(true);\n const isMounted = useRef(() => mounted.current);\n useEffect(() => {\n mounted.current = true;\n return () => {\n mounted.current = false;\n };\n }, []);\n return isMounted.current;\n}","import { useEffect, useLayoutEffect } from 'react';\nconst isReactNative = typeof global !== 'undefined' &&\n// @ts-ignore\nglobal.navigator &&\n// @ts-ignore\nglobal.navigator.product === 'ReactNative';\nconst isDOM = typeof document !== 'undefined';\n\n/**\n * Is `useLayoutEffect` in a DOM or React Native environment, otherwise resolves to useEffect\n * Only useful to avoid the console warning.\n *\n * PREFER `useEffect` UNLESS YOU KNOW WHAT YOU ARE DOING.\n *\n * @category effects\n */\nexport default isDOM || isReactNative ? useLayoutEffect : useEffect;","import { useState } from 'react';\nimport useEffect from './useIsomorphicEffect';\nconst targetMap = new WeakMap();\nlet resizeObserver;\nfunction getResizeObserver() {\n // eslint-disable-next-line no-return-assign\n return resizeObserver = resizeObserver || new window.ResizeObserver(entries => {\n entries.forEach(entry => {\n const handler = targetMap.get(entry.target);\n if (handler) handler(entry.contentRect);\n });\n });\n}\n\n/**\n * Efficiently observe size changes on an element. Depends on the `ResizeObserver` api,\n * and polyfills are needed in older browsers.\n *\n * ```ts\n * const [ref, attachRef] = useCallbackRef(null);\n *\n * const rect = useResizeObserver(ref);\n *\n * return (\n *
\n * {JSON.stringify(rect)}\n *
\n * )\n * ```\n *\n * @param element The DOM element to observe\n */\nexport default function useResizeObserver(element) {\n const [rect, setRect] = useState(null);\n useEffect(() => {\n if (!element) return;\n getResizeObserver().observe(element);\n setRect(element.getBoundingClientRect());\n targetMap.set(element, rect => {\n setRect(rect);\n });\n return () => {\n targetMap.delete(element);\n };\n }, [element]);\n return rect;\n}","const _excluded = [\"as\", \"disabled\"];\nfunction _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.indexOf(n) >= 0) continue; t[n] = r[n]; } return t; }\nimport * as React from 'react';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport function isTrivialHref(href) {\n return !href || href.trim() === '#';\n}\nexport function useButtonProps({\n tagName,\n disabled,\n href,\n target,\n rel,\n role,\n onClick,\n tabIndex = 0,\n type\n}) {\n if (!tagName) {\n if (href != null || target != null || rel != null) {\n tagName = 'a';\n } else {\n tagName = 'button';\n }\n }\n const meta = {\n tagName\n };\n if (tagName === 'button') {\n return [{\n type: type || 'button',\n disabled\n }, meta];\n }\n const handleClick = event => {\n if (disabled || tagName === 'a' && isTrivialHref(href)) {\n event.preventDefault();\n }\n if (disabled) {\n event.stopPropagation();\n return;\n }\n onClick == null ? void 0 : onClick(event);\n };\n const handleKeyDown = event => {\n if (event.key === ' ') {\n event.preventDefault();\n handleClick(event);\n }\n };\n if (tagName === 'a') {\n // Ensure there's a href so Enter can trigger anchor button.\n href || (href = '#');\n if (disabled) {\n href = undefined;\n }\n }\n return [{\n role: role != null ? role : 'button',\n // explicitly undefined so that it overrides the props disabled in a spread\n // e.g. \n disabled: undefined,\n tabIndex: disabled ? undefined : tabIndex,\n href,\n target: tagName === 'a' ? target : undefined,\n 'aria-disabled': !disabled ? undefined : disabled,\n rel: tagName === 'a' ? rel : undefined,\n onClick: handleClick,\n onKeyDown: handleKeyDown\n }, meta];\n}\nconst Button = /*#__PURE__*/React.forwardRef((_ref, ref) => {\n let {\n as: asProp,\n disabled\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded);\n const [buttonProps, {\n tagName: Component\n }] = useButtonProps(Object.assign({\n tagName: asProp,\n disabled\n }, props));\n return /*#__PURE__*/_jsx(Component, Object.assign({}, props, buttonProps, {\n ref: ref\n }));\n});\nButton.displayName = 'Button';\nexport default Button;","const _excluded = [\"onKeyDown\"];\nfunction _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.indexOf(n) >= 0) continue; t[n] = r[n]; } return t; }\n/* eslint-disable jsx-a11y/no-static-element-interactions */\n/* eslint-disable jsx-a11y/anchor-has-content */\n\nimport * as React from 'react';\nimport { useEventCallback } from '@restart/hooks';\nimport { useButtonProps } from './Button';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nexport function isTrivialHref(href) {\n return !href || href.trim() === '#';\n}\n/**\n * An generic `` component that covers a few A11y cases, ensuring that\n * cases where the `href` is missing or trivial like \"#\" are treated like buttons.\n */\nconst Anchor = /*#__PURE__*/React.forwardRef((_ref, ref) => {\n let {\n onKeyDown\n } = _ref,\n props = _objectWithoutPropertiesLoose(_ref, _excluded);\n const [buttonProps] = useButtonProps(Object.assign({\n tagName: 'a'\n }, props));\n const handleKeyDown = useEventCallback(e => {\n buttonProps.onKeyDown(e);\n onKeyDown == null ? void 0 : onKeyDown(e);\n });\n if (isTrivialHref(props.href) || props.role === 'button') {\n return /*#__PURE__*/_jsx(\"a\", Object.assign({\n ref: ref\n }, props, buttonProps, {\n onKeyDown: handleKeyDown\n }));\n }\n return /*#__PURE__*/_jsx(\"a\", Object.assign({\n ref: ref\n }, props, {\n onKeyDown: onKeyDown\n }));\n});\nAnchor.displayName = 'Anchor';\nexport default Anchor;","import invariant from 'invariant';\n\nvar noop = function noop() {};\n\nfunction readOnlyPropType(handler, name) {\n return function (props, propName) {\n if (props[propName] !== undefined) {\n if (!props[handler]) {\n return new Error(\"You have provided a `\" + propName + \"` prop to `\" + name + \"` \" + (\"without an `\" + handler + \"` handler prop. This will render a read-only field. \") + (\"If the field should be mutable use `\" + defaultKey(propName) + \"`. \") + (\"Otherwise, set `\" + handler + \"`.\"));\n }\n }\n };\n}\n\nexport function uncontrolledPropTypes(controlledValues, displayName) {\n var propTypes = {};\n Object.keys(controlledValues).forEach(function (prop) {\n // add default propTypes for folks that use runtime checks\n propTypes[defaultKey(prop)] = noop;\n\n if (process.env.NODE_ENV !== 'production') {\n var handler = controlledValues[prop];\n !(typeof handler === 'string' && handler.trim().length) ? process.env.NODE_ENV !== \"production\" ? invariant(false, 'Uncontrollable - [%s]: the prop `%s` needs a valid handler key name in order to make it uncontrollable', displayName, prop) : invariant(false) : void 0;\n propTypes[prop] = readOnlyPropType(handler, displayName);\n }\n });\n return propTypes;\n}\nexport function isProp(props, prop) {\n return props[prop] !== undefined;\n}\nexport function defaultKey(key) {\n return 'default' + key.charAt(0).toUpperCase() + key.substr(1);\n}\n/**\n * Copyright (c) 2013-present, Facebook, Inc.\n * All rights reserved.\n *\n * This source code is licensed under the BSD-style license found in the\n * LICENSE file in the root directory of this source tree. An additional grant\n * of patent rights can be found in the PATENTS file in the same directory.\n */\n\nexport function canAcceptRef(component) {\n return !!component && (typeof component !== 'function' || component.prototype && component.prototype.isReactComponent);\n}","import _extends from \"@babel/runtime/helpers/esm/extends\";\nimport _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\n\nfunction _toPropertyKey(arg) { var key = _toPrimitive(arg, \"string\"); return typeof key === \"symbol\" ? key : String(key); }\n\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); }\n\nimport { useCallback, useRef, useState } from 'react';\nimport * as Utils from './utils';\n\nfunction useUncontrolledProp(propValue, defaultValue, handler) {\n var wasPropRef = useRef(propValue !== undefined);\n\n var _useState = useState(defaultValue),\n stateValue = _useState[0],\n setState = _useState[1];\n\n var isProp = propValue !== undefined;\n var wasProp = wasPropRef.current;\n wasPropRef.current = isProp;\n /**\n * If a prop switches from controlled to Uncontrolled\n * reset its value to the defaultValue\n */\n\n if (!isProp && wasProp && stateValue !== defaultValue) {\n setState(defaultValue);\n }\n\n return [isProp ? propValue : stateValue, useCallback(function (value) {\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n if (handler) handler.apply(void 0, [value].concat(args));\n setState(value);\n }, [handler])];\n}\n\nexport { useUncontrolledProp };\nexport default function useUncontrolled(props, config) {\n return Object.keys(config).reduce(function (result, fieldName) {\n var _extends2;\n\n var _ref = result,\n defaultValue = _ref[Utils.defaultKey(fieldName)],\n propsValue = _ref[fieldName],\n rest = _objectWithoutPropertiesLoose(_ref, [Utils.defaultKey(fieldName), fieldName].map(_toPropertyKey));\n\n var handlerName = config[fieldName];\n\n var _useUncontrolledProp = useUncontrolledProp(propsValue, defaultValue, props[handlerName]),\n value = _useUncontrolledProp[0],\n handler = _useUncontrolledProp[1];\n\n return _extends({}, rest, (_extends2 = {}, _extends2[fieldName] = value, _extends2[handlerName] = handler, _extends2));\n }, props);\n}","\"use client\";\n\nimport * as React from 'react';\nimport classNames from 'classnames';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst CarouselCaption = /*#__PURE__*/React.forwardRef(({\n className,\n bsPrefix,\n as: Component = 'div',\n ...props\n}, ref) => {\n bsPrefix = useBootstrapPrefix(bsPrefix, 'carousel-caption');\n return /*#__PURE__*/_jsx(Component, {\n ref: ref,\n className: classNames(className, bsPrefix),\n ...props\n });\n});\nCarouselCaption.displayName = 'CarouselCaption';\nexport default CarouselCaption;","\"use client\";\n\nimport classNames from 'classnames';\nimport * as React from 'react';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport { jsx as _jsx } from \"react/jsx-runtime\";\nconst CarouselItem = /*#__PURE__*/React.forwardRef(({\n // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n as: Component = 'div',\n bsPrefix,\n className,\n ...props\n}, ref) => {\n const finalClassName = classNames(className, useBootstrapPrefix(bsPrefix, 'carousel-item'));\n return /*#__PURE__*/_jsx(Component, {\n ref: ref,\n ...props,\n className: finalClassName\n });\n});\nCarouselItem.displayName = 'CarouselItem';\nexport default CarouselItem;","import ownerDocument from './ownerDocument';\n/**\n * Returns the owner window of a given element.\n * \n * @param node the element\n */\n\nexport default function ownerWindow(node) {\n var doc = ownerDocument(node);\n return doc && doc.defaultView || window;\n}","/**\n * Returns the owner document of a given element.\n * \n * @param node the element\n */\nexport default function ownerDocument(node) {\n return node && node.ownerDocument || document;\n}","var rUpper = /([A-Z])/g;\nexport default function hyphenate(string) {\n return string.replace(rUpper, '-$1').toLowerCase();\n}","/**\n * Copyright 2013-2014, Facebook, Inc.\n * All rights reserved.\n * https://github.com/facebook/react/blob/2aeb8a2a6beb00617a4217f7f8284924fa2ad819/src/vendor/core/hyphenateStyleName.js\n */\nimport hyphenate from './hyphenate';\nvar msPattern = /^ms-/;\nexport default function hyphenateStyleName(string) {\n return hyphenate(string).replace(msPattern, '-ms-');\n}","var supportedTransforms = /^((translate|rotate|scale)(X|Y|Z|3d)?|matrix(3d)?|perspective|skew(X|Y)?)$/i;\nexport default function isTransform(value) {\n return !!(value && supportedTransforms.test(value));\n}","import getComputedStyle from './getComputedStyle';\nimport hyphenate from './hyphenateStyle';\nimport isTransform from './isTransform';\n\nfunction style(node, property) {\n var css = '';\n var transforms = '';\n\n if (typeof property === 'string') {\n return node.style.getPropertyValue(hyphenate(property)) || getComputedStyle(node).getPropertyValue(hyphenate(property));\n }\n\n Object.keys(property).forEach(function (key) {\n var value = property[key];\n\n if (!value && value !== 0) {\n node.style.removeProperty(hyphenate(key));\n } else if (isTransform(key)) {\n transforms += key + \"(\" + value + \") \";\n } else {\n css += hyphenate(key) + \": \" + value + \";\";\n }\n });\n\n if (transforms) {\n css += \"transform: \" + transforms + \";\";\n }\n\n node.style.cssText += \";\" + css;\n}\n\nexport default style;","import ownerWindow from './ownerWindow';\n/**\n * Returns one or all computed style properties of an element.\n * \n * @param node the element\n * @param psuedoElement the style property\n */\n\nexport default function getComputedStyle(node, psuedoElement) {\n return ownerWindow(node).getComputedStyle(node, psuedoElement);\n}","export default !!(typeof window !== 'undefined' && window.document && window.document.createElement);","/* eslint-disable no-return-assign */\nimport canUseDOM from './canUseDOM';\nexport var optionsSupported = false;\nexport var onceSupported = false;\n\ntry {\n var options = {\n get passive() {\n return optionsSupported = true;\n },\n\n get once() {\n // eslint-disable-next-line no-multi-assign\n return onceSupported = optionsSupported = true;\n }\n\n };\n\n if (canUseDOM) {\n window.addEventListener('test', options, options);\n window.removeEventListener('test', options, true);\n }\n} catch (e) {\n /* */\n}\n\n/**\n * An `addEventListener` ponyfill, supports the `once` option\n * \n * @param node the element\n * @param eventName the event name\n * @param handle the handler\n * @param options event options\n */\nfunction addEventListener(node, eventName, handler, options) {\n if (options && typeof options !== 'boolean' && !onceSupported) {\n var once = options.once,\n capture = options.capture;\n var wrappedHandler = handler;\n\n if (!onceSupported && once) {\n wrappedHandler = handler.__once || function onceHandler(event) {\n this.removeEventListener(eventName, onceHandler, capture);\n handler.call(this, event);\n };\n\n handler.__once = wrappedHandler;\n }\n\n node.addEventListener(eventName, wrappedHandler, optionsSupported ? options : capture);\n }\n\n node.addEventListener(eventName, handler, options);\n}\n\nexport default addEventListener;","/**\n * A `removeEventListener` ponyfill\n * \n * @param node the element\n * @param eventName the event name\n * @param handle the handler\n * @param options event options\n */\nfunction removeEventListener(node, eventName, handler, options) {\n var capture = options && typeof options !== 'boolean' ? options.capture : options;\n node.removeEventListener(eventName, handler, capture);\n\n if (handler.__once) {\n node.removeEventListener(eventName, handler.__once, capture);\n }\n}\n\nexport default removeEventListener;","import addEventListener from './addEventListener';\nimport removeEventListener from './removeEventListener';\n\nfunction listen(node, eventName, handler, options) {\n addEventListener(node, eventName, handler, options);\n return function () {\n removeEventListener(node, eventName, handler, options);\n };\n}\n\nexport default listen;","import css from './css';\nimport listen from './listen';\nimport triggerEvent from './triggerEvent';\n\nfunction parseDuration(node) {\n var str = css(node, 'transitionDuration') || '';\n var mult = str.indexOf('ms') === -1 ? 1000 : 1;\n return parseFloat(str) * mult;\n}\n\nfunction emulateTransitionEnd(element, duration, padding) {\n if (padding === void 0) {\n padding = 5;\n }\n\n var called = false;\n var handle = setTimeout(function () {\n if (!called) triggerEvent(element, 'transitionend', true);\n }, duration + padding);\n var remove = listen(element, 'transitionend', function () {\n called = true;\n }, {\n once: true\n });\n return function () {\n clearTimeout(handle);\n remove();\n };\n}\n\nexport default function transitionEnd(element, handler, duration, padding) {\n if (duration == null) duration = parseDuration(element) || 0;\n var removeEmulate = emulateTransitionEnd(element, duration, padding);\n var remove = listen(element, 'transitionend', handler);\n return function () {\n removeEmulate();\n remove();\n };\n}","/**\n * Triggers an event on a given element.\n * \n * @param node the element\n * @param eventName the event name to trigger\n * @param bubbles whether the event should bubble up\n * @param cancelable whether the event should be cancelable\n */\nexport default function triggerEvent(node, eventName, bubbles, cancelable) {\n if (bubbles === void 0) {\n bubbles = false;\n }\n\n if (cancelable === void 0) {\n cancelable = true;\n }\n\n if (node) {\n var event = document.createEvent('HTMLEvents');\n event.initEvent(eventName, bubbles, cancelable);\n node.dispatchEvent(event);\n }\n}","import css from 'dom-helpers/css';\nimport transitionEnd from 'dom-helpers/transitionEnd';\nfunction parseDuration(node, property) {\n const str = css(node, property) || '';\n const mult = str.indexOf('ms') === -1 ? 1000 : 1;\n return parseFloat(str) * mult;\n}\nexport default function transitionEndListener(element, handler) {\n const duration = parseDuration(element, 'transitionDuration');\n const delay = parseDuration(element, 'transitionDelay');\n const remove = transitionEnd(element, e => {\n if (e.target === element) {\n remove();\n handler(e);\n }\n }, duration + delay);\n}","export default {\n disabled: false\n};","import React from 'react';\nexport default React.createContext(null);","export var forceReflow = function forceReflow(node) {\n return node.scrollTop;\n};","import _objectWithoutPropertiesLoose from \"@babel/runtime/helpers/esm/objectWithoutPropertiesLoose\";\nimport _inheritsLoose from \"@babel/runtime/helpers/esm/inheritsLoose\";\nimport PropTypes from 'prop-types';\nimport React from 'react';\nimport ReactDOM from 'react-dom';\nimport config from './config';\nimport { timeoutsShape } from './utils/PropTypes';\nimport TransitionGroupContext from './TransitionGroupContext';\nimport { forceReflow } from './utils/reflow';\nexport var UNMOUNTED = 'unmounted';\nexport var EXITED = 'exited';\nexport var ENTERING = 'entering';\nexport var ENTERED = 'entered';\nexport var EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * ---\n *\n * **Note**: `Transition` is a platform-agnostic base component. If you're using\n * transitions in CSS, you'll probably want to use\n * [`CSSTransition`](https://reactcommunity.org/react-transition-group/css-transition)\n * instead. It inherits all the features of `Transition`, but contains\n * additional features necessary to play nice with CSS transitions (hence the\n * name of the component).\n *\n * ---\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the\n * components. It's up to you to give meaning and effect to those states. For\n * example we can add styles to a component when it enters or exits:\n *\n * ```jsx\n * import { Transition } from 'react-transition-group';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n * transition: `opacity ${duration}ms ease-in-out`,\n * opacity: 0,\n * }\n *\n * const transitionStyles = {\n * entering: { opacity: 1 },\n * entered: { opacity: 1 },\n * exiting: { opacity: 0 },\n * exited: { opacity: 0 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n * \n * {state => (\n *
\n * I'm a fade Transition!\n *
\n * )}\n *
\n * );\n * ```\n *\n * There are 4 main states a Transition can be in:\n * - `'entering'`\n * - `'entered'`\n * - `'exiting'`\n * - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component\n * begins the \"Enter\" stage. During this stage, the component will shift from\n * its current transition state, to `'entering'` for the duration of the\n * transition and then to the `'entered'` stage once it's complete. Let's take\n * the following example (we'll use the\n * [useState](https://reactjs.org/docs/hooks-reference.html#usestate) hook):\n *\n * ```jsx\n * function App() {\n * const [inProp, setInProp] = useState(false);\n * return (\n *
\n * \n * {state => (\n * // ...\n * )}\n * \n * \n *
\n * );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state\n * and stay there for 500ms (the value of `timeout`) before it finally switches\n * to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from\n * `'exiting'` to `'exited'`.\n */\n\nvar Transition = /*#__PURE__*/function (_React$Component) {\n _inheritsLoose(Transition, _React$Component);\n\n function Transition(props, context) {\n var _this;\n\n _this = _React$Component.call(this, props, context) || this;\n var parentGroup = context; // In the context of a TransitionGroup all enters are really appears\n\n var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n var initialStatus;\n _this.appearStatus = null;\n\n if (props.in) {\n if (appear) {\n initialStatus = EXITED;\n _this.appearStatus = ENTERING;\n } else {\n initialStatus = ENTERED;\n }\n } else {\n if (props.unmountOnExit || props.mountOnEnter) {\n initialStatus = UNMOUNTED;\n } else {\n initialStatus = EXITED;\n }\n }\n\n _this.state = {\n status: initialStatus\n };\n _this.nextCallback = null;\n return _this;\n }\n\n Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n var nextIn = _ref.in;\n\n if (nextIn && prevState.status === UNMOUNTED) {\n return {\n status: EXITED\n };\n }\n\n return null;\n } // getSnapshotBeforeUpdate(prevProps) {\n // let nextStatus = null\n // if (prevProps !== this.props) {\n // const { status } = this.state\n // if (this.props.in) {\n // if (status !== ENTERING && status !== ENTERED) {\n // nextStatus = ENTERING\n // }\n // } else {\n // if (status === ENTERING || status === ENTERED) {\n // nextStatus = EXITING\n // }\n // }\n // }\n // return { nextStatus }\n // }\n ;\n\n var _proto = Transition.prototype;\n\n _proto.componentDidMount = function componentDidMount() {\n this.updateStatus(true, this.appearStatus);\n };\n\n _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n var nextStatus = null;\n\n if (prevProps !== this.props) {\n var status = this.state.status;\n\n if (this.props.in) {\n if (status !== ENTERING && status !== ENTERED) {\n nextStatus = ENTERING;\n }\n } else {\n if (status === ENTERING || status === ENTERED) {\n nextStatus = EXITING;\n }\n }\n }\n\n this.updateStatus(false, nextStatus);\n };\n\n _proto.componentWillUnmount = function componentWillUnmount() {\n this.cancelNextCallback();\n };\n\n _proto.getTimeouts = function getTimeouts() {\n var timeout = this.props.timeout;\n var exit, enter, appear;\n exit = enter = appear = timeout;\n\n if (timeout != null && typeof timeout !== 'number') {\n exit = timeout.exit;\n enter = timeout.enter; // TODO: remove fallback for next major\n\n appear = timeout.appear !== undefined ? timeout.appear : enter;\n }\n\n return {\n exit: exit,\n enter: enter,\n appear: appear\n };\n };\n\n _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n if (mounting === void 0) {\n mounting = false;\n }\n\n if (nextStatus !== null) {\n // nextStatus will always be ENTERING or EXITING.\n this.cancelNextCallback();\n\n if (nextStatus === ENTERING) {\n if (this.props.unmountOnExit || this.props.mountOnEnter) {\n var node = this.props.nodeRef ? this.props.nodeRef.current : ReactDOM.findDOMNode(this); // https://github.com/reactjs/react-transition-group/pull/749\n // With unmountOnExit or mountOnEnter, the enter animation should happen at the transition between `exited` and `entering`.\n // To make the animation happen, we have to separate each rendering and avoid being processed as batched.\n\n if (node) forceReflow(node);\n }\n\n this.performEnter(mounting);\n } else {\n this.performExit();\n }\n } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n this.setState({\n status: UNMOUNTED\n });\n }\n };\n\n _proto.performEnter = function performEnter(mounting) {\n var _this2 = this;\n\n var enter = this.props.enter;\n var appearing = this.context ? this.context.isMounting : mounting;\n\n var _ref2 = this.props.nodeRef ? [appearing] : [ReactDOM.findDOMNode(this), appearing],\n maybeNode = _ref2[0],\n maybeAppearing = _ref2[1];\n\n var timeouts = this.getTimeouts();\n var enterTimeout = appearing ? timeouts.appear : timeouts.enter; // no enter animation skip right to ENTERED\n // if we are mounting and running this it means appear _must_ be set\n\n if (!mounting && !enter || config.disabled) {\n this.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(maybeNode);\n });\n return;\n }\n\n this.props.onEnter(maybeNode, maybeAppearing);\n this.safeSetState({\n status: ENTERING\n }, function () {\n _this2.props.onEntering(maybeNode, maybeAppearing);\n\n _this2.onTransitionEnd(enterTimeout, function () {\n _this2.safeSetState({\n status: ENTERED\n }, function () {\n _this2.props.onEntered(maybeNode, maybeAppearing);\n });\n });\n });\n };\n\n _proto.performExit = function performExit() {\n var _this3 = this;\n\n var exit = this.props.exit;\n var timeouts = this.getTimeouts();\n var maybeNode = this.props.nodeRef ? undefined : ReactDOM.findDOMNode(this); // no exit animation skip right to EXITED\n\n if (!exit || config.disabled) {\n this.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(maybeNode);\n });\n return;\n }\n\n this.props.onExit(maybeNode);\n this.safeSetState({\n status: EXITING\n }, function () {\n _this3.props.onExiting(maybeNode);\n\n _this3.onTransitionEnd(timeouts.exit, function () {\n _this3.safeSetState({\n status: EXITED\n }, function () {\n _this3.props.onExited(maybeNode);\n });\n });\n });\n };\n\n _proto.cancelNextCallback = function cancelNextCallback() {\n if (this.nextCallback !== null) {\n this.nextCallback.cancel();\n this.nextCallback = null;\n }\n };\n\n _proto.safeSetState = function safeSetState(nextState, callback) {\n // This shouldn't be necessary, but there are weird race conditions with\n // setState callbacks and unmounting in testing, so always make sure that\n // we can cancel any pending setState callbacks after we unmount.\n callback = this.setNextCallback(callback);\n this.setState(nextState, callback);\n };\n\n _proto.setNextCallback = function setNextCallback(callback) {\n var _this4 = this;\n\n var active = true;\n\n this.nextCallback = function (event) {\n if (active) {\n active = false;\n _this4.nextCallback = null;\n callback(event);\n }\n };\n\n this.nextCallback.cancel = function () {\n active = false;\n };\n\n return this.nextCallback;\n };\n\n _proto.onTransitionEnd = function onTransitionEnd(timeout, handler) {\n this.setNextCallback(handler);\n var node = this.props.nodeRef ? this.props.nodeRef.current : ReactDOM.findDOMNode(this);\n var doesNotHaveTimeoutOrListener = timeout == null && !this.props.addEndListener;\n\n if (!node || doesNotHaveTimeoutOrListener) {\n setTimeout(this.nextCallback, 0);\n return;\n }\n\n if (this.props.addEndListener) {\n var _ref3 = this.props.nodeRef ? [this.nextCallback] : [node, this.nextCallback],\n maybeNode = _ref3[0],\n maybeNextCallback = _ref3[1];\n\n this.props.addEndListener(maybeNode, maybeNextCallback);\n }\n\n if (timeout != null) {\n setTimeout(this.nextCallback, timeout);\n }\n };\n\n _proto.render = function render() {\n var status = this.state.status;\n\n if (status === UNMOUNTED) {\n return null;\n }\n\n var _this$props = this.props,\n children = _this$props.children,\n _in = _this$props.in,\n _mountOnEnter = _this$props.mountOnEnter,\n _unmountOnExit = _this$props.unmountOnExit,\n _appear = _this$props.appear,\n _enter = _this$props.enter,\n _exit = _this$props.exit,\n _timeout = _this$props.timeout,\n _addEndListener = _this$props.addEndListener,\n _onEnter = _this$props.onEnter,\n _onEntering = _this$props.onEntering,\n _onEntered = _this$props.onEntered,\n _onExit = _this$props.onExit,\n _onExiting = _this$props.onExiting,\n _onExited = _this$props.onExited,\n _nodeRef = _this$props.nodeRef,\n childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"in\", \"mountOnEnter\", \"unmountOnExit\", \"appear\", \"enter\", \"exit\", \"timeout\", \"addEndListener\", \"onEnter\", \"onEntering\", \"onEntered\", \"onExit\", \"onExiting\", \"onExited\", \"nodeRef\"]);\n\n return (\n /*#__PURE__*/\n // allows for nested Transitions\n React.createElement(TransitionGroupContext.Provider, {\n value: null\n }, typeof children === 'function' ? children(status, childProps) : React.cloneElement(React.Children.only(children), childProps))\n );\n };\n\n return Transition;\n}(React.Component);\n\nTransition.contextType = TransitionGroupContext;\nTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n /**\n * A React reference to DOM element that need to transition:\n * https://stackoverflow.com/a/51127130/4671932\n *\n * - When `nodeRef` prop is used, `node` is not passed to callback functions\n * (e.g. `onEnter`) because user already has direct access to the node.\n * - When changing `key` prop of `Transition` in a `TransitionGroup` a new\n * `nodeRef` need to be provided to `Transition` with changed `key` prop\n * (see\n * [test/CSSTransition-test.js](https://github.com/reactjs/react-transition-group/blob/13435f897b3ab71f6e19d724f145596f5910581c/test/CSSTransition-test.js#L362-L437)).\n */\n nodeRef: PropTypes.shape({\n current: typeof Element === 'undefined' ? PropTypes.any : function (propValue, key, componentName, location, propFullName, secret) {\n var value = propValue[key];\n return PropTypes.instanceOf(value && 'ownerDocument' in value ? value.ownerDocument.defaultView.Element : Element)(propValue, key, componentName, location, propFullName, secret);\n }\n }),\n\n /**\n * A `function` child can be used instead of a React element. This function is\n * called with the current transition status (`'entering'`, `'entered'`,\n * `'exiting'`, `'exited'`), which can be used to apply context\n * specific props to a component.\n *\n * ```jsx\n * \n * {state => (\n * \n * )}\n * \n * ```\n */\n children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,\n\n /**\n * Show the component; triggers the enter or exit states\n */\n in: PropTypes.bool,\n\n /**\n * By default the child component is mounted immediately along with\n * the parent `Transition` component. If you want to \"lazy mount\" the component on the\n * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay\n * mounted, even on \"exited\", unless you also specify `unmountOnExit`.\n */\n mountOnEnter: PropTypes.bool,\n\n /**\n * By default the child component stays mounted after it reaches the `'exited'` state.\n * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.\n */\n unmountOnExit: PropTypes.bool,\n\n /**\n * By default the child component does not perform the enter transition when\n * it first mounts, regardless of the value of `in`. If you want this\n * behavior, set both `appear` and `in` to `true`.\n *\n * > **Note**: there are no special appear states like `appearing`/`appeared`, this prop\n * > only adds an additional enter transition. However, in the\n * > `` component that first enter transition does result in\n * > additional `.appear-*` classes, that way you can choose to style it\n * > differently.\n */\n appear: PropTypes.bool,\n\n /**\n * Enable or disable enter transitions.\n */\n enter: PropTypes.bool,\n\n /**\n * Enable or disable exit transitions.\n */\n exit: PropTypes.bool,\n\n /**\n * The duration of the transition, in milliseconds.\n * Required unless `addEndListener` is provided.\n *\n * You may specify a single timeout for all transitions:\n *\n * ```jsx\n * timeout={500}\n * ```\n *\n * or individually:\n *\n * ```jsx\n * timeout={{\n * appear: 500,\n * enter: 300,\n * exit: 500,\n * }}\n * ```\n *\n * - `appear` defaults to the value of `enter`\n * - `enter` defaults to `0`\n * - `exit` defaults to `0`\n *\n * @type {number | { enter?: number, exit?: number, appear?: number }}\n */\n timeout: function timeout(props) {\n var pt = timeoutsShape;\n if (!props.addEndListener) pt = pt.isRequired;\n\n for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n args[_key - 1] = arguments[_key];\n }\n\n return pt.apply(void 0, [props].concat(args));\n },\n\n /**\n * Add a custom transition end trigger. Called with the transitioning\n * DOM node and a `done` callback. Allows for more fine grained transition end\n * logic. Timeouts are still used as a fallback if provided.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * ```jsx\n * addEndListener={(node, done) => {\n * // use the css transitionend event to mark the finish of a transition\n * node.addEventListener('transitionend', done, false);\n * }}\n * ```\n */\n addEndListener: PropTypes.func,\n\n /**\n * Callback fired before the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEnter: PropTypes.func,\n\n /**\n * Callback fired after the \"entering\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement, isAppearing: bool)\n */\n onEntering: PropTypes.func,\n\n /**\n * Callback fired after the \"entered\" status is applied. An extra parameter\n * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement, isAppearing: bool) -> void\n */\n onEntered: PropTypes.func,\n\n /**\n * Callback fired before the \"exiting\" status is applied.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExit: PropTypes.func,\n\n /**\n * Callback fired after the \"exiting\" status is applied.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed.\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExiting: PropTypes.func,\n\n /**\n * Callback fired after the \"exited\" status is applied.\n *\n * **Note**: when `nodeRef` prop is passed, `node` is not passed\n *\n * @type Function(node: HtmlElement) -> void\n */\n onExited: PropTypes.func\n} : {}; // Name the function so it is clearer in the documentation\n\nfunction noop() {}\n\nTransition.defaultProps = {\n in: false,\n mountOnEnter: false,\n unmountOnExit: false,\n appear: false,\n enter: true,\n exit: true,\n onEnter: noop,\n onEntering: noop,\n onEntered: noop,\n onExit: noop,\n onExiting: noop,\n onExited: noop\n};\nTransition.UNMOUNTED = UNMOUNTED;\nTransition.EXITED = EXITED;\nTransition.ENTERING = ENTERING;\nTransition.ENTERED = ENTERED;\nTransition.EXITING = EXITING;\nexport default Transition;","import { useMemo } from 'react';\nconst toFnRef = ref => !ref || typeof ref === 'function' ? ref : value => {\n ref.current = value;\n};\nexport function mergeRefs(refA, refB) {\n const a = toFnRef(refA);\n const b = toFnRef(refB);\n return value => {\n if (a) a(value);\n if (b) b(value);\n };\n}\n\n/**\n * Create and returns a single callback ref composed from two other Refs.\n *\n * ```tsx\n * const Button = React.forwardRef((props, ref) => {\n * const [element, attachRef] = useCallbackRef();\n * const mergedRef = useMergedRefs(ref, attachRef);\n *\n * return
+ + + + }); + + return ( +
+

+ +
+ + this.setState({ value: e.target.value })} type="text"/> + + +

GitHub Projects for username: {this.props.match.params.id}

+ + + + + + + + + + + {repoList} +
RepositoryDescriptionApp URLTopicsActions
+
+
+ ); + } +} + +export default RepoDetails; diff --git a/frontend/src/components/RepoIssues.js b/frontend/src/components/RepoIssues.js new file mode 100644 index 0000000..627043c --- /dev/null +++ b/frontend/src/components/RepoIssues.js @@ -0,0 +1,79 @@ +import React, { Component } from 'react'; +import { Button, Container, InputGroup, Table } from 'reactstrap'; +import '.././App.css'; +import Form from 'react-bootstrap/Form'; +import AppNavbar from '.././AppNavbar'; + +class RepoIssues extends Component { + + constructor(props) { + super(props); + this.state = {repoIssueList: [], isLoading: true, value: ''}; + + this.handleChange = this.handleChange.bind(this); + this.onSubmit = this.onSubmit.bind(this); + } + + handleChange(event) { + const {issues, isL, value} = this.state; + this.setState({repoIssueList: issues, isLoading: isL, value: event.target.value}); + } + + onSubmit(event){ + let repo = this.state.value; + let id = this.props.match.params.id; + this.props.history.push(`/issues/${id}/${repo}`, { + id: id, + repo: repo + }); + } + + async componentDidMount() { + const response = await fetch(`/get-repo-issue/${this.props.match.params.id}/${this.props.match.params.repo}/`); + const body = await response.json(); + console.log(body) + this.setState({repoIssueList: body, isLoading: false}); + } + + render() { + const {repoIssueList, isLoading} = this.state; + if (isLoading) { + return

Loading...

; + } + const repoList = repoIssueList.map(issue => { + return + {issue.number} + {issue.title} + {issue.body} + + }); + return ( +
+

+ +
+ + this.setState({ value: e.target.value })} /> + + +

Issues for project {this.props.match.params.repo} and account {this.props.match.params.id}

+ + + + + + + + + {repoList} +
Issue No.TitleDescription
+
+
+ ); + } +} + +export default RepoIssues; diff --git a/frontend/src/components/img/darkblue-bg.png b/frontend/src/components/img/darkblue-bg.png new file mode 100644 index 0000000..f2398fa Binary files /dev/null and b/frontend/src/components/img/darkblue-bg.png differ diff --git a/frontend/src/components/img/red-bg.png b/frontend/src/components/img/red-bg.png new file mode 100644 index 0000000..e6922d6 Binary files /dev/null and b/frontend/src/components/img/red-bg.png differ diff --git a/frontend/src/components/img/robot-logo.png b/frontend/src/components/img/robot-logo.png new file mode 100644 index 0000000..48e2a2f Binary files /dev/null and b/frontend/src/components/img/robot-logo.png differ diff --git a/frontend/src/components/img/teal-bg.png b/frontend/src/components/img/teal-bg.png new file mode 100644 index 0000000..45be336 Binary files /dev/null and b/frontend/src/components/img/teal-bg.png differ diff --git a/frontend/src/index.css b/frontend/src/index.css new file mode 100644 index 0000000..ec2585e --- /dev/null +++ b/frontend/src/index.css @@ -0,0 +1,13 @@ +body { + margin: 0; + font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', + 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue', + sans-serif; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; +} + +code { + font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New', + monospace; +} diff --git a/frontend/src/index.js b/frontend/src/index.js new file mode 100644 index 0000000..42652e9 --- /dev/null +++ b/frontend/src/index.js @@ -0,0 +1,15 @@ +import React from 'react'; +import ReactDOM from 'react-dom/client'; +import reportWebVitals from './reportWebVitals'; +import 'bootstrap/dist/css/bootstrap.min.css'; +import './index.css'; +import App from './App'; + +const root = ReactDOM.createRoot(document.getElementById('root')); +root.render( + + + +); + +reportWebVitals(); diff --git a/frontend/src/reportWebVitals.js b/frontend/src/reportWebVitals.js new file mode 100644 index 0000000..5253d3a --- /dev/null +++ b/frontend/src/reportWebVitals.js @@ -0,0 +1,13 @@ +const reportWebVitals = onPerfEntry => { + if (onPerfEntry && onPerfEntry instanceof Function) { + import('web-vitals').then(({ getCLS, getFID, getFCP, getLCP, getTTFB }) => { + getCLS(onPerfEntry); + getFID(onPerfEntry); + getFCP(onPerfEntry); + getLCP(onPerfEntry); + getTTFB(onPerfEntry); + }); + } +}; + +export default reportWebVitals; diff --git a/frontend/src/setupTests.js b/frontend/src/setupTests.js new file mode 100644 index 0000000..7b0828b --- /dev/null +++ b/frontend/src/setupTests.js @@ -0,0 +1 @@ +import '@testing-library/jest-dom'; diff --git a/pom.xml b/pom.xml index e38e025..747f367 100644 --- a/pom.xml +++ b/pom.xml @@ -5,7 +5,7 @@ conorheffron ironoc - 4.4.5 + 5.1.1 war @@ -23,7 +23,7 @@ org.springframework.boot spring-boot-starter-parent 3.3.4 - + @@ -31,6 +31,9 @@ UTF-8 21 3.3.4 + 1.15.1 + v20.16.0 + v1.22.22 @@ -112,12 +115,6 @@ - - junit - junit - 4.13.2 - test - org.projectlombok @@ -197,6 +194,78 @@ + + org.apache.maven.plugins + maven-resources-plugin + 3.1.0 + + + copy-resources + process-classes + + copy-resources + + + ${basedir}/target/classes/static + + + frontend/build + + + + + + + + com.github.eirslett + frontend-maven-plugin + ${frontend-maven-plugin.version} + + frontend + + + + install node + + install-node-and-yarn + + + ${node.version} + ${yarn.version} + + + + yarn install + + yarn + + generate-resources + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/main/java/com/ironoc/portfolio/client/Client.java b/src/main/java/com/ironoc/portfolio/client/Client.java index d3a9c8e..b1d21eb 100644 --- a/src/main/java/com/ironoc/portfolio/client/Client.java +++ b/src/main/java/com/ironoc/portfolio/client/Client.java @@ -3,10 +3,13 @@ import javax.net.ssl.HttpsURLConnection; import java.io.IOException; import java.io.InputStream; +import java.util.List; public interface Client { - HttpsURLConnection createConn(String url) throws IOException; + List callGitHubApi(String apiUri, String uri, Class type, String httpMethod); + + HttpsURLConnection createConn(String url, String baseUrl, String httpMethod) throws IOException; InputStream readInputStream(HttpsURLConnection conn) throws IOException; diff --git a/src/main/java/com/ironoc/portfolio/client/GitClient.java b/src/main/java/com/ironoc/portfolio/client/GitClient.java index 4813cbf..1ec506e 100644 --- a/src/main/java/com/ironoc/portfolio/client/GitClient.java +++ b/src/main/java/com/ironoc/portfolio/client/GitClient.java @@ -1,22 +1,28 @@ package com.ironoc.portfolio.client; +import com.fasterxml.jackson.databind.ObjectMapper; +import com.fasterxml.jackson.databind.type.CollectionType; import com.ironoc.portfolio.aws.SecretManager; import com.ironoc.portfolio.config.PropertyConfigI; +import com.ironoc.portfolio.logger.AbstractLogger; import com.ironoc.portfolio.utils.UrlUtils; import io.micrometer.common.util.StringUtils; import lombok.extern.slf4j.Slf4j; -import org.springframework.http.HttpMethod; +import org.apache.commons.io.IOUtils; import org.springframework.stereotype.Component; -import org.springframework.web.util.UriComponentsBuilder; import javax.net.ssl.HttpsURLConnection; import java.io.IOException; import java.io.InputStream; import java.net.URL; +import java.nio.charset.StandardCharsets; +import java.util.ArrayList; +import java.util.Collections; +import java.util.List; @Component @Slf4j -public class GitClient implements Client { +public class GitClient extends AbstractLogger implements Client { private final PropertyConfigI propertyConfig; @@ -24,17 +30,53 @@ public class GitClient implements Client { private final UrlUtils urlUtils; + private final ObjectMapper objectMapper; + public GitClient(PropertyConfigI propertyConfig, SecretManager secretManager, - UrlUtils urlUtils) { + UrlUtils urlUtils, + ObjectMapper objectMapper) { this.propertyConfig = propertyConfig; this.secretManager = secretManager; this.urlUtils = urlUtils; + this.objectMapper = objectMapper; } @Override - public HttpsURLConnection createConn(String url) throws IOException { - String baseUrl = propertyConfig.getGitApiEndpoint(); + public List callGitHubApi(String apiUri, String uri, Class type, String httpMethod) { + info("Triggering GET request: url={}", apiUri); + List dtos = new ArrayList<>(); + InputStream inputStream = null; + try { + HttpsURLConnection conn = this.createConn(apiUri, uri, httpMethod); + if (conn == null) { + error("Failed to created connection"); + return Collections.emptyList(); + } + inputStream = this.readInputStream(conn); + String jsonResponse = convertInputStreamToString(inputStream); + CollectionType listType = objectMapper.getTypeFactory() + .constructCollectionType(ArrayList.class, type); + dtos = objectMapper.readValue(jsonResponse, listType); + debug("List.of(DTO)={}", dtos); + } catch(Exception ex) { + error("Unexpected error occurred while retrieving data.", ex); + } finally { + try { + if (inputStream != null) { + this.closeConn(inputStream); + } else { + warn("Input stream already closed."); + } + } catch (IOException ex) { + error("Unexpected error occurred while closing input stream.", ex); + } + } + return dtos; + } + + @Override + public HttpsURLConnection createConn(String url, String baseUrl, String httpMethod) throws IOException { URL urlBase = new URL(baseUrl); String base = urlBase.getProtocol() + "://" + urlBase.getHost(); if (!urlUtils.isValidURL(url) || !url.startsWith(base)) { @@ -49,7 +91,7 @@ public HttpsURLConnection createConn(String url) throws IOException { } else { conn.setRequestProperty("Authorization", token); } - conn.setRequestMethod(HttpMethod.GET.name()); + conn.setRequestMethod(httpMethod); conn.setFollowRedirects(propertyConfig.getGitFollowRedirects()); conn.setConnectTimeout(propertyConfig.getGitTimeoutConnect()); conn.setReadTimeout(propertyConfig.getGitTimeoutRead()); @@ -66,4 +108,8 @@ public InputStream readInputStream(HttpsURLConnection conn) throws IOException { public void closeConn(InputStream inputStream) throws IOException { inputStream.close(); } + + String convertInputStreamToString(InputStream inputStream) throws Exception { + return IOUtils.toString(inputStream, StandardCharsets.UTF_8); + } } diff --git a/src/main/java/com/ironoc/portfolio/config/IronocConfiguration.java b/src/main/java/com/ironoc/portfolio/config/IronocConfiguration.java index 2e33ded..1b9cfcb 100644 --- a/src/main/java/com/ironoc/portfolio/config/IronocConfiguration.java +++ b/src/main/java/com/ironoc/portfolio/config/IronocConfiguration.java @@ -8,42 +8,33 @@ import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.annotation.EnableAsync; import org.springframework.scheduling.annotation.EnableScheduling; -import org.springframework.web.servlet.ViewResolver; import org.springframework.web.servlet.config.annotation.DefaultServletHandlerConfigurer; -import org.springframework.web.servlet.config.annotation.EnableWebMvc; import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; -import org.springframework.web.servlet.view.InternalResourceViewResolver; + +import java.util.Arrays; +import java.util.List; @Configuration -@EnableWebMvc @EnableAsync @EnableScheduling @ComponentScan(basePackages = { "com.ironoc.portfolio" }) public class IronocConfiguration implements WebMvcConfigurer { - protected static final String RESOURCES_HANDLER = "/resources/**"; - protected static final String FAV_ICON = "/favicon.ico"; - protected static final String SITE_MAP = "/sitemap.xml"; - protected static final String ROBOTS_TEXT = "/robots.txt"; - protected static final String STATIC_LOC = "/static/"; - protected static final String IMAGES_LOC = STATIC_LOC + "imgs/"; - protected static final String STATIC_CONF_LOC = STATIC_LOC + "config/"; - - @Bean - public ViewResolver getViewResolver() { - InternalResourceViewResolver resolver = new InternalResourceViewResolver(); - resolver.setPrefix("/templates/"); - resolver.setSuffix(".html"); - return resolver; - } - @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { - registry.addResourceHandler(RESOURCES_HANDLER).addResourceLocations(STATIC_LOC); - registry.addResourceHandler(FAV_ICON).addResourceLocations(IMAGES_LOC); - registry.addResourceHandler(SITE_MAP).addResourceLocations(STATIC_CONF_LOC); - registry.addResourceHandler(ROBOTS_TEXT).addResourceLocations(STATIC_CONF_LOC); + List ignorePaths = Arrays.asList("api"); + List handledExtensions = Arrays.asList( + "html", "js", "json", + "csv", "css", + "svg", "eot", "ttf", "woff", + "appcache", + "png", "jpg", "jpeg", + "gif", "ico"); + registry.addResourceHandler("/**") + .addResourceLocations("classpath:/static/") + .resourceChain(false) + .addResolver(new PushStateResourceResolver(handledExtensions, ignorePaths)); } @Override diff --git a/src/main/java/com/ironoc/portfolio/config/Properties.java b/src/main/java/com/ironoc/portfolio/config/Properties.java index d2b8ec6..2c11797 100644 --- a/src/main/java/com/ironoc/portfolio/config/Properties.java +++ b/src/main/java/com/ironoc/portfolio/config/Properties.java @@ -5,7 +5,8 @@ @Getter public enum Properties { - GIT_API_ENDPOINT("com.ironoc.portfolio.github.api.endpoint"), + GIT_API_ENDPOINT_REPOS("com.ironoc.portfolio.github.api.endpoint.repos"), + GIT_API_ENDPOINT_ISSUES("com.ironoc.portfolio.github.api.endpoint.issues"), GIT_TIMEOUT_CONNECT ("com.ironoc.portfolio.github.timeout.connect"), GIT_TIMEOUT_READ("com.ironoc.portfolio.github.timeout.read"), GIT_INSTANCE_FOLLOW_REDIRECTS("com.ironoc.portfolio.github.instance-follow-redirects"), diff --git a/src/main/java/com/ironoc/portfolio/config/PropertyConfig.java b/src/main/java/com/ironoc/portfolio/config/PropertyConfig.java index f413e6a..4cd014d 100644 --- a/src/main/java/com/ironoc/portfolio/config/PropertyConfig.java +++ b/src/main/java/com/ironoc/portfolio/config/PropertyConfig.java @@ -16,8 +16,13 @@ public PropertyConfig(Environment environment, PropertyKeyI propertyKey) { } @Override - public String getGitApiEndpoint() { - return environment.getRequiredProperty(propertyKey.getGitApiEndpoint()); + public String getGitApiEndpointRepos() { + return environment.getRequiredProperty(propertyKey.getGitApiEndpointRepos()); + } + + @Override + public String getGitApiEndpointIssues() { + return environment.getRequiredProperty(propertyKey.getGitApiEndpointIssues()); } @Override diff --git a/src/main/java/com/ironoc/portfolio/config/PropertyConfigI.java b/src/main/java/com/ironoc/portfolio/config/PropertyConfigI.java index 4b5fcd4..e895ccc 100644 --- a/src/main/java/com/ironoc/portfolio/config/PropertyConfigI.java +++ b/src/main/java/com/ironoc/portfolio/config/PropertyConfigI.java @@ -2,7 +2,7 @@ public interface PropertyConfigI { - String getGitApiEndpoint(); + String getGitApiEndpointRepos(); Integer getGitTimeoutConnect(); @@ -11,4 +11,6 @@ public interface PropertyConfigI { Boolean getGitInstanceFollowRedirects(); Boolean getGitFollowRedirects(); + + String getGitApiEndpointIssues(); } \ No newline at end of file diff --git a/src/main/java/com/ironoc/portfolio/config/PropertyKey.java b/src/main/java/com/ironoc/portfolio/config/PropertyKey.java index f2872fb..ab4a751 100644 --- a/src/main/java/com/ironoc/portfolio/config/PropertyKey.java +++ b/src/main/java/com/ironoc/portfolio/config/PropertyKey.java @@ -6,8 +6,13 @@ public class PropertyKey implements PropertyKeyI { @Override - public String getGitApiEndpoint() { - return Properties.GIT_API_ENDPOINT.getKey(); + public String getGitApiEndpointRepos() { + return Properties.GIT_API_ENDPOINT_REPOS.getKey(); + } + + @Override + public String getGitApiEndpointIssues() { + return Properties.GIT_API_ENDPOINT_ISSUES.getKey(); } @Override diff --git a/src/main/java/com/ironoc/portfolio/config/PropertyKeyI.java b/src/main/java/com/ironoc/portfolio/config/PropertyKeyI.java index 2f37b38..1c1351d 100644 --- a/src/main/java/com/ironoc/portfolio/config/PropertyKeyI.java +++ b/src/main/java/com/ironoc/portfolio/config/PropertyKeyI.java @@ -2,7 +2,7 @@ public interface PropertyKeyI { - String getGitApiEndpoint(); + String getGitApiEndpointRepos(); String getGitTimeoutConnect(); @@ -11,4 +11,6 @@ public interface PropertyKeyI { String getGitInstanceFollowRedirects(); String getGitFollowRedirects(); + + String getGitApiEndpointIssues(); } diff --git a/src/main/java/com/ironoc/portfolio/config/PushStateResourceResolver.java b/src/main/java/com/ironoc/portfolio/config/PushStateResourceResolver.java new file mode 100644 index 0000000..a1b43e9 --- /dev/null +++ b/src/main/java/com/ironoc/portfolio/config/PushStateResourceResolver.java @@ -0,0 +1,80 @@ +package com.ironoc.portfolio.config; + +import com.ironoc.portfolio.logger.AbstractLogger; +import jakarta.servlet.http.HttpServletRequest; +import org.springframework.core.io.ClassPathResource; +import org.springframework.core.io.Resource; +import org.springframework.util.StringUtils; +import org.springframework.web.servlet.resource.ResourceResolver; +import org.springframework.web.servlet.resource.ResourceResolverChain; + +import java.io.IOException; +import java.util.List; + +public class PushStateResourceResolver extends AbstractLogger implements ResourceResolver { + + private final Resource index; + + private final List handledExtensions; + + private final List ignoredPaths; + + public PushStateResourceResolver(List handledExtensions, List ignoredPaths) { + this.handledExtensions = handledExtensions; + this.ignoredPaths = ignoredPaths; + this.index = new ClassPathResource("/static/index.html"); + } + + @Override + public Resource resolveResource(HttpServletRequest request, String requestPath, + List locations, ResourceResolverChain chain) { + return resolve(requestPath, locations); + } + + @Override + public String resolveUrlPath(String resourcePath, List locations, + ResourceResolverChain chain) { + Resource resolvedResource = resolve(resourcePath, locations); + if (resolvedResource == null) { + return null; + } + try { + return resolvedResource.getURL().toString(); + } catch (IOException e) { + error("Unexpected error occurred resolving URL path.", e); + return resolvedResource.getFilename(); + } + } + + private Resource resolve(String requestPath, List locations) { + if (isIgnored(requestPath)) { + return null; + } + if (isHandled(requestPath)) { + return locations.stream() + .map(loc -> createRelative(loc, requestPath)) + .filter(resource -> resource != null && resource.exists()) + .findFirst() + .orElseGet(null); + } + return index; + } + + private Resource createRelative(Resource resource, String relativePath) { + try { + return resource.createRelative(relativePath); + } catch (IOException e) { + error("Unexpected error occurred creating relative path.", e); + return null; + } + } + + private boolean isIgnored(String path) { + return ignoredPaths.contains(path); + } + + private boolean isHandled(String path) { + String extension = StringUtils.getFilenameExtension(path); + return handledExtensions.stream().anyMatch(ext -> ext.equals(extension)); + } +} diff --git a/src/main/java/com/ironoc/portfolio/controller/CustomErrorController.java b/src/main/java/com/ironoc/portfolio/controller/CustomErrorController.java deleted file mode 100644 index fa4ec2c..0000000 --- a/src/main/java/com/ironoc/portfolio/controller/CustomErrorController.java +++ /dev/null @@ -1,27 +0,0 @@ -package com.ironoc.portfolio.controller; - -import com.ironoc.portfolio.logger.AbstractLogger; -import jakarta.servlet.RequestDispatcher; -import jakarta.servlet.http.HttpServletRequest; - -import org.springframework.boot.web.servlet.error.ErrorController; -import org.springframework.stereotype.Controller; -import org.springframework.web.bind.annotation.RequestMapping; -import org.springframework.web.servlet.view.RedirectView; - -@Controller -public class CustomErrorController extends AbstractLogger implements ErrorController { - - protected static final String PATH = "/error"; - - @RequestMapping(value = PATH) - public RedirectView error(HttpServletRequest request) { - error("Unexpected error occurred. {}, The HTTP status is: {}", - request.getAttribute(RequestDispatcher.ERROR_MESSAGE), - request.getAttribute(RequestDispatcher.ERROR_STATUS_CODE)); - RedirectView redirectView = new RedirectView("/", false); - error("Bad request for {}. Redirecting to home", - request.getAttribute(RequestDispatcher.ERROR_REQUEST_URI)); - return redirectView; - } -} diff --git a/src/main/java/com/ironoc/portfolio/controller/GitProjectsController.java b/src/main/java/com/ironoc/portfolio/controller/GitProjectsController.java index 01b9540..c7788b5 100644 --- a/src/main/java/com/ironoc/portfolio/controller/GitProjectsController.java +++ b/src/main/java/com/ironoc/portfolio/controller/GitProjectsController.java @@ -1,7 +1,9 @@ package com.ironoc.portfolio.controller; import com.ironoc.portfolio.domain.RepositoryDetailDomain; +import com.ironoc.portfolio.domain.RepositoryIssueDomain; import com.ironoc.portfolio.dto.RepositoryDetailDto; +import com.ironoc.portfolio.dto.RepositoryIssueDto; import com.ironoc.portfolio.logger.AbstractLogger; import com.ironoc.portfolio.service.GitDetailsService; import io.swagger.v3.oas.annotations.Operation; @@ -55,17 +57,60 @@ public ResponseEntity> getReposByUsernameReqParam(H return getReposByUsername(request, username); } + @Operation(summary = "Get project issues by GitHub username & repository (project name).", + description = "Returns a list of Github project bugs/issues per 'username' & 'repository' path variables.") + @ApiResponses(value = { + @ApiResponse(responseCode = "200", + description = "Successfully retrieved GitHub issues for username & repository path variables.") + }) + @GetMapping(value = {"/get-repo-issue/{username}/{repository}/"}, produces= MediaType.APPLICATION_JSON_VALUE) + public ResponseEntity> getIssuesByUsernameAndRepoPathVars(HttpServletRequest request, + @PathVariable(value = "username") String username, + @PathVariable(value = "repository") String repository) { + return getIssuesByUsernameAndRepo(request, username, repository); + } + + private ResponseEntity> getIssuesByUsernameAndRepo(HttpServletRequest request, + String username, + String repository) { + // user & repo name validation (must contain only letters, numbers and/or dash chars) + String userId = ""; + String repo = ""; + if (!StringUtils.isNoneBlank(username, repository)) { + return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(Collections.emptyList()); + } else if (!StringUtils.isAlphanumericSpace(sanitizeValue(username) + .replaceAll("-", " "))) { + return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(Collections.emptyList()); + } else if (!StringUtils.isAlphanumericSpace(sanitizeValue(repository) + .replaceAll("-", " "))) { + return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(Collections.emptyList()); + } else { + List pathVars = sanitizeValues(username, repository); + userId = pathVars.get(0); + repo = pathVars.get(1); + } + info("Github list issues by username={} and repo={} for request, host={}, uri={}, user-agent={}", + userId, repo, + request.getHeader("host"), + request.getRequestURI(), + request.getHeader("user-agent")); + List repositoryIssueDtos = gitDetailsService.getIssues(userId, repo); + info("The repository issues for user={} and repo={} are: {}", userId, repo, repositoryIssueDtos); + return ResponseEntity.status(HttpStatus.OK) + .body(gitDetailsService.mapIssuesToResponse(repositoryIssueDtos)); + } + private ResponseEntity> getReposByUsername(HttpServletRequest request, String username) { // username validation (must contain only letters, numbers and/or dash chars) String userId = ""; if (StringUtils.isBlank(username)) { return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(Collections.emptyList()); - } else if (!StringUtils.isAlphanumericSpace(sanitizeUsername(username) + } else if (!StringUtils.isAlphanumericSpace(sanitizeValue(username) .replaceAll("-", " "))) { return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(Collections.emptyList()); } else { - userId = sanitizeUsername(username); + userId = sanitizeValue(username); } info("Github get repositories by username={} for request, host={}, uri={}, user-agent={}", @@ -79,10 +124,17 @@ private ResponseEntity> getReposByUsername(HttpServ .body(gitDetailsService.mapRepositoriesToResponse(repositories)); } - private String sanitizeUsername(String username) { + private List sanitizeValues(String... values) { + // trim leading and trailing whitespace + String sanitizedValueUserId = sanitizeValue(values[0]); + String sanitizedValueRepo = sanitizeValue(values[1]); + return List.of(sanitizedValueUserId, sanitizedValueRepo); + } + + private String sanitizeValue(String value) { // trim leading and trailing whitespace - String sanitizedUserId = username.trim(); + String sanitizedValue = value.trim(); // remove unwanted characters & accents etc - return sanitizedUserId.replaceAll("\\p{M}", ""); + return sanitizedValue.replaceAll("\\p{M}", ""); } } diff --git a/src/main/java/com/ironoc/portfolio/controller/HomeController.java b/src/main/java/com/ironoc/portfolio/controller/HomeController.java deleted file mode 100644 index 4eab0ca..0000000 --- a/src/main/java/com/ironoc/portfolio/controller/HomeController.java +++ /dev/null @@ -1,29 +0,0 @@ -package com.ironoc.portfolio.controller; - -import com.ironoc.portfolio.logger.AbstractLogger; -import com.ironoc.portfolio.service.GitDetails; -import jakarta.servlet.http.HttpServletRequest; - -import org.springframework.beans.factory.annotation.Autowired; -import org.springframework.stereotype.Controller; -import org.springframework.web.bind.annotation.RequestMapping; - -@Controller -public class HomeController extends AbstractLogger { - - private final GitDetails gitDetails; - - @Autowired - public HomeController(GitDetails gitDetails) { - this.gitDetails = gitDetails; - } - - @RequestMapping( {"/"} ) - public String index(HttpServletRequest request) { - info("Home page request details, host={}, uri={}, user-agent={}", - request.getHeader("host"), - request.getRequestURI(), - request.getHeader("user-agent")); - return "index"; - } -} diff --git a/src/main/java/com/ironoc/portfolio/domain/RepositoryDetailDomain.java b/src/main/java/com/ironoc/portfolio/domain/RepositoryDetailDomain.java index 67c50ec..e4d9539 100644 --- a/src/main/java/com/ironoc/portfolio/domain/RepositoryDetailDomain.java +++ b/src/main/java/com/ironoc/portfolio/domain/RepositoryDetailDomain.java @@ -4,9 +4,11 @@ import lombok.AllArgsConstructor; import lombok.Builder; import lombok.Getter; +import lombok.NoArgsConstructor; @Builder @AllArgsConstructor +@NoArgsConstructor @Getter public class RepositoryDetailDomain { diff --git a/src/main/java/com/ironoc/portfolio/domain/RepositoryIssueDomain.java b/src/main/java/com/ironoc/portfolio/domain/RepositoryIssueDomain.java new file mode 100644 index 0000000..b56095e --- /dev/null +++ b/src/main/java/com/ironoc/portfolio/domain/RepositoryIssueDomain.java @@ -0,0 +1,24 @@ +package com.ironoc.portfolio.domain; + +import io.swagger.v3.oas.annotations.media.Schema; +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Getter; + +@Builder +@AllArgsConstructor +@Getter +public class RepositoryIssueDomain { + + @Schema(name= "number", description = "Project Issue Number.", + example = "45", required = true) + private String number; + + @Schema(name= "title", description = "Issue Title Text.", + example = "The UI is not rendering the GitHub Repo Details View", required = true) + private String title; + + @Schema(name= "body", description = "Issue Content & Description.", + example = "The app crashes when I visit the Repo Details View", required = false) + private String body; +} diff --git a/src/main/java/com/ironoc/portfolio/dto/RepositoryIssueDto.java b/src/main/java/com/ironoc/portfolio/dto/RepositoryIssueDto.java new file mode 100644 index 0000000..27c5f9e --- /dev/null +++ b/src/main/java/com/ironoc/portfolio/dto/RepositoryIssueDto.java @@ -0,0 +1,28 @@ +package com.ironoc.portfolio.dto; + +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; +import com.fasterxml.jackson.annotation.JsonInclude; +import lombok.AllArgsConstructor; +import lombok.Builder; +import lombok.Getter; +import lombok.NoArgsConstructor; + +@Builder +@AllArgsConstructor +@NoArgsConstructor +@Getter +@JsonIgnoreProperties(ignoreUnknown = true) +@JsonInclude(JsonInclude.Include.NON_NULL) +public class RepositoryIssueDto { + + private String number; + + private String title; + + private String body; + + @Override + public String toString() { + return "number: '" + this.number + "'"; + } +} diff --git a/src/main/java/com/ironoc/portfolio/job/GitDetailsJob.java b/src/main/java/com/ironoc/portfolio/job/GitDetailsJob.java index 66349ff..cfeb3e1 100644 --- a/src/main/java/com/ironoc/portfolio/job/GitDetailsJob.java +++ b/src/main/java/com/ironoc/portfolio/job/GitDetailsJob.java @@ -7,9 +7,6 @@ import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; -import java.util.HashSet; -import java.util.Set; - @Component public class GitDetailsJob { @@ -17,8 +14,6 @@ public class GitDetailsJob { private final GitDetails gitDetails; - public static final String USERNAME_HOME_PAGE = "conorheffron"; - @Autowired public GitDetailsJob(GitDetails gitDetails, GitRepoCache gitRepoCache) { this.gitRepoCache = gitRepoCache; @@ -36,12 +31,8 @@ public void triggerGitDetailsJob() { } private void triggerJob() { - // set user ID list - Set userIds = new HashSet<>(); - userIds.add(USERNAME_HOME_PAGE); - // run background process to update cache - GitDetailsRunnable runnable = new GitDetailsRunnable(gitRepoCache, gitDetails, userIds); + GitDetailsRunnable runnable = new GitDetailsRunnable(gitRepoCache, gitDetails); runnable.run(); } } diff --git a/src/main/java/com/ironoc/portfolio/job/GitDetailsRunnable.java b/src/main/java/com/ironoc/portfolio/job/GitDetailsRunnable.java index 2ed0c78..b6b83a0 100644 --- a/src/main/java/com/ironoc/portfolio/job/GitDetailsRunnable.java +++ b/src/main/java/com/ironoc/portfolio/job/GitDetailsRunnable.java @@ -4,37 +4,47 @@ import com.ironoc.portfolio.dto.RepositoryDetailDto; import com.ironoc.portfolio.service.GitDetails; import jakarta.annotation.PreDestroy; +import lombok.Getter; +import java.util.HashSet; import java.util.List; import java.util.Set; +@Getter public class GitDetailsRunnable implements Runnable { private final GitRepoCache gitRepoCache; private final GitDetails gitDetails; - private final Set userIds; + public final Set userIds; + + public static final String USERNAME_HOME_PAGE = "conorheffron"; public GitDetailsRunnable(GitRepoCache gitRepoCache, - GitDetails gitDetails, - Set usersIds) { + GitDetails gitDetails) { this.gitRepoCache = gitRepoCache; this.gitDetails = gitDetails; - this.userIds = usersIds; + this.userIds = populateUserIds(); + } + + private Set populateUserIds() { + // set user ID list + Set userIds = new HashSet<>(); + userIds.add(USERNAME_HOME_PAGE); + return userIds; } @Override public void run() { for (String userId : userIds) { - List repoDetails = gitDetails.getRepoDetails(userId); - gitRepoCache.put(userId, repoDetails); + List dtos = gitDetails.getRepoDetails(userId); + gitRepoCache.put(userId, gitDetails.mapRepositoriesToResponse(dtos)); } } @PreDestroy public void tearDown() { this.userIds.clear(); - this.tearDown(); } } diff --git a/src/main/java/com/ironoc/portfolio/service/GitDetails.java b/src/main/java/com/ironoc/portfolio/service/GitDetails.java index bfd6f66..8df6753 100644 --- a/src/main/java/com/ironoc/portfolio/service/GitDetails.java +++ b/src/main/java/com/ironoc/portfolio/service/GitDetails.java @@ -1,7 +1,9 @@ package com.ironoc.portfolio.service; import com.ironoc.portfolio.domain.RepositoryDetailDomain; +import com.ironoc.portfolio.domain.RepositoryIssueDomain; import com.ironoc.portfolio.dto.RepositoryDetailDto; +import com.ironoc.portfolio.dto.RepositoryIssueDto; import java.util.List; @@ -9,5 +11,13 @@ public interface GitDetails { List getRepoDetails(String username); - List mapRepositoriesToResponse(List repositoryDetailDtos); + List mapRepositoriesToResponse( + List repositoryDetailDtos); + + List mapResponseToRepositories( + List repositoryDetailDomains); + + List getIssues(String userId, String repo); + + List mapIssuesToResponse(List repositoryIssueDtos); } diff --git a/src/main/java/com/ironoc/portfolio/service/GitDetailsService.java b/src/main/java/com/ironoc/portfolio/service/GitDetailsService.java index 92eee7c..9476abd 100644 --- a/src/main/java/com/ironoc/portfolio/service/GitDetailsService.java +++ b/src/main/java/com/ironoc/portfolio/service/GitDetailsService.java @@ -1,23 +1,21 @@ package com.ironoc.portfolio.service; -import com.fasterxml.jackson.databind.ObjectMapper; import com.ironoc.portfolio.client.Client; import com.ironoc.portfolio.config.PropertyConfigI; import com.ironoc.portfolio.domain.RepositoryDetailDomain; +import com.ironoc.portfolio.domain.RepositoryIssueDomain; import com.ironoc.portfolio.dto.RepositoryDetailDto; -import com.ironoc.portfolio.job.GitDetailsJob; +import com.ironoc.portfolio.dto.RepositoryIssueDto; +import com.ironoc.portfolio.job.GitDetailsRunnable; import com.ironoc.portfolio.logger.AbstractLogger; import com.ironoc.portfolio.utils.UrlUtils; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.http.HttpMethod; import org.springframework.stereotype.Service; import org.springframework.web.util.UriComponentsBuilder; -import javax.net.ssl.HttpsURLConnection; -import java.io.IOException; -import java.io.InputStream; -import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; import java.util.List; @@ -28,8 +26,6 @@ public class GitDetailsService extends AbstractLogger implements GitDetails { private final PropertyConfigI propertyConfig; - private final ObjectMapper objectMapper; - private final Client gitClient; private final GitRepoCache gitRepoCache; @@ -38,12 +34,10 @@ public class GitDetailsService extends AbstractLogger implements GitDetails { @Autowired public GitDetailsService(PropertyConfigI propertyConfig, - ObjectMapper objectMapper, Client gitClient, GitRepoCache gitRepoCache, UrlUtils urlUtils) { this.propertyConfig = propertyConfig; - this.objectMapper = objectMapper; this.gitClient = gitClient; this.urlUtils = urlUtils; this.gitRepoCache = gitRepoCache; @@ -52,45 +46,24 @@ public GitDetailsService(PropertyConfigI propertyConfig, @Override public List getRepoDetails(String username) { // check cache for home page user ID - if (username.toLowerCase().equals(GitDetailsJob.USERNAME_HOME_PAGE)) { - List repoDetails = gitRepoCache.get(GitDetailsJob.USERNAME_HOME_PAGE); + if (username.toLowerCase().equals(GitDetailsRunnable.USERNAME_HOME_PAGE)) { + List repoDetails = gitRepoCache + .get(GitDetailsRunnable.USERNAME_HOME_PAGE); if (repoDetails != null) { - return repoDetails; + return this.mapResponseToRepositories(repoDetails); } } // further end-point validation (contains User ID) - String uri = propertyConfig.getGitApiEndpoint(); + String uri = propertyConfig.getGitApiEndpointRepos(); String apiUri = UriComponentsBuilder.fromHttpUrl(uri) .buildAndExpand(username) .toUriString(); - if (StringUtils.isBlank(apiUri) | StringUtils.isBlank(apiUri) + if (StringUtils.isBlank(apiUri) | StringUtils.isBlank(uri) | !urlUtils.isValidURL(apiUri)) { warn("URL is not valid: url={}", apiUri); return Collections.emptyList(); } - info("Triggering repositories GET request: url={}", apiUri); - List repositoryDetailDtos = new ArrayList<>(); - InputStream inputStream = null; - try { - HttpsURLConnection conn = gitClient.createConn(apiUri); - inputStream = gitClient.readInputStream(conn); - repositoryDetailDtos = Arrays.asList(objectMapper.readValue(inputStream, - RepositoryDetailDto[].class)); - debug("repositoryDetailDtos={}", repositoryDetailDtos); - } catch(IOException ex) { - error("Unexpected error occurred while retrieving repo details for user=" + username, ex); - } finally { - try { - if (inputStream != null) { - gitClient.closeConn(inputStream); - } else { - warn("Input stream already closed."); - } - } catch (IOException ex) { - error("Unexpected error occurred while closing input stream.", ex); - } - } - return repositoryDetailDtos; + return gitClient.callGitHubApi(apiUri, uri, RepositoryDetailDto.class, HttpMethod.GET.name()); } @Override @@ -108,6 +81,50 @@ public List mapRepositoriesToResponse( .collect(Collectors.toList()); } + @Override + public List mapResponseToRepositories( + List repositoryDetailDomains) { + return repositoryDetailDomains.stream() + .map(repositoryDetailDomain -> RepositoryDetailDto.builder() + .name(repositoryDetailDomain.getName()) + .fullName(parseNull(repositoryDetailDomain.getFullName())) + .description(parseNull(repositoryDetailDomain.getDescription())) + .homePage(parseNull(repositoryDetailDomain.getAppHome())) + .topics(StringUtils.isNotBlank(repositoryDetailDomain.getTopics()) ? + Arrays.asList(repositoryDetailDomain.getTopics() + .substring(1, repositoryDetailDomain.getTopics().length() - 1) + .split(", ")) : Collections.emptyList()) + .htmlUrl(repositoryDetailDomain.getRepoUrl()) + .build()) + .collect(Collectors.toList()); + } + + @Override + public List getIssues(String userId, String repo) { + // further end-point validation (contains User ID) + String uri = propertyConfig.getGitApiEndpointIssues(); + String apiUri = UriComponentsBuilder.fromHttpUrl(uri) + .buildAndExpand(userId, repo) + .toUriString(); + if (StringUtils.isBlank(apiUri) | StringUtils.isBlank(uri) + | !urlUtils.isValidURL(apiUri)) { + warn("URL is not valid: url={}", apiUri); + return Collections.emptyList(); + } + return gitClient.callGitHubApi(apiUri, uri, RepositoryIssueDto.class, HttpMethod.GET.name()); + } + + @Override + public List mapIssuesToResponse(List repositoryIssueDtos) { + return repositoryIssueDtos.stream() + .map(repositoryIssueDto -> RepositoryIssueDomain.builder() + .number(repositoryIssueDto.getNumber()) + .title(repositoryIssueDto.getTitle()) + .body(repositoryIssueDto.getBody()) + .build()) + .collect(Collectors.toList()); + } + private String parseNull(String value) { return StringUtils.isBlank(value) ? "" : value; } diff --git a/src/main/java/com/ironoc/portfolio/service/GitRepoCache.java b/src/main/java/com/ironoc/portfolio/service/GitRepoCache.java index 8744390..e8c3cf1 100644 --- a/src/main/java/com/ironoc/portfolio/service/GitRepoCache.java +++ b/src/main/java/com/ironoc/portfolio/service/GitRepoCache.java @@ -1,5 +1,6 @@ package com.ironoc.portfolio.service; +import com.ironoc.portfolio.domain.RepositoryDetailDomain; import com.ironoc.portfolio.dto.RepositoryDetailDto; import org.springframework.stereotype.Service; @@ -8,7 +9,7 @@ @Service public interface GitRepoCache { - void put(String userId, List repositoryDetails); + void put(String userId, List repositoryDetails); - List get(String userId); + List get(String userId); } diff --git a/src/main/java/com/ironoc/portfolio/service/GitRepoCacheService.java b/src/main/java/com/ironoc/portfolio/service/GitRepoCacheService.java index 0a89dd4..ea3caaf 100644 --- a/src/main/java/com/ironoc/portfolio/service/GitRepoCacheService.java +++ b/src/main/java/com/ironoc/portfolio/service/GitRepoCacheService.java @@ -1,6 +1,6 @@ package com.ironoc.portfolio.service; -import com.ironoc.portfolio.dto.RepositoryDetailDto; +import com.ironoc.portfolio.domain.RepositoryDetailDomain; import jakarta.annotation.PreDestroy; import org.springframework.stereotype.Service; @@ -11,25 +11,24 @@ @Service public class GitRepoCacheService implements GitRepoCache { - private final Map> userGitDetails; + private final Map> userGitDetails; public GitRepoCacheService() { this.userGitDetails = new HashMap<>(); } @Override - public void put(String userId, List repositoryDetails) { + public void put(String userId, List repositoryDetails) { userGitDetails.put(userId, repositoryDetails); } @Override - public List get(String userId) { + public List get(String userId) { return userGitDetails.get(userId); } @PreDestroy public void tearDown() { this.userGitDetails.clear(); - this.tearDown(); } } diff --git a/src/main/resources/application.yml b/src/main/resources/application.yml index 1cc2ca7..2bee1f4 100644 --- a/src/main/resources/application.yml +++ b/src/main/resources/application.yml @@ -8,7 +8,9 @@ com: instance-follow-redirects: true follow-redirects: true api: - endpoint: https://api.github.com/users/{username}/repos + endpoint: + repos: https://api.github.com/users/{username}/repos + issues: https://api.github.com/repos/{username}/{repo}/issues spring: mvc: diff --git a/src/main/resources/log4j2-spring.xml b/src/main/resources/log4j2-spring.xml deleted file mode 100644 index ec68e78..0000000 --- a/src/main/resources/log4j2-spring.xml +++ /dev/null @@ -1,37 +0,0 @@ - - - - - - - - - - %d %p %C{1} [%t] %m%n - - - - - - - - - - - - - - - - - - - - - - diff --git a/src/main/webapp/static/config/robots.txt b/src/main/webapp/static/config/robots.txt deleted file mode 100644 index eb84c8b..0000000 --- a/src/main/webapp/static/config/robots.txt +++ /dev/null @@ -1,4 +0,0 @@ -User-agent: * -Disallow: - -SITEMAP: http://www.ironoc.com/sitemap.xml \ No newline at end of file diff --git a/src/main/webapp/static/config/sitemap.xml b/src/main/webapp/static/config/sitemap.xml deleted file mode 100644 index 4300a83..0000000 --- a/src/main/webapp/static/config/sitemap.xml +++ /dev/null @@ -1,11 +0,0 @@ - - - - http://www.ironoc.com/ - 2017-01-20T15:05:03+00:00 - - \ No newline at end of file diff --git a/src/main/webapp/static/css/style.css b/src/main/webapp/static/css/style.css deleted file mode 100644 index d7f5c9e..0000000 --- a/src/main/webapp/static/css/style.css +++ /dev/null @@ -1,260 +0,0 @@ -body { - font: 400 15px Lato, sans-serif; - line-height: 1.8; - color: #818181; -} - -h2 { - font-size: 24px; - text-transform: uppercase; - color: #303030; - font-weight: 600; - margin-bottom: 30px; -} - -h4 { - font-size: 19px; - line-height: 1.375em; - color: #303030; - font-weight: 400; - margin-bottom: 30px; -} - -.jumbotron { - background-color: #A8CD1B; - color: #fff; - padding: 100px 25px; - font-family: Montserrat, sans-serif; -} - -.jumbotron img { - width: 20%; - height: 20%; -} - -.container-fluid { - padding: 60px 50px; -} - -.bg-grey { - background-color: #f6f6f6; -} - -.logo-small { - color: #A8CD1B; - font-size: 50px; -} - -.logo { - color: #A8CD1B; - font-size: 200px; -} - -.thumbnail { - padding: 0 0 15px 0; - border: none; - border-radius: 0; -} - -.thumbnail img { - width: 100%; - height: 100%; - margin-bottom: 10px; -} - -.carousel-control.right, .carousel-control.left { - background-image: none; - color: #A8CD1B; -} - -.carousel-indicators li { - border-color: #A8CD1B; -} - -.carousel-indicators li.active { - background-color: #A8CD1B; -} - -.item a { - font-size: 19px; - line-height: 1.375em; - font-weight: 400; - font-style: italic; - margin: 70px 0; -} - -.item span { - font-style: normal; -} - -.panel { - border: 1px solid #A8CD1B; - border-radius: 0 !important; - transition: box-shadow 0.5s; -} - -.panel:hover { - box-shadow: 5px 0px 40px rgba(0, 0, 0, .2); -} - -.panel-footer .btn:hover { - border: 1px solid #A8CD1B; - background-color: #fff !important; - color: #A8CD1B; -} - -.panel-heading { - color: #fff !important; - background-color: #A8CD1B !important; - padding: 25px; - border-bottom: 1px solid transparent; - border-top-left-radius: 0px; - border-top-right-radius: 0px; - border-bottom-left-radius: 0px; - border-bottom-right-radius: 0px; -} - -.panel-footer { - background-color: white !important; -} - -.panel-footer h3 { - font-size: 32px; -} - -.panel-footer h4 { - color: #aaa; - font-size: 14px; -} - -.panel-footer .btn { - margin: 15px 0; - background-color: #A8CD1B; - color: #fff; -} - -.navbar { - margin-bottom: 0; - background-color: #A8CD1B; - z-index: 9999; - border: 0; - font-size: 12px !important; - line-height: 1.42857143 !important; - letter-spacing: 4px; - border-radius: 0; - font-family: Montserrat, sans-serif; -} - -.navbar li a, .navbar .navbar-brand { - color: #fff !important; -} - -.navbar-nav li a:hover, .navbar-nav li.active a { - color: #A8CD1B !important; - background-color: #fff !important; -} - -.navbar-default .navbar-toggle { - border-color: transparent; - color: #fff !important; -} - -footer .glyphicon { - font-size: 20px; - margin-bottom: 20px; - color: #A8CD1B; -} - -.slideanim { - visibility: hidden; -} - -.slide { - animation-name: slide; - -webkit-animation-name: slide; - animation-duration: 1s; - -webkit-animation-duration: 1s; - visibility: visible; -} - -@ -keyframes slide { 0% { - opacity: 0; - transform: translateY(70%); -} - -100% -{ -opacity -: - -1; -transform -: - -translateY -(0%); - - -} -} -@ --webkit-keyframes slide { 0% { - opacity: 0; - -webkit-transform: translateY(70%); -} - -100% -{ -opacity - - - - -: - - - - - -1; --webkit-transform - - - - -: - - - - - -translateY - - - - -(0%); -} -} -@media screen and (max-width: 768px) { - .col-sm-4 { - text-align: center; - margin: 25px 0; - } - .btn-lg { - width: 100%; - margin-bottom: 35px; - } -} - -@media screen and (max-width: 480px) { - .logo { - font-size: 150px; - } -} - -form { - width: 50%; - margin-left : 25% -} \ No newline at end of file diff --git a/src/main/webapp/static/imgs/favicon.ico b/src/main/webapp/static/imgs/favicon.ico deleted file mode 100644 index 26b4b57..0000000 Binary files a/src/main/webapp/static/imgs/favicon.ico and /dev/null differ diff --git a/src/main/webapp/static/js/index.js b/src/main/webapp/static/js/index.js deleted file mode 100644 index 6a9dfb2..0000000 --- a/src/main/webapp/static/js/index.js +++ /dev/null @@ -1,29 +0,0 @@ -window.onload = function() { - repositoryDetailsByUserName('conorheffron'); -}; - -function repositoryDetailsByUserName(username) { - fetch('/get-repo-detail?username=' + username) - .then(Response => Response.json()) - .then(repoDetails => { - renderRepoDetails(repoDetails); -})}; - -function renderRepoDetails(val){ - let output = document.getElementById("repo-output"); - let html = ''; - - val.forEach((repo_row, index) =>{ - html += ` - ${index} - ${repo_row.name} - ${repo_row.description} - ${repo_row.appHome} - ${repo_row.fullName} - ${repo_row.topics} - - `; - - }) - output.innerHTML = html; -} \ No newline at end of file diff --git a/src/main/webapp/templates/index.html b/src/main/webapp/templates/index.html deleted file mode 100644 index ff88fe2..0000000 --- a/src/main/webapp/templates/index.html +++ /dev/null @@ -1,180 +0,0 @@ - - - - Portfolio | Software Engineer | DevOps | Data Analytics - | iRonoc - - - - - - - - - - - - - - - - - -
- iRonoc -

iRonoc

-

Web Application Development | Software Engineering | Data Engineering | Cloud Deployments | DevOps

-
- - -
-
-
-

About

-

Welcome, I'm Conor Heffron, a Software Engineer hailing from County Meath, Ireland. - With over ten years of professional experience, I specialize in writing clean code and - developing high-performance applications. As a passionate Full Stack Developer, I am constantly - expanding my technical expertise across various tech stacks, languages, frameworks, and - tools in the realm of Software, Data, and DevOps. Let's connect and explore exciting - opportunities together! See below for contact details.

- - Link Tree -

- View Conor Heffron's profile on LinkedIn -

Follow - @conorheffron

- -
-
-
- - -
-

Portfolio

-

- Technologies:
Server-side: Java / Spring Boot 3, Python3, Django 5, R, & MySQL
Front-end: HTML5+CSS, - JQUERY, JSP, angularJS
and more... -

- - -
- -
-

GitHub Projects

-
-
- - -
-
- -
- - - - - - - - - - - - - -
#NameDescriptionApp HomeRepo URLTopics
-
-
- - - diff --git a/src/test/java/com/ironoc/portfolio/client/GitClientTest.java b/src/test/java/com/ironoc/portfolio/client/GitClientTest.java index af638ed..4a8a714 100644 --- a/src/test/java/com/ironoc/portfolio/client/GitClientTest.java +++ b/src/test/java/com/ironoc/portfolio/client/GitClientTest.java @@ -2,21 +2,26 @@ import com.ironoc.portfolio.aws.SecretManager; import com.ironoc.portfolio.config.PropertyConfigI; +import com.ironoc.portfolio.dto.RepositoryDetailDto; import com.ironoc.portfolio.utils.UrlUtils; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; import org.mockito.InjectMocks; import org.mockito.Mock; import org.mockito.junit.jupiter.MockitoExtension; +import org.springframework.http.HttpMethod; import javax.net.ssl.HttpsURLConnection; +import java.io.File; import java.io.IOException; import java.io.InputStream; +import java.util.Collection; import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.is; import static org.hamcrest.Matchers.nullValue; import static org.hamcrest.Matchers.notNullValue; +import static org.hamcrest.Matchers.emptyIterable; import static org.mockito.Mockito.never; import static org.mockito.Mockito.verify; import static org.mockito.Mockito.when; @@ -44,6 +49,16 @@ public class GitClientTest { private static final String TEST_URL = "https://unittest.github.com/users/conorheffron/repos"; + @Test + public void test_callGitHubApi_fail() { + // when + Collection result = gitClient + .callGitHubApi(TEST_URL, TEST_URL, RepositoryDetailDto.class, HttpMethod.GET.name()); + + // then + assertThat(result, is(emptyIterable())); + } + @Test public void test_readInputStream_fail() throws IOException { // when @@ -79,15 +94,13 @@ public void test_close_success() throws IOException { @Test public void test_createConn_without_token_success() throws IOException { // given - when(propertyConfigMock.getGitApiEndpoint()).thenReturn(TEST_URL); when(urlUtilsMock.isValidURL(TEST_URL)).thenReturn(true); // when - HttpsURLConnection result = gitClient.createConn(TEST_URL); + HttpsURLConnection result = gitClient.createConn(TEST_URL, TEST_URL, HttpMethod.GET.name()); // then verify(urlUtilsMock).isValidURL(TEST_URL); - verify(propertyConfigMock).getGitApiEndpoint(); verify(propertyConfigMock).getGitFollowRedirects(); verify(propertyConfigMock).getGitTimeoutConnect(); verify(propertyConfigMock).getGitTimeoutRead(); @@ -100,16 +113,14 @@ public void test_createConn_without_token_success() throws IOException { @Test public void test_createConn_with_token_success() throws IOException { // given - when(propertyConfigMock.getGitApiEndpoint()).thenReturn(TEST_URL); when(urlUtilsMock.isValidURL(TEST_URL)).thenReturn(true); when(secretManagerMock.getGitSecret()).thenReturn("test_fake_token"); // when - HttpsURLConnection result = gitClient.createConn(TEST_URL); + HttpsURLConnection result = gitClient.createConn(TEST_URL, TEST_URL, HttpMethod.GET.name()); // then verify(urlUtilsMock).isValidURL(TEST_URL); - verify(propertyConfigMock).getGitApiEndpoint(); verify(propertyConfigMock).getGitFollowRedirects(); verify(propertyConfigMock).getGitTimeoutConnect(); verify(propertyConfigMock).getGitTimeoutRead(); @@ -122,15 +133,13 @@ public void test_createConn_with_token_success() throws IOException { @Test public void test_createConn_invalid_url_fail() throws IOException { // given - when(propertyConfigMock.getGitApiEndpoint()).thenReturn(TEST_URL); when(urlUtilsMock.isValidURL(TEST_URL)).thenReturn(false); // when - HttpsURLConnection result = gitClient.createConn(TEST_URL); + HttpsURLConnection result = gitClient.createConn(TEST_URL, TEST_URL, HttpMethod.GET.name()); // then verify(urlUtilsMock).isValidURL(TEST_URL); - verify(propertyConfigMock).getGitApiEndpoint(); verify(propertyConfigMock, never()).getGitFollowRedirects(); verify(propertyConfigMock, never()).getGitTimeoutConnect(); verify(propertyConfigMock, never()).getGitTimeoutRead(); @@ -139,4 +148,142 @@ public void test_createConn_invalid_url_fail() throws IOException { assertThat(result, is(nullValue())); } + + @Test + public void test_convertInputStreamToString_success() throws Exception { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_response.json"); + + // when + String result = gitClient.convertInputStreamToString(jsonInputStream); + + + // then + assertThat(result, is("[\n" + + " {\n" + + " \"id\": 737159069,\n" + + " \"node_id\": \"R_kgDOK_AnnQ\",\n" + + " \"name\": \"bio-cell-red-edge\",\n" + + " \"full_name\": \"conorheffron/bio-cell-red-edge\",\n" + + " \"private\": false,\n" + + " \"owner\": {\n" + + " \"login\": \"conorheffron\",\n" + + " \"id\": 8218626,\n" + + " \"node_id\": \"MDQ6VXNlcjgyMTg2MjY=\",\n" + + " \"avatar_url\": \"https://avatars.githubusercontent.com/u/8218626?v=4\",\n" + + " \"gravatar_id\": \"\",\n" + + " \"url\": \"https://api.github.com/users/conorheffron\",\n" + + " \"html_url\": \"https://github.com/conorheffron\",\n" + + " \"followers_url\": \"https://api.github.com/users/conorheffron/followers\",\n" + + " \"following_url\": \"https://api.github.com/users/conorheffron/following{/other_user}\",\n" + + " \"gists_url\": \"https://api.github.com/users/conorheffron/gists{/gist_id}\",\n" + + " \"starred_url\": \"https://api.github.com/users/conorheffron/starred{/owner}{/repo}\",\n" + + " \"subscriptions_url\": \"https://api.github.com/users/conorheffron/subscriptions\",\n" + + " \"organizations_url\": \"https://api.github.com/users/conorheffron/orgs\",\n" + + " \"repos_url\": \"https://api.github.com/users/conorheffron/repos\",\n" + + " \"events_url\": \"https://api.github.com/users/conorheffron/events{/privacy}\",\n" + + " \"received_events_url\": \"https://api.github.com/users/conorheffron/received_events\",\n" + + " \"type\": \"User\",\n" + + " \"site_admin\": false\n" + + " },\n" + + " \"html_url\": \"https://github.com/conorheffron/bio-cell-red-edge\",\n" + + " \"description\": \"Edge Detection of Biological Cell (Image Processing Script)\",\n" + + " \"fork\": false,\n" + + " \"url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge\",\n" + + " \"forks_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/forks\",\n" + + " \"keys_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/keys{/key_id}\",\n" + + " \"collaborators_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/collaborators{/collaborator}\",\n" + + " \"teams_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/teams\",\n" + + " \"hooks_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/hooks\",\n" + + " \"issue_events_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/issues/events{/number}\",\n" + + " \"events_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/events\",\n" + + " \"assignees_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/assignees{/user}\",\n" + + " \"branches_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/branches{/branch}\",\n" + + " \"tags_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/tags\",\n" + + " \"blobs_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/git/blobs{/sha}\",\n" + + " \"git_tags_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/git/tags{/sha}\",\n" + + " \"git_refs_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/git/refs{/sha}\",\n" + + " \"trees_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/git/trees{/sha}\",\n" + + " \"statuses_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/statuses/{sha}\",\n" + + " \"languages_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/languages\",\n" + + " \"stargazers_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/stargazers\",\n" + + " \"contributors_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/contributors\",\n" + + " \"subscribers_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/subscribers\",\n" + + " \"subscription_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/subscription\",\n" + + " \"commits_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/commits{/sha}\",\n" + + " \"git_commits_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/git/commits{/sha}\",\n" + + " \"comments_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/comments{/number}\",\n" + + " \"issue_comment_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/issues/comments{/number}\",\n" + + " \"contents_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/contents/{+path}\",\n" + + " \"compare_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/compare/{base}...{head}\",\n" + + " \"merges_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/merges\",\n" + + " \"archive_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/{archive_format}{/ref}\",\n" + + " \"downloads_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/downloads\",\n" + + " \"issues_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/issues{/number}\",\n" + + " \"pulls_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/pulls{/number}\",\n" + + " \"milestones_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/milestones{/number}\",\n" + + " \"notifications_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/notifications{?since,all,participating}\",\n" + + " \"labels_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/labels{/name}\",\n" + + " \"releases_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/releases{/id}\",\n" + + " \"deployments_url\": \"https://api.github.com/repos/conorheffron/bio-cell-red-edge/deployments\",\n" + + " \"created_at\": \"2023-12-30T02:40:43Z\",\n" + + " \"updated_at\": \"2024-07-25T23:06:48Z\",\n" + + " \"pushed_at\": \"2024-07-25T23:10:52Z\",\n" + + " \"git_url\": \"git://github.com/conorheffron/bio-cell-red-edge.git\",\n" + + " \"ssh_url\": \"git@github.com:conorheffron/bio-cell-red-edge.git\",\n" + + " \"clone_url\": \"https://github.com/conorheffron/bio-cell-red-edge.git\",\n" + + " \"svn_url\": \"https://github.com/conorheffron/bio-cell-red-edge\",\n" + + " \"homepage\": \"https://conorheffron.github.io/bio-cell-red-edge/\",\n" + + " \"size\": 11698,\n" + + " \"stargazers_count\": 1,\n" + + " \"watchers_count\": 1,\n" + + " \"language\": \"Python\",\n" + + " \"has_issues\": true,\n" + + " \"has_projects\": true,\n" + + " \"has_downloads\": true,\n" + + " \"has_wiki\": true,\n" + + " \"has_pages\": true,\n" + + " \"has_discussions\": false,\n" + + " \"forks_count\": 0,\n" + + " \"mirror_url\": null,\n" + + " \"archived\": false,\n" + + " \"disabled\": false,\n" + + " \"open_issues_count\": 0,\n" + + " \"license\": {\n" + + " \"key\": \"gpl-3.0\",\n" + + " \"name\": \"GNU General Public License v3.0\",\n" + + " \"spdx_id\": \"GPL-3.0\",\n" + + " \"url\": \"https://api.github.com/licenses/gpl-3.0\",\n" + + " \"node_id\": \"MDc6TGljZW5zZTk=\"\n" + + " },\n" + + " \"allow_forking\": true,\n" + + " \"is_template\": false,\n" + + " \"web_commit_signoff_required\": false,\n" + + " \"topics\": [\n" + + " \"biology\",\n" + + " \"computer-vision\",\n" + + " \"image-processing\",\n" + + " \"scikitlearn-machine-learning\"\n" + + " ],\n" + + " \"visibility\": \"public\",\n" + + " \"forks\": 0,\n" + + " \"open_issues\": 0,\n" + + " \"watchers\": 1,\n" + + " \"default_branch\": \"main\"\n" + + " },\n" + + " {\n" + + " \"id\": 850363843,\n" + + " \"node_id\": \"R_kgDOMq-Fww\",\n" + + " \"name\": \"booking-sys\",\n" + + " \"full_name\": \"conorheffron/booking-sys\",\n" + + " \"private\": true,\n" + + " \"html_url\": \"https://github.com/conorheffron/booking-sys\",\n" + + " \"description\": \"Sample Reservations & Bookings Viewer System\",\n" + + " \"homepage\": \"https://booking-sys-ebgefrdmh3afbhee.northeurope-01.azurewebsites.net/book/\"\n" + + " }\n" + + "]")); + assertThat(jsonInputStream, is(notNullValue())); + jsonInputStream.close(); + } } diff --git a/src/test/java/com/ironoc/portfolio/config/IronocConfigurationTest.java b/src/test/java/com/ironoc/portfolio/config/IronocConfigurationTest.java index 5dad83f..d3bfc26 100644 --- a/src/test/java/com/ironoc/portfolio/config/IronocConfigurationTest.java +++ b/src/test/java/com/ironoc/portfolio/config/IronocConfigurationTest.java @@ -10,20 +10,19 @@ import org.mockito.junit.jupiter.MockitoExtension; import org.springframework.boot.web.server.WebServerFactoryCustomizer; import org.springframework.boot.web.servlet.server.ConfigurableServletWebServerFactory; -import org.springframework.web.servlet.ViewResolver; import org.springframework.web.servlet.config.annotation.DefaultServletHandlerConfigurer; +import org.springframework.web.servlet.config.annotation.ResourceChainRegistration; import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistration; import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; -import org.springframework.web.servlet.view.InternalResourceViewResolver; import java.util.List; import static org.hamcrest.MatcherAssert.assertThat; import static org.hamcrest.Matchers.is; import static org.hamcrest.Matchers.notNullValue; +import static org.mockito.ArgumentMatchers.any; import static org.mockito.Mockito.when; import static org.mockito.Mockito.verify; -import static org.mockito.Mockito.times; @ExtendWith(MockitoExtension.class) public class IronocConfigurationTest { @@ -40,21 +39,18 @@ public class IronocConfigurationTest { @Mock private DefaultServletHandlerConfigurer defaultServletHandlerConfigurerMock; - @Test - public void test_getViewResolver_success() { - // when - ViewResolver result = ironocConfiguration.getViewResolver(); - - // then - assertThat(result, is(notNullValue())); - assertThat(result.getClass(), is(InternalResourceViewResolver.class)); - } + @Mock + private ResourceChainRegistration resourceChainRegistrationMock; @Test public void test_addResourceHandlers_success() { // given when(resourceHandlerRegistryMock.addResourceHandler(ArgumentMatchers.anyString())) .thenReturn(resourceHandlerRegistrationMock); + when(resourceHandlerRegistrationMock.addResourceLocations(ArgumentMatchers.anyString())) + .thenReturn(resourceHandlerRegistrationMock); + when(resourceHandlerRegistrationMock.resourceChain(false)) + .thenReturn(resourceChainRegistrationMock); // when ironocConfiguration.addResourceHandlers(resourceHandlerRegistryMock); @@ -63,20 +59,13 @@ public void test_addResourceHandlers_success() { ArgumentCaptor resourceHandlerCaptors = ArgumentCaptor.forClass(String.class); ArgumentCaptor resourceLocationCaptors = ArgumentCaptor.forClass(String.class); - verify(resourceHandlerRegistryMock, times(4)).addResourceHandler(resourceHandlerCaptors.capture()); - verify(resourceHandlerRegistrationMock, times(4)).addResourceLocations(resourceLocationCaptors.capture()); + verify(resourceHandlerRegistryMock).addResourceHandler(resourceHandlerCaptors.capture()); + verify(resourceHandlerRegistrationMock).addResourceLocations(resourceLocationCaptors.capture()); + verify(resourceHandlerRegistrationMock).resourceChain(false); + verify(resourceChainRegistrationMock).addResolver(any(PushStateResourceResolver.class)); List capturedResourceHandlers = resourceHandlerCaptors.getAllValues(); - assertThat(IronocConfiguration.RESOURCES_HANDLER, is(capturedResourceHandlers.get(0))); - assertThat(IronocConfiguration.FAV_ICON, is(capturedResourceHandlers.get(1))); - assertThat(IronocConfiguration.SITE_MAP, is(capturedResourceHandlers.get(2))); - assertThat(IronocConfiguration.ROBOTS_TEXT, is(capturedResourceHandlers.get(3))); - - List capturedLocations = resourceLocationCaptors.getAllValues(); - assertThat(IronocConfiguration.STATIC_LOC, is(capturedLocations.get(0))); - assertThat(IronocConfiguration.IMAGES_LOC, is(capturedLocations.get(1))); - assertThat(IronocConfiguration.STATIC_CONF_LOC, is(capturedLocations.get(2))); - assertThat(IronocConfiguration.STATIC_CONF_LOC, is(capturedLocations.get(3))); + assertThat(capturedResourceHandlers.get(0), is("/**")); } @Test diff --git a/src/test/java/com/ironoc/portfolio/config/PropertyConfigTest.java b/src/test/java/com/ironoc/portfolio/config/PropertyConfigTest.java index 476287a..991d5c5 100644 --- a/src/test/java/com/ironoc/portfolio/config/PropertyConfigTest.java +++ b/src/test/java/com/ironoc/portfolio/config/PropertyConfigTest.java @@ -27,17 +27,33 @@ public class PropertyConfigTest { private static final String TEST_PROP_VAL = "test_val"; @Test - public void test_getGitApiEndpoint_success() { + public void test_getGitApiEndpoint_Repos_success() { // given - when(propertyKeyMock.getGitApiEndpoint()).thenReturn(Properties.GIT_API_ENDPOINT.getKey()); - when(environmentMock.getRequiredProperty(Properties.GIT_API_ENDPOINT.getKey())).thenReturn(TEST_PROP_VAL); + when(propertyKeyMock.getGitApiEndpointRepos()).thenReturn(Properties.GIT_API_ENDPOINT_REPOS.getKey()); + when(environmentMock.getRequiredProperty(Properties.GIT_API_ENDPOINT_REPOS.getKey())).thenReturn(TEST_PROP_VAL); // when - String result = propertyConfig.getGitApiEndpoint(); + String result = propertyConfig.getGitApiEndpointRepos(); // then - verify(propertyKeyMock).getGitApiEndpoint(); - verify(environmentMock).getRequiredProperty(Properties.GIT_API_ENDPOINT.getKey()); + verify(propertyKeyMock).getGitApiEndpointRepos(); + verify(environmentMock).getRequiredProperty(Properties.GIT_API_ENDPOINT_REPOS.getKey()); + + assertThat(result, is(TEST_PROP_VAL)); + } + + @Test + public void test_getGitApiEndpointIssues_success() { + // given + when(propertyKeyMock.getGitApiEndpointIssues()).thenReturn(Properties.GIT_API_ENDPOINT_ISSUES.getKey()); + when(environmentMock.getRequiredProperty(Properties.GIT_API_ENDPOINT_ISSUES.getKey())).thenReturn(TEST_PROP_VAL); + + // when + String result = propertyConfig.getGitApiEndpointIssues(); + + // then + verify(propertyKeyMock).getGitApiEndpointIssues(); + verify(environmentMock).getRequiredProperty(Properties.GIT_API_ENDPOINT_ISSUES.getKey()); assertThat(result, is(TEST_PROP_VAL)); } diff --git a/src/test/java/com/ironoc/portfolio/config/PropertyKeyTest.java b/src/test/java/com/ironoc/portfolio/config/PropertyKeyTest.java new file mode 100644 index 0000000..3acbaf4 --- /dev/null +++ b/src/test/java/com/ironoc/portfolio/config/PropertyKeyTest.java @@ -0,0 +1,70 @@ +package com.ironoc.portfolio.config; + +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.ExtendWith; +import org.mockito.InjectMocks; +import org.mockito.junit.jupiter.MockitoExtension; + +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.is; + +@ExtendWith(MockitoExtension.class) +public class PropertyKeyTest { + + @InjectMocks + private PropertyKey propertyKey; + + @Test + public void test_getGitApiEndpointIssues_success() { + // when + String result = propertyKey.getGitApiEndpointIssues(); + + // then + assertThat(result, is("com.ironoc.portfolio.github.api.endpoint.issues")); + } + + @Test + public void test_getGitApiEndpointRepos_success() { + // when + String result = propertyKey.getGitApiEndpointRepos(); + + // then + assertThat(result, is("com.ironoc.portfolio.github.api.endpoint.repos")); + } + + @Test + public void test_getGitFollowRedirects_success() { + // when + String result = propertyKey.getGitFollowRedirects(); + + // then + assertThat(result, is("com.ironoc.portfolio.github.follow-redirects")); + } + + @Test + public void test_getGitTimeoutRead_success() { + // when + String result = propertyKey.getGitTimeoutRead(); + + // then + assertThat(result, is("com.ironoc.portfolio.github.timeout.read")); + } + + @Test + public void test_getGitTimeoutConnect_success() { + // when + String result = propertyKey.getGitTimeoutConnect(); + + // then + assertThat(result, is("com.ironoc.portfolio.github.timeout.connect")); + } + + @Test + public void test_getGitInstanceFollowRedirects_success() { + // when + String result = propertyKey.getGitInstanceFollowRedirects(); + + // then + assertThat(result, is("com.ironoc.portfolio.github.instance-follow-redirects")); + } +} diff --git a/src/test/java/com/ironoc/portfolio/config/TestIronocConfiguration.java b/src/test/java/com/ironoc/portfolio/config/TestIronocConfiguration.java new file mode 100644 index 0000000..7d45894 --- /dev/null +++ b/src/test/java/com/ironoc/portfolio/config/TestIronocConfiguration.java @@ -0,0 +1,20 @@ +package com.ironoc.portfolio.config; + +import org.springframework.beans.BeansException; +import org.springframework.boot.test.context.TestConfiguration; +import org.springframework.context.ApplicationContext; +import org.springframework.context.ApplicationContextAware; +import org.springframework.context.annotation.ComponentScan; +import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; + +@TestConfiguration +@ComponentScan(basePackages = { "com.ironoc.portfolio" }) +public class TestIronocConfiguration implements WebMvcConfigurer, ApplicationContextAware { + + private ApplicationContext applicationContext; + + @Override + public void setApplicationContext(ApplicationContext applicationContext) throws BeansException { + this.applicationContext = applicationContext; + } +} diff --git a/src/test/java/com/ironoc/portfolio/controller/CustomErrorControllerTest.java b/src/test/java/com/ironoc/portfolio/controller/CustomErrorControllerTest.java deleted file mode 100644 index a940d75..0000000 --- a/src/test/java/com/ironoc/portfolio/controller/CustomErrorControllerTest.java +++ /dev/null @@ -1,53 +0,0 @@ -package com.ironoc.portfolio.controller; - -import jakarta.servlet.RequestDispatcher; -import jakarta.servlet.http.HttpServletRequest; - -import org.junit.jupiter.api.Test; -import org.junit.jupiter.api.extension.ExtendWith; -import org.mockito.InjectMocks; -import org.mockito.Mock; -import org.mockito.junit.jupiter.MockitoExtension; -import org.springframework.web.servlet.view.RedirectView; - -import static org.hamcrest.MatcherAssert.assertThat; -import static org.hamcrest.Matchers.is; -import static org.hamcrest.Matchers.isA; -import static org.hamcrest.Matchers.notNullValue; -import static org.mockito.ArgumentMatchers.anyString; -import static org.mockito.Mockito.times; -import static org.mockito.Mockito.verify; - -@ExtendWith(MockitoExtension.class) -public class CustomErrorControllerTest { - - @InjectMocks - private CustomErrorController customErrorController; - - @Mock - private HttpServletRequest httpServletRequestMock; - - @Test - public void test_error_view_success() { - // when - RedirectView result = customErrorController.error(httpServletRequestMock); - - // then - verify(httpServletRequestMock, times(3)).getAttribute(anyString()); - verify(httpServletRequestMock).getAttribute(RequestDispatcher.ERROR_MESSAGE); - verify(httpServletRequestMock).getAttribute(RequestDispatcher.ERROR_STATUS_CODE); - verify(httpServletRequestMock).getAttribute(RequestDispatcher.ERROR_REQUEST_URI); - - assertThat(result, is(notNullValue())); - assertThat(result, isA(RedirectView.class)); - } - - @Test - public void test_getErrorPath_success() { - // when - String result = CustomErrorController.PATH; - - // then - assertThat(result, is("/error")); - } -} diff --git a/src/test/java/com/ironoc/portfolio/controller/GitProjectsControllerIntegrationTest.java b/src/test/java/com/ironoc/portfolio/controller/GitProjectsControllerIntegrationTest.java new file mode 100644 index 0000000..33fc8b9 --- /dev/null +++ b/src/test/java/com/ironoc/portfolio/controller/GitProjectsControllerIntegrationTest.java @@ -0,0 +1,194 @@ +package com.ironoc.portfolio.controller; + +import com.fasterxml.jackson.databind.ObjectMapper; +import com.ironoc.portfolio.config.TestIronocConfiguration; +import com.ironoc.portfolio.dto.RepositoryDetailDto; +import com.ironoc.portfolio.dto.RepositoryIssueDto; +import com.ironoc.portfolio.service.GitDetailsService; +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.TestInstance; +import org.junit.jupiter.api.extension.ExtendWith; +import org.mockito.InjectMocks; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.mock.mockito.MockBean; +import org.springframework.http.HttpStatus; +import org.springframework.http.MediaType; +import org.springframework.mock.web.MockHttpServletResponse; +import org.springframework.test.context.ContextConfiguration; +import org.springframework.test.context.junit.jupiter.SpringExtension; +import org.springframework.test.context.web.WebAppConfiguration; +import org.springframework.test.web.servlet.MockMvc; +import org.springframework.test.web.servlet.setup.MockMvcBuilders; +import org.springframework.web.context.WebApplicationContext; + +import java.io.File; +import java.io.InputStream; +import java.util.List; + +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.is; +import static org.mockito.ArgumentMatchers.anyList; +import static org.mockito.Mockito.when; +import static org.mockito.Mockito.verify; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status; +import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get; + +@ExtendWith(SpringExtension.class) +@WebAppConfiguration() +@ContextConfiguration(classes = {TestIronocConfiguration.class}) +@TestInstance(TestInstance.Lifecycle.PER_CLASS) +public class GitProjectsControllerIntegrationTest { + + @Autowired + private WebApplicationContext webAppContext; + + private MockMvc mockMvc; + + @Autowired + private ObjectMapper objectMapper; + + @MockBean + private GitDetailsService gitDetailsServiceMock; + + @InjectMocks + private GitProjectsController gitProjectsController;// controller under test + + private static final String JSON_RESPONSE = "[{\"name\":\"bio-cell-red-edge\"," + + "\"fullName\":\"conorheffron/bio-cell-red-edge\"," + + "\"description\":\"Edge Detection of Biological Cell (Image Processing Script)\"," + + "\"appHome\":\"https://conorheffron.github.io/bio-cell-red-edge/\"," + + "\"repoUrl\":\"https://github.com/conorheffron/bio-cell-red-edge\"," + + "\"topics\":\"[biology, computer-vision, image-processing, scikitlearn-machine-learning]\"}," + + "{\"name\":\"booking-sys\",\"fullName\":\"conorheffron/booking-sys\"," + + "\"description\":\"Sample Reservations & Bookings Viewer System\"," + + "\"appHome\":\"https://booking-sys-ebgefrdmh3afbhee.northeurope-01.azurewebsites.net/book/\"," + + "\"repoUrl\":\"https://github.com/conorheffron/booking-sys\",\"topics\":\"\"" + + "}]"; + private static final String ISSUES_JSON_RESPONSE = "[{\"number\":\"62\"," + + "\"title\":\"Re-write frontend with React \"," + + "\"body\":\"Use React or Angular framework & JavaScript " + + "or TypeScript as implementation language? \\r\\n- Research & select best option.\"}," + + "{\"number\":\"57\"," + + "\"title\":\"Setup LB, Support SSL\"," + + "\"body\":\"- [x] 1. Setup LB\\r\\n" + + "- [ ] 2. Support SSL\\r\\n" + + "- [ ] 3. Setup domain, map to AWS LB\"}" + + "]"; + + @BeforeEach + public void setup() { + mockMvc = MockMvcBuilders.webAppContextSetup(webAppContext).build(); + } + + @Test + public void test_getReposByUsernamePathVar_success() throws Exception { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_response.json"); + List dtos = List.of(objectMapper.readValue(jsonInputStream, RepositoryDetailDto[].class)); + + when(gitDetailsServiceMock.getRepoDetails("conorheffron")).thenReturn(dtos); + when(gitDetailsServiceMock.mapRepositoriesToResponse(anyList())) + .thenReturn(new GitDetailsService(null, null, null, null) + .mapRepositoriesToResponse(dtos)); + + // when + MockHttpServletResponse response = mockMvc.perform(get("/get-repo-detail/conorheffron/") + .accept(MediaType.APPLICATION_JSON)).andExpect(status().isOk()) + .andReturn().getResponse(); + + // then + verify(gitDetailsServiceMock).getRepoDetails("conorheffron"); + verify(gitDetailsServiceMock).mapRepositoriesToResponse(anyList()); + + assertThat(response.getStatus(), is(HttpStatus.OK.value())); + assertThat(response.getContentAsString(), is(JSON_RESPONSE)); + } + + @Test + public void test_getReposByUsernamePathVar_empty_response_success() throws Exception { + // when + MockHttpServletResponse response = mockMvc.perform(get("/get-repo-detail/test-user/") + .accept(MediaType.APPLICATION_JSON)).andExpect(status().isOk()) + .andReturn().getResponse(); + + // then + assertThat(response.getStatus(), is(HttpStatus.OK.value())); + assertThat(response.getContentAsString(), is("[]")); + } + + @Test + public void test_getReposByUsernameReqParam_success() throws Exception { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_response.json"); + List dtos = List.of(objectMapper.readValue(jsonInputStream, RepositoryDetailDto[].class)); + + when(gitDetailsServiceMock.getRepoDetails("conorheffron")).thenReturn(dtos); + when(gitDetailsServiceMock.mapRepositoriesToResponse(anyList())) + .thenReturn(new GitDetailsService(null, null, null, null) + .mapRepositoriesToResponse(dtos)); + + // when + MockHttpServletResponse response = mockMvc.perform(get("/get-repo-detail?username=conorheffron") + .accept(MediaType.APPLICATION_JSON)).andExpect(status().isOk()) + .andReturn().getResponse(); + + // then + verify(gitDetailsServiceMock).getRepoDetails("conorheffron"); + verify(gitDetailsServiceMock).mapRepositoriesToResponse(anyList()); + + assertThat(response.getStatus(), is(HttpStatus.OK.value())); + assertThat(response.getContentAsString(), is(JSON_RESPONSE)); + } + + @Test + public void test_getReposByUsernameReqParam_empty_response_success() throws Exception { + // when + MockHttpServletResponse response = mockMvc.perform(get("/get-repo-detail?username=test-user") + .accept(MediaType.APPLICATION_JSON)).andExpect(status().isOk()) + .andReturn().getResponse(); + + // then + assertThat(response.getStatus(), is(HttpStatus.OK.value())); + assertThat(response.getContentAsString(), is("[]")); + } + + @Test + public void test_getIssuesByUsernameAndRepoPathVars_empty_response_success() throws Exception { + // when + MockHttpServletResponse response = mockMvc.perform(get("/get-repo-issue/test-user/test-repo/") + .accept(MediaType.APPLICATION_JSON)).andExpect(status().isOk()) + .andReturn().getResponse(); + + // then + assertThat(response.getStatus(), is(HttpStatus.OK.value())); + assertThat(response.getContentAsString(), is("[]")); + } + + @Test + public void test_getIssuesByUsernameAndRepoPathVars_success() throws Exception { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_issues_response.json"); + List dtos = List.of(objectMapper.readValue(jsonInputStream, RepositoryIssueDto[].class)); + + when(gitDetailsServiceMock.getIssues("test-user", "test-repo")).thenReturn(dtos); + when(gitDetailsServiceMock.mapIssuesToResponse(anyList())) + .thenReturn(new GitDetailsService(null, null, null, null) + .mapIssuesToResponse(dtos)); + + // when + MockHttpServletResponse response = mockMvc.perform(get("/get-repo-issue/test-user/test-repo/") + .accept(MediaType.APPLICATION_JSON)).andExpect(status().isOk()) + .andReturn().getResponse(); + + // then + verify(gitDetailsServiceMock).getIssues("test-user", "test-repo"); + verify(gitDetailsServiceMock).mapIssuesToResponse(anyList()); + + assertThat(response.getStatus(), is(HttpStatus.OK.value())); + assertThat(response.getContentAsString(), is(ISSUES_JSON_RESPONSE)); + } +} diff --git a/src/test/java/com/ironoc/portfolio/controller/GitProjectsControllerTest.java b/src/test/java/com/ironoc/portfolio/controller/GitProjectsControllerTest.java index 4852469..3810b42 100644 --- a/src/test/java/com/ironoc/portfolio/controller/GitProjectsControllerTest.java +++ b/src/test/java/com/ironoc/portfolio/controller/GitProjectsControllerTest.java @@ -1,6 +1,7 @@ package com.ironoc.portfolio.controller; import com.ironoc.portfolio.domain.RepositoryDetailDomain; +import com.ironoc.portfolio.domain.RepositoryIssueDomain; import com.ironoc.portfolio.service.GitDetailsService; import jakarta.servlet.http.HttpServletRequest; import org.junit.jupiter.api.Test; @@ -37,6 +38,7 @@ public class GitProjectsControllerTest { private static final String TEST_USERNAME_ALPHA = "conorheffron"; private static final String TEST_USERNAME_ALPHA_NUMERIC = "conor123"; + private static final String TEST_REPO = "booking-sys"; @Test public void test_getReposByUsernamePathVar_success() { @@ -98,4 +100,87 @@ public void test_getReposByUsernameReqParam_username_fail() { assertThat(result.getBody(), is(emptyIterable())); assertThat(result.getStatusCode(), is(HttpStatus.BAD_REQUEST)); } + + @Test + public void test_getReposByUsernameReqParam_username_blank_fail() { + // when + ResponseEntity> result = gitProjectsController + .getReposByUsernameReqParam(httpServletRequestMock, null); + + // then + verify(httpServletRequestMock, never()).getRequestURI(); + verify(httpServletRequestMock, never()).getHeader(anyString()); + verify(gitDetailsServiceMock, never()).mapRepositoriesToResponse(anyList()); + + assertThat(result, is(notNullValue())); + assertThat(result.getBody(), is(emptyIterable())); + assertThat(result.getStatusCode(), is(HttpStatus.BAD_REQUEST)); + } + + @Test + public void test_getIssuesByUsernameAndRepoPathVars_success() { + // when + ResponseEntity> result = gitProjectsController + .getIssuesByUsernameAndRepoPathVars(httpServletRequestMock, TEST_USERNAME_ALPHA, TEST_REPO); + + // then + verify(httpServletRequestMock).getRequestURI(); + verify(httpServletRequestMock, times(2)).getHeader(anyString()); + verify(gitDetailsServiceMock).getIssues(anyString(), anyString()); + verify(gitDetailsServiceMock).mapIssuesToResponse(anyList()); + + assertThat(result, is(notNullValue())); + assertThat(result.getStatusCode(), is(HttpStatus.OK)); + } + + @Test + public void test_getIssuesByUsernameAndRepoPathVars_username_invalid_fail() { + // when + ResponseEntity> result = gitProjectsController + .getIssuesByUsernameAndRepoPathVars(httpServletRequestMock, "service-accnt-123%^*$£'", TEST_REPO); + + // then + verify(httpServletRequestMock, never()).getRequestURI(); + verify(httpServletRequestMock, never()).getHeader(anyString()); + verify(gitDetailsServiceMock, never()).getIssues(anyString(), anyString()); + verify(gitDetailsServiceMock, never()).mapIssuesToResponse(anyList()); + + assertThat(result, is(notNullValue())); + assertThat(result.getBody(), is(emptyIterable())); + assertThat(result.getStatusCode(), is(HttpStatus.BAD_REQUEST)); + } + + @Test + public void test_getIssuesByUsernameAndRepoPathVars_project_invalid_fail() { + // when + ResponseEntity> result = gitProjectsController + .getIssuesByUsernameAndRepoPathVars(httpServletRequestMock, TEST_USERNAME_ALPHA, "project-123%^*$£'"); + + // then + verify(httpServletRequestMock, never()).getRequestURI(); + verify(httpServletRequestMock, never()).getHeader(anyString()); + verify(gitDetailsServiceMock, never()).getIssues(anyString(), anyString()); + verify(gitDetailsServiceMock, never()).mapIssuesToResponse(anyList()); + + assertThat(result, is(notNullValue())); + assertThat(result.getBody(), is(emptyIterable())); + assertThat(result.getStatusCode(), is(HttpStatus.BAD_REQUEST)); + } + + @Test + public void test_getIssuesByUsernameAndRepoPathVars_missing_path_vars_fail() { + // when + ResponseEntity> result = gitProjectsController + .getIssuesByUsernameAndRepoPathVars(httpServletRequestMock, null, null); + + // then + verify(httpServletRequestMock, never()).getRequestURI(); + verify(httpServletRequestMock, never()).getHeader(anyString()); + verify(gitDetailsServiceMock, never()).getIssues(anyString(), anyString()); + verify(gitDetailsServiceMock, never()).mapIssuesToResponse(anyList()); + + assertThat(result, is(notNullValue())); + assertThat(result.getBody(), is(emptyIterable())); + assertThat(result.getStatusCode(), is(HttpStatus.BAD_REQUEST)); + } } diff --git a/src/test/java/com/ironoc/portfolio/controller/HomeControllerTest.java b/src/test/java/com/ironoc/portfolio/controller/HomeControllerTest.java deleted file mode 100644 index e7e9f2e..0000000 --- a/src/test/java/com/ironoc/portfolio/controller/HomeControllerTest.java +++ /dev/null @@ -1,39 +0,0 @@ -package com.ironoc.portfolio.controller; - -import jakarta.servlet.http.HttpServletRequest; -import org.junit.jupiter.api.Test; -import org.junit.jupiter.api.extension.ExtendWith; -import org.mockito.InjectMocks; -import org.mockito.Mock; -import org.mockito.junit.jupiter.MockitoExtension; - -import static org.hamcrest.MatcherAssert.assertThat; -import static org.hamcrest.Matchers.is; -import static org.mockito.ArgumentMatchers.anyString; -import static org.mockito.Mockito.times; -import static org.mockito.Mockito.verify; - -@ExtendWith(MockitoExtension.class) -public class HomeControllerTest { - - @InjectMocks - private HomeController homeController; - - @Mock - private HttpServletRequest httpServletRequestMock; - - @Test - public void test_index_success() { - // given - String homeView = "index"; - - // when - String result = homeController.index(httpServletRequestMock); - - // then - verify(httpServletRequestMock).getRequestURI(); - verify(httpServletRequestMock, times(2)).getHeader(anyString()); - - assertThat(result, is(homeView)); - } -} diff --git a/src/test/java/com/ironoc/portfolio/job/GitDetailsRunnableTest.java b/src/test/java/com/ironoc/portfolio/job/GitDetailsRunnableTest.java new file mode 100644 index 0000000..2cceae4 --- /dev/null +++ b/src/test/java/com/ironoc/portfolio/job/GitDetailsRunnableTest.java @@ -0,0 +1,46 @@ +package com.ironoc.portfolio.job; + +import com.ironoc.portfolio.service.GitDetails; +import com.ironoc.portfolio.service.GitRepoCache; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.ExtendWith; +import org.mockito.InjectMocks; +import org.mockito.Mock; +import org.mockito.junit.jupiter.MockitoExtension; + +import static org.hamcrest.Matchers.emptyIterable; +import static org.hamcrest.Matchers.hasSize; +import static org.mockito.ArgumentMatchers.anyList; +import static org.mockito.ArgumentMatchers.anyString; +import static org.mockito.Mockito.verify; +import static org.hamcrest.MatcherAssert.assertThat; + +@ExtendWith(MockitoExtension.class) +public class GitDetailsRunnableTest { + + @InjectMocks + private GitDetailsRunnable gitDetailsRunnable; + + @Mock + private GitDetails gitDetailsMock; + + @Mock + private GitRepoCache gitRepoCacheMock; + + @Test + public void test_run_tearDown_success() { + // when + gitDetailsRunnable.run(); + + // then + verify(gitDetailsMock).getRepoDetails(anyString()); + verify(gitRepoCacheMock).put(anyString(), anyList()); + verify(gitDetailsMock).mapRepositoriesToResponse(anyList()); + + assertThat(gitDetailsRunnable.getUserIds(), hasSize(1)); + + gitDetailsRunnable.tearDown(); + assertThat(gitDetailsRunnable.getUserIds(), emptyIterable()); + } +} + diff --git a/src/test/java/com/ironoc/portfolio/service/GitDetailsServiceTest.java b/src/test/java/com/ironoc/portfolio/service/GitDetailsServiceTest.java index 3662543..17e5a4a 100644 --- a/src/test/java/com/ironoc/portfolio/service/GitDetailsServiceTest.java +++ b/src/test/java/com/ironoc/portfolio/service/GitDetailsServiceTest.java @@ -1,11 +1,14 @@ package com.ironoc.portfolio.service; import com.fasterxml.jackson.databind.ObjectMapper; +import com.fasterxml.jackson.databind.type.CollectionType; import com.ironoc.portfolio.client.Client; import com.ironoc.portfolio.config.PropertyConfigI; import com.ironoc.portfolio.domain.RepositoryDetailDomain; +import com.ironoc.portfolio.domain.RepositoryIssueDomain; import com.ironoc.portfolio.dto.RepositoryDetailDto; -import com.ironoc.portfolio.job.GitDetailsJob; +import com.ironoc.portfolio.dto.RepositoryIssueDto; +import com.ironoc.portfolio.job.GitDetailsRunnable; import com.ironoc.portfolio.utils.UrlUtils; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.extension.ExtendWith; @@ -13,11 +16,11 @@ import org.mockito.Mock; import org.mockito.junit.jupiter.MockitoExtension; -import javax.net.ssl.HttpsURLConnection; import java.io.File; import java.io.IOException; import java.io.InputStream; import java.util.Arrays; +import java.util.ArrayList; import java.util.Collections; import java.util.List; import java.util.Optional; @@ -44,13 +47,7 @@ public class GitDetailsServiceTest { private PropertyConfigI propertyConfigMock; @Mock - private ObjectMapper objectMapperMock; - - @Mock - private Client gitClient; - - @Mock - private HttpsURLConnection httpsURLConnectionMock; + private Client gitClientMock; @Mock private UrlUtils urlUtilsMock; @@ -58,7 +55,7 @@ public class GitDetailsServiceTest { @Mock private GitRepoCache gitRepoCacheMock; - private ObjectMapper objectMapper = new ObjectMapper(); + private final ObjectMapper objectMapper = new ObjectMapper(); private static final String TEST_URI = "https://unittest.github.com/users/{username}/repos"; @@ -85,35 +82,35 @@ public void test_get_repos_success() throws IOException { .isPrivate(false) .build(); - when(propertyConfigMock.getGitApiEndpoint()) + when(propertyConfigMock.getGitApiEndpointRepos()) .thenReturn(TEST_URI); when(urlUtilsMock.isValidURL(anyString())).thenReturn(true); - when(gitClient.createConn(anyString())).thenReturn(httpsURLConnectionMock); - when(gitClient.readInputStream(httpsURLConnectionMock)).thenReturn(jsonInputStream); - when(objectMapperMock.readValue(jsonInputStream, RepositoryDetailDto[].class)) - .thenReturn(objectMapper.readValue(jsonInputStream, RepositoryDetailDto[].class)); + when(propertyConfigMock.getGitApiEndpointRepos()).thenReturn(TEST_URI); + when(urlUtilsMock.isValidURL(anyString())).thenReturn(true); + CollectionType listType = objectMapper.getTypeFactory() + .constructCollectionType(ArrayList.class, RepositoryDetailDto.class); + when(gitClientMock.callGitHubApi(anyString(), anyString(), any(), anyString())) + .thenReturn(objectMapper.readValue(jsonInputStream, listType)); // when List results = gitDetailsService.getRepoDetails(testUserId); // then - verify(propertyConfigMock).getGitApiEndpoint(); + verify(propertyConfigMock).getGitApiEndpointRepos(); verify(urlUtilsMock).isValidURL(anyString()); - verify(propertyConfigMock).getGitApiEndpoint(); - verify(gitClient).createConn(anyString()); - verify(gitClient).readInputStream(any(HttpsURLConnection.class)); - verify(objectMapperMock).readValue(any(InputStream.class), any(Class.class)); - verify(gitClient).closeConn(any(InputStream.class)); -; + verify(gitClientMock).callGitHubApi(anyString(), anyString(), any(), anyString()); + assertThat(results, is(hasSize(2))); Optional result = results.stream().findFirst(); - assertThat(result.get().getName(), is(expected.getName())); - assertThat(result.get().getFullName(), is(expected.getFullName())); - assertThat(result.get().getDescription(), is(expected.getDescription())); - assertThat(result.get().getTopics(), is(expected.getTopics())); - assertThat(result.get().getHomePage(), is(expected.getHomePage())); - assertThat(result.get().getHtmlUrl(), is(expected.getHtmlUrl())); - assertThat(result.get().isPrivate(), is(expected.isPrivate())); + if (result.isPresent()) { + assertThat(result.get().getName(), is(expected.getName())); + assertThat(result.get().getFullName(), is(expected.getFullName())); + assertThat(result.get().getDescription(), is(expected.getDescription())); + assertThat(result.get().getTopics(), is(expected.getTopics())); + assertThat(result.get().getHomePage(), is(expected.getHomePage())); + assertThat(result.get().getHtmlUrl(), is(expected.getHtmlUrl())); + assertThat(result.get().isPrivate(), is(expected.isPrivate())); + } RepositoryDetailDto result2 = results.get(1); assertThat(result2.getName(), is("booking-sys")); assertThat(result2.getFullName(), is("conorheffron/booking-sys")); @@ -125,6 +122,51 @@ public void test_get_repos_success() throws IOException { assertThat(result2.isPrivate(), is(Boolean.TRUE)); } + @Test + public void test_get_issues_success() throws IOException { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_issues_response.json"); + String testRepo = "bio-cell-red-edge"; + String testUserId = "conor-h"; + String testBody = "Use React or Angular framework & JavaScript or TypeScript as implementation language? " + + "\r\n- Research & select best option."; + String testTitle = "Re-write frontend with React "; + String testIssueNo = "62"; + RepositoryIssueDto expected = RepositoryIssueDto.builder() + .number(testIssueNo) + .title(testTitle) + .body(testBody) + .build(); + + when(propertyConfigMock.getGitApiEndpointIssues()).thenReturn(TEST_URI); + when(urlUtilsMock.isValidURL(anyString())).thenReturn(true); + when(urlUtilsMock.isValidURL(anyString())).thenReturn(true); + CollectionType listType = objectMapper.getTypeFactory() + .constructCollectionType(ArrayList.class, RepositoryIssueDto.class); + when(gitClientMock.callGitHubApi(anyString(), anyString(), any(), anyString())) + .thenReturn(objectMapper.readValue(jsonInputStream, listType)); + + // when + List results = gitDetailsService.getIssues(testUserId, testRepo); + + // then + verify(propertyConfigMock).getGitApiEndpointIssues(); + verify(urlUtilsMock).isValidURL(anyString()); + verify(gitClientMock).callGitHubApi(anyString(), anyString(), any(), anyString()); + + assertThat(results, is(hasSize(2))); + Optional result = results.stream().findFirst(); + assertThat(result.get().getNumber(), is(expected.getNumber())); + assertThat(result.get().getTitle(), is(expected.getTitle())); + assertThat(result.get().getBody(), is(expected.getBody())); + RepositoryIssueDto result2 = results.get(1); + assertThat(result2.getNumber(), is("57")); + assertThat(result2.getTitle(), is("Setup LB, Support SSL")); + assertThat(result2.getBody(), is("- [x] 1. Setup LB\r\n- [ ] 2. " + + "Support SSL\r\n- [ ] 3. Setup domain, map to AWS LB")); + } + @Test public void test_get_repos_parseNull_values_success() throws IOException { // given @@ -139,25 +181,21 @@ public void test_get_repos_parseNull_values_success() throws IOException { .isPrivate(false) .build(); - when(propertyConfigMock.getGitApiEndpoint()).thenReturn(TEST_URI); + when(propertyConfigMock.getGitApiEndpointRepos()).thenReturn(TEST_URI); when(urlUtilsMock.isValidURL(anyString())).thenReturn(true); - when(gitClient.createConn(anyString())).thenReturn(httpsURLConnectionMock); - when(gitClient.readInputStream(httpsURLConnectionMock)).thenReturn(jsonInputStream); - when(objectMapperMock.readValue(jsonInputStream, RepositoryDetailDto[].class)) - .thenReturn(objectMapper.readValue(jsonInputStream, RepositoryDetailDto[].class)); + CollectionType listType = objectMapper.getTypeFactory() + .constructCollectionType(ArrayList.class, RepositoryDetailDto.class); + when(gitClientMock.callGitHubApi(anyString(), anyString(), any(), anyString())) + .thenReturn(objectMapper.readValue(jsonInputStream, listType)); // when List results = gitDetailsService.getRepoDetails(testUserId); // then - verify(propertyConfigMock).getGitApiEndpoint(); + verify(propertyConfigMock).getGitApiEndpointRepos(); verify(urlUtilsMock).isValidURL(anyString()); - verify(propertyConfigMock).getGitApiEndpoint(); - verify(gitClient).createConn(anyString()); - verify(gitClient).readInputStream(any(HttpsURLConnection.class)); - verify(objectMapperMock).readValue(any(InputStream.class), any(Class.class)); - verify(gitClient).closeConn(any(InputStream.class)); - ; + verify(gitClientMock).callGitHubApi(anyString(), anyString(), any(), anyString()); + assertThat(results, is(hasSize(1))); Optional result = results.stream().findFirst(); assertThat(result.get().getName(), is(expected.getName())); @@ -178,7 +216,7 @@ public void test_getRepoDetails_result_cached_success() { List results = gitDetailsService.getRepoDetails(testUserId); // then - verify(gitRepoCacheMock).get(GitDetailsJob.USERNAME_HOME_PAGE); + verify(gitRepoCacheMock).get(GitDetailsRunnable.USERNAME_HOME_PAGE); assertThat(results, is(notNullValue())); assertThat(results, is(hasSize(0))); @@ -188,13 +226,13 @@ public void test_getRepoDetails_result_cached_success() { public void test_getRepoDetails_url_invalid_fail() { // given String testUserId = "conorheffron-test-id"; - when(propertyConfigMock.getGitApiEndpoint()).thenReturn(TEST_URI); + when(propertyConfigMock.getGitApiEndpointRepos()).thenReturn(TEST_URI); // when List results = gitDetailsService.getRepoDetails(testUserId); // then - verify(propertyConfigMock).getGitApiEndpoint(); + verify(propertyConfigMock).getGitApiEndpointRepos(); assertThat(results, is(notNullValue())); assertThat(results, is(hasSize(0))); @@ -208,7 +246,7 @@ public void test_mapRepositoriesToResponse_success() throws IOException { // when List results = gitDetailsService.mapRepositoriesToResponse( - Arrays.asList(objectMapper.readValue(jsonInputStream, RepositoryDetailDto[].class))); + List.of(objectMapper.readValue(jsonInputStream, RepositoryDetailDto[].class))); assertThat(results, is(hasSize(2))); Optional result = results.stream().findFirst(); @@ -230,7 +268,41 @@ public void test_mapRepositoriesToResponse_success() throws IOException { assertThat(result2.getAppHome(), is("https://booking-sys-ebgefrdmh3afbhee.northeurope-01.azurewebsites.net/book/")); assertThat(result2.getRepoUrl(), is("https://github.com/conorheffron/booking-sys")); + jsonInputStream.close(); + } + @Test + public void test_mapResponseToRepositories_success() throws IOException { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_repo_detail_response.json"); + + // when + List results = gitDetailsService.mapResponseToRepositories( + Arrays.asList(objectMapper.readValue(jsonInputStream, RepositoryDetailDomain[].class))); + + assertThat(results, is(hasSize(2))); + Optional result = results.stream().findFirst(); + assertThat(result.get().getName(), is("bio-cell-red-edge")); + assertThat(result.get().getFullName(), is("conorheffron/bio-cell-red-edge")); + assertThat(result.get().getDescription(), + is("Edge Detection of Biological Cell (Image Processing Script)")); + String testTopics = "[Biology, computer-vision, image-processing, scikitlearn-machine-learning]"; + assertThat(result.get().getTopics(), + is(Arrays.asList(testTopics.substring(1, testTopics.length() - 1) + .split(", ")))); + assertThat(result.get().getHomePage(), + is("https://conorheffron.github.io/bio-cell-red-edge/")); + assertThat(result.get().getHtmlUrl(), + is("https://github.com/conorheffron/bio-cell-red-edge")); + RepositoryDetailDto result2 = results.get(1); + assertThat(result2.getName(), is("booking-sys")); + assertThat(result2.getFullName(), is(emptyString())); + assertThat(result2.getDescription(), is("python3 and django5 web app")); + assertThat(result2.getTopics(), is(emptyIterable())); + assertThat(result2.getHomePage(), + is("https://booking-sys-ebgefrdmh3afbhee.northeurope-01.azurewebsites.net/book/")); + assertThat(result2.getHtmlUrl(), is("https://github.com/conorheffron/booking-sys")); jsonInputStream.close(); } @@ -244,6 +316,7 @@ public void test_mapRepositoriesToResponse_parseNulls_success() throws IOExcepti List results = gitDetailsService.mapRepositoriesToResponse( Arrays.asList(objectMapper.readValue(jsonInputStream, RepositoryDetailDto[].class))); + // then assertThat(results, is(hasSize(1))); Optional result = results.stream().findFirst(); assertThat(result.get().getName(), is("conorheffron/ironoc-test")); @@ -254,4 +327,29 @@ public void test_mapRepositoriesToResponse_parseNulls_success() throws IOExcepti assertThat(result.get().getRepoUrl(), is(emptyString())); jsonInputStream.close(); } + + @Test + public void test_mapIssuesToResponse_success() throws IOException { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_issues_response.json"); + + // when + List results = gitDetailsService.mapIssuesToResponse( + Arrays.asList(objectMapper.readValue(jsonInputStream, RepositoryIssueDto[].class))); + + // then + assertThat(results, is(hasSize(2))); + Optional result = results.stream().findFirst(); + assertThat(result.get().getNumber(), is("62")); + assertThat(result.get().getTitle(), is("Re-write frontend with React ")); + assertThat(result.get().getBody(), is("Use React or Angular framework & JavaScript " + + "or TypeScript as implementation language? \r\n- Research & select best option.")); + RepositoryIssueDomain result2 = results.get(1); + assertThat(result2.getNumber(), is("57")); + assertThat(result2.getTitle(), is("Setup LB, Support SSL")); + assertThat(result2.getBody(), is("- [x] 1. Setup LB\r\n- [ ] 2. " + + "Support SSL\r\n- [ ] 3. Setup domain, map to AWS LB")); + jsonInputStream.close(); + } } diff --git a/src/test/java/com/ironoc/portfolio/service/GitRepoCacheServiceTest.java b/src/test/java/com/ironoc/portfolio/service/GitRepoCacheServiceTest.java new file mode 100644 index 0000000..782961d --- /dev/null +++ b/src/test/java/com/ironoc/portfolio/service/GitRepoCacheServiceTest.java @@ -0,0 +1,71 @@ +package com.ironoc.portfolio.service; + +import com.fasterxml.jackson.databind.ObjectMapper; +import com.ironoc.portfolio.domain.RepositoryDetailDomain; +import org.junit.jupiter.api.Test; +import org.junit.jupiter.api.extension.ExtendWith; +import org.mockito.InjectMocks; +import org.mockito.junit.jupiter.MockitoExtension; + +import java.io.File; +import java.io.IOException; +import java.io.InputStream; +import java.util.Collections; +import java.util.List; +import java.util.Optional; + +import static org.hamcrest.MatcherAssert.assertThat; +import static org.hamcrest.Matchers.hasSize; +import static org.hamcrest.Matchers.emptyString; +import static org.hamcrest.Matchers.is; +import static org.hamcrest.Matchers.notNullValue; +import static org.hamcrest.Matchers.nullValue; + +@ExtendWith(MockitoExtension.class) +public class GitRepoCacheServiceTest { + + @InjectMocks + private GitRepoCacheService gitRepoCacheService; + + @Test + public void test_cache_success() throws IOException { + // given + InputStream jsonInputStream = Thread.currentThread().getContextClassLoader() + .getResourceAsStream("json" + File.separator + "test_repo_detail_response.json"); + RepositoryDetailDomain[] dtos = new ObjectMapper().readValue(jsonInputStream, RepositoryDetailDomain[].class); + gitRepoCacheService.put("user1", Collections.emptyList()); + gitRepoCacheService.put("user-2", List.of(dtos)); + + // when + List results = gitRepoCacheService.get("user1"); + List results2 = gitRepoCacheService.get("user-2"); + List results3 = gitRepoCacheService.get("conorheffron-3"); + + // then + assertThat(results, is(notNullValue())); + assertThat(results, is(hasSize(0))); + assertThat(results2, is(hasSize(2))); + Optional result = results2.stream().findFirst(); + assertThat(result.get().getName(), is("bio-cell-red-edge")); + assertThat(result.get().getFullName(), is("conorheffron/bio-cell-red-edge")); + assertThat(result.get().getDescription(), + is("Edge Detection of Biological Cell (Image Processing Script)")); + assertThat(result.get().getTopics(), + is("[Biology, computer-vision, image-processing, scikitlearn-machine-learning]")); + assertThat(result.get().getAppHome(), + is("https://conorheffron.github.io/bio-cell-red-edge/")); + assertThat(result.get().getRepoUrl(), + is("https://github.com/conorheffron/bio-cell-red-edge")); + RepositoryDetailDomain result2 = results2.get(1); + assertThat(result2.getName(), is("booking-sys")); + assertThat(result2.getFullName(), is(nullValue())); + assertThat(result2.getDescription(), is("python3 and django5 web app")); + assertThat(result2.getTopics(), is(emptyString())); + assertThat(result2.getAppHome(), + is("https://booking-sys-ebgefrdmh3afbhee.northeurope-01.azurewebsites.net/book/")); + assertThat(result2.getRepoUrl(), is("https://github.com/conorheffron/booking-sys")); + jsonInputStream.close(); + assertThat(results3, is(nullValue())); + gitRepoCacheService.tearDown(); + } +} diff --git a/src/test/resources/json/test_issues_response.json b/src/test/resources/json/test_issues_response.json new file mode 100644 index 0000000..fb36ddc --- /dev/null +++ b/src/test/resources/json/test_issues_response.json @@ -0,0 +1,12 @@ +[ + { + "number": "62", + "title": "Re-write frontend with React \u003CPOC\u003E", + "body": "Use React or Angular framework & JavaScript or TypeScript as implementation language? \r\n- Research & select best option." + }, + { + "number": "57", + "title": "Setup LB, Support SSL", + "body": "- [x] 1. Setup LB\r\n- [ ] 2. Support SSL\r\n- [ ] 3. Setup domain, map to AWS LB" + } +] \ No newline at end of file diff --git a/src/test/resources/json/test_repo_detail_response.json b/src/test/resources/json/test_repo_detail_response.json new file mode 100644 index 0000000..5b117d7 --- /dev/null +++ b/src/test/resources/json/test_repo_detail_response.json @@ -0,0 +1,17 @@ +[ + { + "name": "bio-cell-red-edge", + "fullName": "conorheffron/bio-cell-red-edge", + "repoUrl": "https://github.com/conorheffron/bio-cell-red-edge", + "description": "Edge Detection of Biological Cell (Image Processing Script)", + "appHome": "https://conorheffron.github.io/bio-cell-red-edge/", + "topics": "[Biology, computer-vision, image-processing, scikitlearn-machine-learning]" + }, + { + "name": "booking-sys", + "repoUrl": "https://github.com/conorheffron/booking-sys", + "appHome": "https://booking-sys-ebgefrdmh3afbhee.northeurope-01.azurewebsites.net/book/", + "description": "python3 and django5 web app", + "topics": "" + } +] \ No newline at end of file